mirror of
https://github.com/Azgaar/Fantasy-Map-Generator.git
synced 2025-12-16 17:31:24 +01:00
477 lines
No EOL
36 KiB
HTML
477 lines
No EOL
36 KiB
HTML
<!DOCTYPE html>
|
||
<head>
|
||
<title>Azgaar's Fantasy Map Generator Demo</title>
|
||
<meta name="author" content="Azgaar (Max Ganiev)">
|
||
<meta charset="utf-8">
|
||
<meta name="description" content="Azgaar's Fantasy Map Generator demo. Based on D3 Voronoi diagram rendered to svg.">
|
||
<script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>
|
||
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.min.js"></script>
|
||
<script src="https://d3js.org/d3.v4.min.js"></script>
|
||
<script src="https://d3js.org/d3-scale-chromatic.v1.min.js"></script>
|
||
<script src="https://mewo2.com/js/priority-queue.js"></script>
|
||
<script src="https://rawgit.com/LuisSevillano/9f6c9edd7f90ac6cca54ed744e28f3ee/raw/38f9774f83f00b286360db1ea97d851f79e594aa/polylabel.js"></script>
|
||
<script src="names.js"></script>
|
||
<link rel="stylesheet" type="text/css" href="index.css?version=0.52b"/>
|
||
<link rel="stylesheet" type="text/css" href="https://code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css"/>
|
||
<link rel="stylesheet" type="text/css" href="./font/fontello.css"/>
|
||
<script src="quantize.js"></script>
|
||
</head>
|
||
<body>
|
||
<svg xmlns="http://www.w3.org/2000/svg" width="960" height="540">
|
||
<defs>
|
||
<filter id="blurFilter" x="-1" y="-1" width="100" height="100">
|
||
<feGaussianBlur in="SourceGraphic" stdDeviation="0.2"/>
|
||
</filter>
|
||
<filter id="dropShadow">
|
||
<feGaussianBlur in="SourceAlpha" stdDeviation="2"/>
|
||
<feOffset dx="1" dy="2"/>
|
||
<feMerge>
|
||
<feMergeNode/>
|
||
<feMergeNode in="SourceGraphic"/>
|
||
</feMerge>
|
||
</filter>
|
||
<g id="deftemp">
|
||
<mask id="shape" x="0" y="0" width="100%" height="100%" fill="black"></mask>
|
||
</g>
|
||
<g id="defs-icons">
|
||
<symbol id="icon-anchor" viewBox="0 0 28 28">
|
||
<title>Anchor</title>
|
||
<path d="M15 4c0-0.547-0.453-1-1-1s-1 0.453-1 1 0.453 1 1 1 1-0.453 1-1zM28 18.5v5.5c0 0.203-0.125 0.391-0.313 0.469-0.063 0.016-0.125 0.031-0.187 0.031-0.125 0-0.25-0.047-0.359-0.141l-1.453-1.453c-2.453 2.953-6.859 4.844-11.688 4.844s-9.234-1.891-11.688-4.844l-1.453 1.453c-0.094 0.094-0.234 0.141-0.359 0.141-0.063 0-0.125-0.016-0.187-0.031-0.187-0.078-0.313-0.266-0.313-0.469v-5.5c0-0.281 0.219-0.5 0.5-0.5h5.5c0.203 0 0.391 0.125 0.469 0.313s0.031 0.391-0.109 0.547l-1.563 1.563c1.406 1.891 4.109 3.266 7.203 3.687v-10.109h-3c-0.547 0-1-0.453-1-1v-2c0-0.547 0.453-1 1-1h3v-2.547c-1.188-0.688-2-1.969-2-3.453 0-2.203 1.797-4 4-4s4 1.797 4 4c0 1.484-0.812 2.766-2 3.453v2.547h3c0.547 0 1 0.453 1 1v2c0 0.547-0.453 1-1 1h-3v10.109c3.094-0.422 5.797-1.797 7.203-3.687l-1.563-1.563c-0.141-0.156-0.187-0.359-0.109-0.547s0.266-0.313 0.469-0.313h5.5c0.281 0 0.5 0.219 0.5 0.5z"></path>
|
||
</symbol>
|
||
</g>
|
||
<pattern id="oceanPattern" width="100" height="100" patternUnits="userSpaceOnUse">
|
||
<filter id='image'>
|
||
<feImage x="0" y="0" width="100" height="100" xlink:href="">
|
||
</filter>
|
||
<rect width='100' height='100' filter="url(#image)" opacity='0.2'/>
|
||
</pattern>
|
||
<pattern id="mottling" width="16" height="9" patternUnits="userSpaceOnUse">
|
||
<filter id='turb'>
|
||
<feTurbulence type='fractalNoise' baseFrequency='.7' numOctaves='10' stitchTiles='stitch'/>
|
||
</filter>
|
||
<rect width='16' height='9' filter="url(#turb)"/>
|
||
</pattern>
|
||
</defs>
|
||
</svg>
|
||
<canvas id="canvas" width="960" height="540" style="opacity: 0;"></canvas>
|
||
<div id="optionsContainer">
|
||
<div id="collapsible">
|
||
<button id="optionsTrigger" class="options" title="Click to display Options">▶</button>
|
||
<button id="regenerate" class="options" title="Click to generate a new map">New Map!</button>
|
||
</div>
|
||
<div id="options">
|
||
<div class="drag-trigger"></div>
|
||
<div class="tab">
|
||
<button id="layoutTab" class="options">Layout</button>
|
||
<button id="styleTab" class="options">Style</button>
|
||
<button id="optionsTab" class="options">Options</button>
|
||
<button id="customizeTab" class="options">Customize</button>
|
||
</div>
|
||
<div id="layoutContent" class="tabcontent">
|
||
<p style="display: inline-block;">Select preset:</p>
|
||
<select id="layoutPreset">
|
||
<option value="layoutPolitical" selected>Political map</option>
|
||
<option value="layoutCultural">Cultural map</option>
|
||
<!-- <option value="layoutEconomical">Economical map</option> -->
|
||
<option value="layoutHeightmap">Heightmap</option>
|
||
<option value="layoutLandmass">Pure landmass</option>
|
||
</select>
|
||
<p>Displayed layers. Drag to move, click to toggle</p>
|
||
<div id="mapLayers">
|
||
<li title="Toggle Ocean, not movable" id="toggleOcean" onclick="$('#oceanPattern').fadeToggle()" class="solid">Ocean</li>
|
||
<li title="Toggle Landmass, not movable" id="toggleLandmass" onclick="$('#landmass').fadeToggle()" class="solid">Landmass</span></li>
|
||
<li title="Toggle Heightmap" id="toggleHeight" class="buttonoff">Heightmap</li>
|
||
<li title="Toggle Cultures map" id="toggleCultures" class="buttonoff">Cultures</li>
|
||
<li title="Toggle Routes" id="toggleRoutes" onclick="$('#routes').fadeToggle()">Routes</li>
|
||
<li title="Toggle Rivers" id="toggleRivers" onclick="$('#rivers').fadeToggle()">Rivers</li>
|
||
<li title="Toggle Countries" id="toggleCountries">Countries</li>
|
||
<li title="Toggle Borders" id="toggleBorders" onclick="$('#borders').fadeToggle()">Borders</li>
|
||
<li title="Toggle Relief icons" id="toggleRelief" onclick="$('#terrain').fadeToggle()">Relief</li>
|
||
<li title="Toggle Grid" id="toggleGrid" class="buttonoff" onclick="$('#grid').fadeToggle()">Grid</li>
|
||
<li title="Toggle Labels" id="toggleLabels" onclick="$('#labels').fadeToggle()">Labels</li>
|
||
<li title="Toggle Burg icons" id="toggleIcons" onclick="$('#burgs').fadeToggle()">Burgs</li>
|
||
</div>
|
||
</div>
|
||
<div id="styleContent" class="tabcontent">
|
||
<p style="display: inline-block;">Select element:</p>
|
||
<select id="styleElementSelect">
|
||
<option value="oceanBase" selected>Ocean</option>
|
||
<option value="landmass">Landmass</option>
|
||
<option value="terrs">Heightmap</option>
|
||
<option value="cults">Cultures</option>
|
||
<option value="roads">Roads</option>
|
||
<option value="trails">Trails</option>
|
||
<option value="searoutes">Searoutes</option>
|
||
<option value="rivers">Rivers</option>
|
||
<option value="terrain">Relief</option>
|
||
<option value="regions">Countries</option>
|
||
<option value="stateBorders">State Borders</option>
|
||
<option value="neutralBorders">Neutral Borders</option>
|
||
<option value="coastline">Coastline</option>
|
||
<option value="lakes">Lakes</option>
|
||
<option value="grid">Grid</option>
|
||
<option value="labels">Labels</option>
|
||
<option value="burgs">Burgs</option>
|
||
</select>
|
||
<div id="styleInputs">
|
||
<div id="styleFill">
|
||
Fill: <input id="styleFillInput" type="color" value="#5E4FA2"/>
|
||
<output id="styleFillOutput">#5E4FA2</output>
|
||
</div>
|
||
<div id="styleStroke">
|
||
Stroke: <input id="styleStrokeInput" type="color" value="#5E4FA2"/>
|
||
<output id="styleStrokeOutput">#5E4FA2</output>
|
||
</div>
|
||
<div id="styleMultiple">Colors:</div>
|
||
<div id="styleStrokeWidth">
|
||
<br>Stroke width: <input id="styleStrokeWidthInput" type="range" min="0" max="3" step="0.01" value="1">
|
||
<output id="styleStrokeWidthOutput">1</output>
|
||
</div>
|
||
<div id="styleStrokeDasharray">
|
||
<br>Stroke dasharray: <input id="styleStrokeDasharrayInput" class="pureInput" value="1 2">
|
||
</div>
|
||
<div id="styleStrokeLinecap">
|
||
<br>Stroke linecap: <select id="styleStrokeLinecapInput" class="pureInput">
|
||
<option value="inherit" selected>Inherit</option>
|
||
<option value="butt">Butt</option>
|
||
<option value="round">Round</option>
|
||
<option value="square">Square</option>
|
||
</select>
|
||
</div>
|
||
<div id="styleFontSize">
|
||
<br>Font size: <button title="Multiply all Fonts size by 1.1" id="styleFontPlus">+</button><button title="Multiply all Fonts size by 0.9" id="styleFontMinus">-</button>
|
||
</div>
|
||
<div id="styleSize">
|
||
<br>Radius: <button title="Multiply Radius by 1.1" id="styleFillPlus">+</button><button title="Multiply Radius by 0.9" id="styleFillMinus">-</button>
|
||
<span> Stroke: </span><button title="Multiply Stroke-width by 1.1" id="styleStrokePlus">+</button><button title="Multiply Stroke-width by 0.9" id="styleStrokeMinus">-</button>
|
||
</div>
|
||
<div id="styleOpacity">
|
||
<br>Opacity: <input id="styleOpacityInput" type="range" min="0" max="1" step="0.01" value="1">
|
||
<output id="styleOpacityOutput">1</output>
|
||
</div>
|
||
<div id="styleFilter">
|
||
<br>Filter: <select id="styleFilterInput" class="pureInput">
|
||
<option value="">None</option>
|
||
<option value="url(#blurFilter)" selected>Blur</option>
|
||
<option value="url(#dropShadow)" selected>Shadow</option>
|
||
</select>
|
||
</div>
|
||
<div id="styleScheme">
|
||
<br>Color scheme: <select id="styleSchemeInput" class="pureInput">
|
||
<option value="bright" selected>Bright</option>
|
||
<option value="light">Light</option>
|
||
<option value="green">Green</option>
|
||
<option value="monochrome">Monochrome</option>
|
||
</select>
|
||
</div>
|
||
</div>
|
||
<p>Toggle filters:</p>
|
||
<button onclick="$('svg').toggleClass('grayscale')" class="buttonoff">Grayscale</button>
|
||
<button onclick="$('svg').toggleClass('sepia')" class="buttonoff">Sepia</button>
|
||
<button onclick="$('svg').toggleClass('tint')" class="buttonoff">Tint</button>
|
||
<button onclick="$('svg').toggleClass('dingy')" class="buttonoff">Dingy</button>
|
||
</div>
|
||
<div id="optionsContent" class="tabcontent">
|
||
<p>Generate new map to apply the options!</p>
|
||
<table>
|
||
<tr>
|
||
<td title="Select template to be used for a Heightmap generation">Heightmap template</td>
|
||
<td>
|
||
<select id="templateInput">
|
||
<option value="Random" selected>Random</option>
|
||
<option value="Volcano">Volcano</option>
|
||
<option value="High Island">High Island</option>
|
||
<option value="Low Island">Low Island</option>
|
||
<option value="Continents">Continents</option>
|
||
<option value="Archipelago">Archipelago</option>
|
||
<option value="Atoll">Atoll</option>
|
||
</select>
|
||
</td>
|
||
<td></td>
|
||
</tr>
|
||
<tr>
|
||
<td title="Set the graph size. A non-default values are not properly tested yet! Works good with converted maps">Graph size</td>
|
||
<td>
|
||
<input id="sizeInput" type="range" min="0.8" max="4" step="0.1" value="1">
|
||
</td>
|
||
<td>
|
||
<output id="sizeOutput">1</output>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td title="Define how many Settlements should be placed">Burgs count</td>
|
||
<td>
|
||
<input id="manorsInput" type="range" min="0" max="1000" value="500">
|
||
</td>
|
||
<td>
|
||
<output id="manorsOutput">500</output>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td title="Define how many Countries should be created">Countries count</td>
|
||
<td>
|
||
<input id="regionsInput" type="range" min="0" max="100" value="13">
|
||
</td>
|
||
<td>
|
||
<output id="regionsOutput">13</output>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td title="Define Countries size variety. Set to 0 to have all countries sized the same">Countries disbalance</td>
|
||
<td>
|
||
<input id="powerInput" type="range" min="0" max="10" step="0.2" value="5">
|
||
</td>
|
||
<td>
|
||
<output id="powerOutput">5</output><br>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td title="Maximum distance to a closer manor to consider polygon as a Neutral Land">Burg influence radius</td>
|
||
<td>
|
||
<input id="neutralInput" type="range" min="1" max="100" step="1" value="100">
|
||
</td>
|
||
<td>
|
||
<output id="neutralOutput">100</output>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td title="Define the land swampiness. Increase to see more marshes (turn on 'Relief' layer)">Swampness</td>
|
||
<td>
|
||
<input id="swampinessInput" type="range" min="0" max="100" value="10">
|
||
</td>
|
||
<td>
|
||
<output id="swampinessOutput">10</output>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td title="Define the coastline sharpness. Decrease for a more round land shape">Coastline curvature</td>
|
||
<td>
|
||
<input id="sharpnessInput" type="range" min="0.1" max="0.2" value="0.2" step="0.05">
|
||
</td>
|
||
<td>
|
||
<output id="sharpnessOutput">0.2</output>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td title="Define the Land outline layers scheme">Coast outline layers</td>
|
||
<td>
|
||
<select id="outlineLayers">
|
||
<option value="random">Random</option>
|
||
<option value="-6,-3,-1" selected>-6,-3,-1</option>
|
||
<option value="-9,-6,-3,-1">-9,-6,-3,-1</option>
|
||
<option value="-6,-5,-4,-3,-2,-1">-6,-5,-4,-3,-2,-1</option>
|
||
<option value="-9,-8,-7,-6,-5,-4,-3,-2,-1">-9,-8,-7,-6,-5,-4,-3,-2,-1</option>
|
||
<option value="-6,-4,-2">-6,-4,-2</option>
|
||
<option value="-8,-6,-4,-2">-8,-6,-4,-2</option>
|
||
</select>
|
||
</td>
|
||
<td></td>
|
||
</tr>
|
||
<tr>
|
||
<td title="Select the coastline rendering style">Coastline style</td>
|
||
<td>
|
||
<select id="curveType">
|
||
<option value="Catmull–Rom" selected>Catmull–Rom</option>
|
||
<option value="Linear">Linear</option>
|
||
<option value="Basis">Basis</option>
|
||
<option value="Cardinal">Cardinal</option>
|
||
<option value="Step">Step</option>
|
||
</select>
|
||
</td>
|
||
<td></td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div id="customizeContent" class="tabcontent" style="display: block;">
|
||
<p title="Click "Start" to initiate customization, "Complete" to finalize the Heightmap">Heightmap customization:</p>
|
||
<div id="customizationMain">
|
||
<button title="Roll back to Heightmap customization" id="fromHeightmap">Roll back</button>
|
||
<button title="Start from scratch" id="fromScratch">Clear All</button>
|
||
<button class="buttonoff" title="Finalize the Heightmap. Not allowed if landmass area is insufficient" id="getMap" disabled="disabled">Complete</button>
|
||
</div>
|
||
<div id="customizationMenu" style="display: none;">
|
||
<div id="customizeTools">
|
||
<label title="Customization Tools">Tools:</label><br>
|
||
<button title="Open template editor" id="applyTemplate">Apply Template</button>
|
||
<button title="Open Image Convertion master" id="convertImage">Convert Image</button>
|
||
<button title="Rescale elevation" id="rescale">Rescale</button>
|
||
</div>
|
||
<div id="customizeBrushes">
|
||
<label title="Select brush and click on the map to use it">Free Draw brushes:</label><br>
|
||
<button id="brushElevate" title="Click and drag the map to increase cells elevation" class="radio">↥</button>
|
||
<button id="brushDepress" title="Click and drag the map to decrease cells elevation" class="radio">↧</button>
|
||
<button id="brushAlign" title="Click and drag the map to align cells elevation" class="radio">=</button>
|
||
<button id="brushSmooth" title="Click and drag the map to smooth cells elevation" class="radio">~</button>
|
||
<button id="brushHill" title="Click on the map to place a Hill" class="radio pressed">H</button>
|
||
<button id="brushPit" title="Click on the map to place a Pit" class="radio">P</button>
|
||
<button id="brushRange" title="Select two points to place a Range" class="radio">R</button>
|
||
<button id="brushTrough" title="Select two points to place a Trought" class="radio">T</button>
|
||
<button title="Smooth all heights" id="smoothHeights">≈</button>
|
||
<br><label title="Set the brush power">Brush power:</label>
|
||
<input id="brushPower" type="range" min="0.01" max="0.3" step="0.01" value="0.05">
|
||
<output id="brushPowerOutput">0.05</output><br>
|
||
</div><br>
|
||
<label title="Count of Land cells and Land-Map ratio">Landmass: <span id="landmassCounter">0</span></label><hr>
|
||
</div>
|
||
<p>Click to add a Label:</p>
|
||
<button id="addLabel" class="radio">Label</button>
|
||
<button id="addBurg" class="radio">Burg</button>
|
||
<div>
|
||
<p>Save / Load map:</p>
|
||
<button id="saveMap" title="Save in .map format to be loaded later as fully functional map">Save Map</button>
|
||
<button id="loadMap" title="Load fully functional map in a .map format">Load Map</button>
|
||
<button id="savePNG" title="Download the visible part of the map as .png image">Get PNG</button>
|
||
<button id="saveSVG" title="Download the map as .svg image for later use in vector graphics editors">Get SVG</button>
|
||
<input type="file" accept=".map" id="fileToLoad">
|
||
</div>
|
||
</div>
|
||
<div id="sticked">
|
||
<button id="randomMap" title="Generate new random map based on options being set" class="options">New Map</button>
|
||
<div style="float:right; margin-right:5px;">
|
||
<!-- Zoom should be smooth and centrified, to be fixed later
|
||
<button id="zoomMinus" title="Zoom out" class="options">-</button>
|
||
<button id="zoomPlus" title="Zoom in" class="options">+</button>
|
||
-->
|
||
<button id="zoomReset" title="Reset map zoom to default" class="options">Reset Zoom</button>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="labelEditor" style="display: none">
|
||
<button id="editGroupButton" title="Edit label Group" class="editButton icon-list-bullet"></button>
|
||
<select id="editGroupSelect" title="Select Group for this label" class="editTrigger"/></select>
|
||
<input id="editGroupInput" placeholder="new name" title="Declare new Group for this label" class="editTrigger"/>
|
||
<span id="editGroupNew" title="Declare new Group for this label" class="editButtonS icon-plus-squared-alt"></span>
|
||
<span id="editGroupRemove" title="Remove the Group with all labels" class="editButtonS icon-trash-empty"></span>
|
||
<button id="editTextButton" title="Edit label Text" class="editButton icon-pencil"></button>
|
||
<input id="editText" class="editTrigger"/>
|
||
<span id="editTextRandom" title="Generate random name" class="editButtonS icon-shuffle"></span>
|
||
<button id="editFontButton" title="Select Font for the entire Group" class="editButton icon-font"></button>
|
||
<span id="editExternalFont" title="Fetch fonts by linking @font-face declaration" class="editButtonS icon-link"></span>
|
||
<select id="editFontSelect" class="editTrigger" title="Select one of the default Fonts"></select>
|
||
<input id="editFontInput" placeholder="link to @font-face" title="Fetch fonts by linking @font-face declaration" class="editTrigger"/>
|
||
<i id="editSizeIcon" class="icon-text-height"></i>
|
||
<input id="editSize" title="Change Font size for the entire Group" class="editTrigger" value="14" type="number" min="1" max="100" step=".5"/>
|
||
<button id="editStyleButton" title="Select Color for the entire Group" class="editButton icon-brush"></button>
|
||
<input id="editColor" type="color" class="editTrigger" value="#3e3e4b">
|
||
<i id="editOpacityIcon" class="icon-adjust"></i>
|
||
<input id="editOpacity" title="Change Opacity for the entire Group" class="editTrigger" value="1" type="number" min="0" max="1" step="0.02">
|
||
<i id="editShadowIcon" class="icon-clone"></i>
|
||
<input id="editShadow" title="Change Shadow for the entire Group" class="editTrigger" value="1" type="number" min="0" max="1" step="0.02" disabled="true">
|
||
<button id="editAngleButton" title="Rotate the label" class="editButton icon-ccw"></button>
|
||
<input id="editAngle" class="editTrigger" value="0" type="range" min="-180" max="180" step="0.2" oninput="editAngleValue.innerHTML = Math.abs(this.value)+'°'">
|
||
<span id="editAngleValue" class="editValue">0°</span>
|
||
<button id="editCopy" title="Copy the label" class="editButton icon-clone"></button>
|
||
<button id="editRemoveSingle" title="Remove the label" class="editButton icon-trash"></button>
|
||
</div>
|
||
|
||
<div id="riverEditor" style="display: none">
|
||
<button id="riverRisize" title="Resize (rotate, scale) river" class="editButton icon-arrows-cw"></button>
|
||
<i id="riverAngleIcon" title="Rotate river" class="dialog-icon icon-cw"></i>
|
||
<input id="riverAngle" class="editTrigger" value="0" type="range" min="-180" max="180" step="0.2">
|
||
<span id="riverAngleValue" class="editValue">0°</span>
|
||
<i id="riverScaleIcon" title="Change river scale" class="dialog-icon icon-link-ext"></i>
|
||
<input id="riverScale" class="editTrigger" value="1" type="number" min="0.1" max="3" step="0.01">
|
||
<span id="riverReset" title="Reset transformation" class="editButtonS icon-cancel-circled2"></span>
|
||
<button id="riverRenegerate" title="Regenerate river" class="editButton icon-shuffle"></button>
|
||
<button id="riverAddPoint" title="Click to add a river point" class="editButton icon-plus-squared-alt"></button>
|
||
<button id="riverRemovePoint" title="Click on red circle to remove river point" class="editButton icon-minus-squared-alt"></button>
|
||
<button id="riverCopy" title="Copy river" class="editButton icon-clone"></button>
|
||
<button id="riverNew" title="Create new river clicking on map" class="editButton icon-map-pin"></button>
|
||
<button id="riverRemove" title="Remove river" class="editButton icon-trash"></button>
|
||
</div>
|
||
|
||
<div id="templateEditor" style="display: none">
|
||
<div id="templateTop">
|
||
Base template: <select id="templateSelect" data-prev="templateNew" title="Select base template"/>
|
||
<option value="templateCustom" selected>Custom</option>
|
||
<option value="templateVolcano">Volcano</option>
|
||
<option value="templateHighIsland">High Island</option>
|
||
<option value="templateLowIsland">Low Island</option>
|
||
<option value="templateContinents">Continents</option>
|
||
<option value="templateArchipelago">Archipelago</option>
|
||
<option value="templateAtoll">Atoll</option>
|
||
</select>
|
||
</div>
|
||
<div id="templateTools">
|
||
<button id="templateMountain" title="Mountain: high big blob. Can be placed only once and only as a first step" class="noicon">M</button>
|
||
<button id="templateHill" title="Hill: small blob" class="noicon">H</button>
|
||
<button id="templatePit" title="Pit: round depression" class="noicon">P</button>
|
||
<button id="templateRange" title="Pit: elongated elevation" class="noicon">R</button>
|
||
<button id="templateTrough" title="Trough: elongated depression" class="noicon">T</button>
|
||
<button id="templateStrait" title="Strait: centered vertical depression" class="noicon">S</button>
|
||
<button id="templateAdd" title="Add or subtract value from all heights" class="noicon">+</button>
|
||
<button id="templateMultiply" title="Multiply all heights by factor" class="noicon">*</button>
|
||
<button id="templateSmooth" title="Smooth the map replacing cell heights by an average values of its neighbors" class="noicon">~</button>
|
||
</div>
|
||
<div id="templateBody" data-changed=0>
|
||
<div data-type="Mountain">Mountain
|
||
<span title="Remove step" class="icon-trash-empty" onclick="this.parentNode.parentNode.removeChild(this.parentNode)"></span>
|
||
</div>
|
||
</div>
|
||
<div id="templateBottom">
|
||
<button id="templateRun" title="Apply current template" class="icon-play"></button>
|
||
<button id="templateClear" title="Clear the map" class="icon-cancel-circled2"></button>
|
||
<button id="templateComplete" title="Finalize the Heightmap. Not allowed if insufficient land area available" class="icon-check"></button>
|
||
<button id="templateLoad" title="Open previously saved template" class="icon-upload"></button>
|
||
<input type="file" accept=".txt" id="templateToLoad" style="display: none;">
|
||
<button id="templateSave" title="Save template" class="icon-download"></button>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="imageConverter" style="display: none">
|
||
<div id="convertImageButtons">
|
||
<input type="file" accept="image/*" id="imageToLoad" style="display: none;">
|
||
<button id="convertImageLoad" title="Load image to convert" class="icon-upload"></button>
|
||
<button id="convertAutoLum" title="Auto-assign colors based on liminosity" class="icon-adjust"></button>
|
||
<button id="convertAutoHue" title="Auto-assign colors based on hue" class="icon-brush"></button>
|
||
<button id="convertColorsMinus" title="Reduce the number of colors. Minimal number is 3" class="icon-minus-squared"></button>
|
||
<button id="convertColorsPlus" title="Increase the number of colors. Minimal number is 256" class="icon-plus-squared"></button>
|
||
<input id="convertColors" value="12" style="display: none;"/>
|
||
<button id="convertImageGrid" title="Toggle grid" class="icon-eye"></button>
|
||
<button id="convertOverlayButton" title="Change overlay opacity" class="icon-clone"></button>
|
||
<input id="convertOverlay" title="Change overlay opacity" type="range" min="0" max="1" step="0.01" value="0" style="display: none;">
|
||
<span id="convertOverlayValue" title="Overlay opacity" style="display: none;">0</span>
|
||
<button id="convertComplete" title="Complete conversion. All unassigned colors will be considered as ocean" class="icon-check"></button>
|
||
</div>
|
||
<div id="colorsSelect">
|
||
<div id="colorScheme"></div>
|
||
<span id="colorsSelectValue">0</span>
|
||
</div>
|
||
<div id="colorsAssigned" style="display: none">
|
||
<label>Assigned colors: </label><br>
|
||
</div>
|
||
<div id="colorsUnassigned" style="display: none">
|
||
<label>Unassigned colors: </label><br>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="heightmapRescaler" style="display: none">
|
||
<div id="rescalerButtons">
|
||
<button id="rescaleMultiply" title="Multiply heights by value" class="icon-cancel-circled"></button>
|
||
<button id="rescaleAdd" title="Add value to heights" class="icon-plus-circled"></button>
|
||
<input id="rescaleModifier" class="pureInput" title="Set modifier value. Value may be positive, negative, fractional, '^2', '^3'" type="number" value="1.1" min="0" max="10" step="0.01">
|
||
<input id="rescaleSubject" class="pureInput" title="Select change subject: 'all', 'land' or interval with hyphen withount space, e.g. '0.17-0.2'" value="land">
|
||
</div>
|
||
</div>
|
||
|
||
<div id="alert" title="Warning!" style="display: none">
|
||
<p id="alertMessage">Warning!</p>
|
||
</div>
|
||
|
||
<div id="statusbar">
|
||
Coord: <span id="lx">0</span>/<span id="ly">0</span>;
|
||
Cell: <span id="cell">0</span>;
|
||
Height: <span id="height">0</span>;
|
||
Type: <span id="feature">no</span>;
|
||
Flux: <span id="flux">0</span>;
|
||
Region: <span id="region">no</span>;
|
||
Culture: <span id="culture">no</span>;
|
||
River: <span id="river">no</span>;
|
||
Path: <span id="path">no</span>;
|
||
Score: <span id="score">no</span>.
|
||
</div>
|
||
|
||
<script type="text/javascript" src="script.js?version=0.52b"></script>
|
||
</body> |