v 0.8.05b

This commit is contained in:
Azgaar 2019-04-25 21:47:08 +03:00
parent 9aa369b6df
commit 6cb21bbead
6 changed files with 66 additions and 44 deletions

View file

@ -10,7 +10,7 @@
console.time('generateCultures');
cells = pack.cells;
cells.culture = new Int8Array(cells.i.length); // cell cultures
let count = +culturesInput.value;
let count = +culturesInput.value;
const populated = cells.i.filter(i => cells.s[i]).sort((a, b) => cells.s[b] - cells.s[a]); // cells sorted by population
if (populated.length < count * 25) {
@ -38,8 +38,8 @@
}
}
pack.cultures = d3.shuffle(getDefault()).slice(0, count);
const centers = d3.quadtree();
pack.cultures = getRandomCultures(count);
const centers = d3.quadtree();
const colors = getColors(count);
pack.cultures.forEach(function(culture, i) {
@ -60,6 +60,17 @@
const invalidBase = pack.cultures.some(c => !nameBase[c.base]);
if (invalidBase) applyDefaultNamesData();
function getRandomCultures(c) {
const d = getDefault();
const cultures = [];
while (cultures.length < c) {
let culture = d[0];
do {culture = d[rand(d.length-1)];} while (Math.random() > culture.odd || cultures.find(c => c.name === culture.name))
cultures.push(culture);
}
return cultures;
}
// culture center tends to be placed in a density populated cell
function placeCultureCenter() {
let center, spacing = (graphWidth + graphHeight) / count;
@ -99,36 +110,38 @@
const getDefault = function() {
return [
{name:"Shwazen", base:0},
{name:"Angshire", base:1},
{name:"Luari", base:2},
{name:"Tallian", base:3},
{name:"Astellian", base:4},
{name:"Slovan", base:5},
{name:"Norse", base:6},
{name:"Elladan", base:7},
{name:"Romian", base:8},
{name:"Soumi", base:9},
{name:"Koryo", base:10},
{name:"Hantzu", base:11},
{name:"Yamoto", base:12},
{name:"Portuzian", base:13},
{name:"Nawatli", base:14},
{name:"Vengrian", base: 15},
{name:"Turchian", base: 16},
{name:"Berberan", base: 17},
{name:"Eurabic", base: 18},
{name:"Inuk", base: 19},
{name:"Euskati", base: 20},
{name:"Negarian", base: 21},
{name:"Keltan", base: 22},
{name:"Efratic", base: 23},
{name:"Tehrani", base: 24},
{name:"Maui", base: 25},
{name:"Carnatic", base: 26},
{name:"Inqan", base: 27},
{name:"Kiswaili", base: 28},
{name:"Vietic", base: 29}
{name:"Shwazen", base:0, odd: .7},
{name:"Angshire", base:1, odd: 1},
{name:"Luari", base:2, odd: .6},
{name:"Tallian", base:3, odd: .6},
{name:"Astellian", base:4, odd: .6},
{name:"Slovan", base:5, odd: .7},
{name:"Norse", base:6, odd: .7},
{name:"Elladan", base:7, odd: .7},
{name:"Romian", base:8, odd: .7},
{name:"Soumi", base:9, odd: .4},
{name:"Koryo", base:10, odd: .5},
{name:"Hantzu", base:11, odd: .5},
{name:"Yamoto", base:12, odd: .5},
{name:"Portuzian", base:13, odd: .4},
{name:"Nawatli", base:14, odd: .2},
{name:"Vengrian", base: 15, odd: .2},
{name:"Turchian", base: 16, odd: .2},
{name:"Berberan", base: 17, odd: .2},
{name:"Eurabic", base: 18, odd: .2},
{name:"Inuk", base: 19, odd: .1},
{name:"Euskati", base: 20, odd: .1},
{name:"Negarian", base: 21, odd: .05},
{name:"Keltan", base: 22, odd: .1},
{name:"Efratic", base: 23, odd: .1},
{name:"Tehrani", base: 24, odd: .1},
{name:"Maui", base: 25, odd: .05},
{name:"Carnatic", base: 26, odd: .1},
{name:"Inqan", base: 27, odd: .1},
{name:"Kiswaili", base: 28, odd: .1},
{name:"Vietic", base: 29, odd: .1}//,
//{name:"Guantzu", base:30, odd: 1},
//{name:"Ulus", base:31, odd: .1}
];
}

View file

@ -378,7 +378,7 @@ function editCultures() {
}
function addCulture() {
const defaultCultures = Cultures.getDefault();
const defaultCultures = Cultures.getDefault();
let culture, base, name;
if (pack.cultures.length < defaultCultures.length) {
// add one of the default cultures

View file

@ -337,9 +337,6 @@ function togglePopulation() {
function drawPopulation() {
population.selectAll("line").remove();
const cells = pack.cells, p = cells.p, burgs = pack.burgs;
// pack.cells.pop.reduce((s=0,v) => s+v)
// pack.burgs.map(b => b.population).reduce((s=0,v) => s+v)
const show = d3.transition().duration(2000).ease(d3.easeSinIn);
const rural = Array.from(cells.i.filter(i => cells.pop[i] > 0), i => [p[i][0], p[i][1], p[i][1] - cells.pop[i] / 8]);
@ -348,7 +345,7 @@ function drawPopulation() {
.attr("x2", d => d[0]).attr("y2", d => d[1])
.transition(show).attr("y2", d => d[2]);
const urban = burgs.filter(b => b.i).map(b => [b.x, b.y, b.y - b.population / 8 * urbanization.value]);
const urban = burgs.filter(b => b.i && !b.removed).map(b => [b.x, b.y, b.y - b.population / 8 * urbanization.value]);
population.select("#urban").selectAll("line").data(urban).enter().append("line")
.attr("x1", d => d[0]).attr("y1", d => d[1])
.attr("x2", d => d[0]).attr("y2", d => d[1])

View file

@ -167,7 +167,8 @@ function selectStyleElement() {
if (sel === "gridOverlay") styleGrid.style.display = "block";
if (sel === "terrain") styleRelief.style.display = "block";
if (sel === "texture") styleTexture.style.display = "block";
if (sel === "routes" || sel === "labels" || sel == "anchors" || sel == "burgIcons" || sel === "lakes") {styleGroup.style.display = "block";}
if (sel === "routes" || sel === "labels" || sel == "anchors" || sel == "burgIcons" || sel === "lakes") styleGroup.style.display = "block";
if (sel === "markers") styleMarkers.style.display = "block";
if (sel === "population") {
stylePopulation.style.display = "block";