mirror of
https://github.com/Azgaar/Fantasy-Map-Generator.git
synced 2025-12-17 17:51:24 +01:00
* feat: render states - use global fn * feat: render states - separate pole detection from layer render * feat: render provinces * chore: unify drawFillWithGap * refactor: drawIce * refactor: drawBorders * refactor: drawHeightmap * refactor: drawTemperature * refactor: drawBiomes * refactor: drawPrec * refactor: drawPrecipitation * refactor: drawPopulation * refactor: drawCells * refactor: geColor * refactor: drawMarkers * refactor: drawScaleBar * refactor: drawScaleBar * refactor: drawMilitary * refactor: pump version to 1.104.00 * refactor: pump version to 1.104.00 * refactor: drawCoastline and createDefaultRuler * refactor: drawCoastline * refactor: Features module start * refactor: features - define distance fields * feat: drawFeatures * feat: drawIce don't hide * feat: detect coastline - fix issue with border feature * feat: separate labels rendering from generation process * feat: auto-update and restore layers * refactor - change layers * refactor - sort layers * fix: regenerate burgs to re-render layers * fix: getColor is not defined * fix: burgs overview - don't auto-show labels on hover * fix: redraw population on change * refactor: improve tooltip logic for burg labels and icons * chore: pump version to 1.104.0 * fefactor: edit coastline and lake * fix: minot fixes * fix: submap --------- Co-authored-by: Azgaar <azgaar.fmg@yandex.com>
69 lines
2 KiB
JavaScript
69 lines
2 KiB
JavaScript
"use strict";
|
|
|
|
function drawBurgIcons() {
|
|
TIME && console.time("drawBurgIcons");
|
|
|
|
icons.selectAll("circle, use").remove(); // cleanup
|
|
|
|
// capitals
|
|
const capitals = pack.burgs.filter(b => b.capital && !b.removed);
|
|
const capitalIcons = burgIcons.select("#cities");
|
|
const capitalSize = capitalIcons.attr("size") || 1;
|
|
const capitalAnchors = anchors.selectAll("#cities");
|
|
const capitalAnchorsSize = capitalAnchors.attr("size") || 2;
|
|
|
|
capitalIcons
|
|
.selectAll("circle")
|
|
.data(capitals)
|
|
.enter()
|
|
.append("circle")
|
|
.attr("id", d => "burg" + d.i)
|
|
.attr("data-id", d => d.i)
|
|
.attr("cx", d => d.x)
|
|
.attr("cy", d => d.y)
|
|
.attr("r", capitalSize);
|
|
|
|
capitalAnchors
|
|
.selectAll("use")
|
|
.data(capitals.filter(c => c.port))
|
|
.enter()
|
|
.append("use")
|
|
.attr("xlink:href", "#icon-anchor")
|
|
.attr("data-id", d => d.i)
|
|
.attr("x", d => rn(d.x - capitalAnchorsSize * 0.47, 2))
|
|
.attr("y", d => rn(d.y - capitalAnchorsSize * 0.47, 2))
|
|
.attr("width", capitalAnchorsSize)
|
|
.attr("height", capitalAnchorsSize);
|
|
|
|
// towns
|
|
const towns = pack.burgs.filter(b => b.i && !b.capital && !b.removed);
|
|
const townIcons = burgIcons.select("#towns");
|
|
const townSize = townIcons.attr("size") || 0.5;
|
|
const townsAnchors = anchors.selectAll("#towns");
|
|
const townsAnchorsSize = townsAnchors.attr("size") || 1;
|
|
|
|
townIcons
|
|
.selectAll("circle")
|
|
.data(towns)
|
|
.enter()
|
|
.append("circle")
|
|
.attr("id", d => "burg" + d.i)
|
|
.attr("data-id", d => d.i)
|
|
.attr("cx", d => d.x)
|
|
.attr("cy", d => d.y)
|
|
.attr("r", townSize);
|
|
|
|
townsAnchors
|
|
.selectAll("use")
|
|
.data(towns.filter(c => c.port))
|
|
.enter()
|
|
.append("use")
|
|
.attr("xlink:href", "#icon-anchor")
|
|
.attr("data-id", d => d.i)
|
|
.attr("x", d => rn(d.x - townsAnchorsSize * 0.47, 2))
|
|
.attr("y", d => rn(d.y - townsAnchorsSize * 0.47, 2))
|
|
.attr("width", townsAnchorsSize)
|
|
.attr("height", townsAnchorsSize);
|
|
|
|
TIME && console.timeEnd("drawBurgIcons");
|
|
}
|