mirror of
https://github.com/infinitefusion/infinitefusion-e18.git
synced 2025-12-09 22:24:58 +00:00
Renamed townmapgen, embedded its graphics in the html file
This commit is contained in:
420
Town Map Generator.html
Normal file
420
Town Map Generator.html
Normal file
@@ -0,0 +1,420 @@
|
||||
<body>
|
||||
<div>
|
||||
<u>Town Map Generator</u>
|
||||
</div>
|
||||
<form name="mf" action="javascript:void(null)">
|
||||
<table>
|
||||
<tr>
|
||||
<td>Filename:</td>
|
||||
<td><input type="text" name="filename" value="mapRegion0.png"/></td>
|
||||
<td><input type="button" name="btnChange" value="Change"/></td>
|
||||
<td>Name of the region graphic (in Graphics/UI/Town Map/)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Name:</td>
|
||||
<td><input type="text" name="name" value="Sample Region"/></td>
|
||||
<td><input type="button" name="btnChange2" value="Change"/></td>
|
||||
<td>Name of the region</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Square width:</td>
|
||||
<td><input type="text" name="sqwidth" size="4" min="1" max="16" value="16"/></td>
|
||||
<td><input type="button" name="btnRefreshWidth" value="Refresh"/></td>
|
||||
<td>Width of each point in the Town Map (in pixels)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Square height:</td>
|
||||
<td><input type="text" name="sqheight" size="4" min="1" max="16" value="16"/></td>
|
||||
<td><input type="button" name="btnRefreshHeight" value="Refresh"/></td>
|
||||
<td>Height of each point in the Town Map (in pixels)</td>
|
||||
</tr>
|
||||
</table>
|
||||
</form>
|
||||
<hr/>
|
||||
<div>
|
||||
<u>Edit point properties</u><br />
|
||||
Click on a point in the Town Map to edit its properties.
|
||||
</div>
|
||||
<div id="map">
|
||||
<img name="map" src="Graphics/UI/Town Map/mapRegion0.png" alt="" width="480" height="320"/>
|
||||
</div>
|
||||
<form name="f" action="javascript:void(null)">
|
||||
<table>
|
||||
<tr>
|
||||
<td>Co-ordinates:</td>
|
||||
<td><input type="text" name="curpos" readonly="readonly"/></td>
|
||||
<td>X and Y co-ordinates of this point in the Town Map (click in the map above)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Name:</td>
|
||||
<td><input type="text" name="locname"/></td>
|
||||
<td>Name of this location</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Landmark:</td>
|
||||
<td><input type="text" name="poi"/></td>
|
||||
<td>Name of a landmark found in this location</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Fly destination:</td>
|
||||
<td><input type="text" name="healing"/></td>
|
||||
<td>Map ID, X and Y tile co-ordinates the player will appear at when Flying to this location</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Switch:</td>
|
||||
<td><input type="text" name="swtch"/></td>
|
||||
<td>Number of a Game Switch that needs to be ON to see this point's name/landmark and to Fly to this location</td>
|
||||
</tr>
|
||||
</table>
|
||||
<div>
|
||||
<input type="button" name="btnSave" value="Save" disabled="disabled"/>
|
||||
<input type="button" name="btnCancel" value="Cancel"/><br/ >
|
||||
<hr/>
|
||||
<u>PBS file "town_map.txt" text for this region</u><br />
|
||||
<textarea name="data" rows="10" cols="70"></textarea><br/ >
|
||||
<input type="button" name="btnLoad" value="Load into map"/>
|
||||
Apply the data in this box to the map above<br/ >
|
||||
When you're done, copy this text into "town_map.txt". Remember that it needs a section line (a number in square brackets).
|
||||
</div>
|
||||
</form>
|
||||
<script type="text/javascript">
|
||||
choiceX=-1
|
||||
choiceY=-1
|
||||
mappoints=[]
|
||||
mpelements=[]
|
||||
|
||||
function target(event){
|
||||
return event.target||event.srcElement
|
||||
}
|
||||
|
||||
function addChild(e){
|
||||
if(document.documentElement){
|
||||
document.documentElement.appendChild(e)
|
||||
} else{
|
||||
document.body.appendChild(e)
|
||||
}
|
||||
}
|
||||
|
||||
function removeChild(e){
|
||||
if(document.documentElement){
|
||||
document.documentElement.removeChild(e)
|
||||
} else{
|
||||
document.body.removeChild(e)
|
||||
}
|
||||
}
|
||||
|
||||
function positionedOffset(element) {
|
||||
var valueT = 0, valueL = 0;
|
||||
do {
|
||||
valueT += element.offsetTop || 0;
|
||||
valueL += element.offsetLeft || 0;
|
||||
element = element.offsetParent;
|
||||
if (element) {
|
||||
p = element.style.position;
|
||||
if (p == 'relative' || p == 'absolute') break;
|
||||
}
|
||||
} while (element);
|
||||
return [valueL, valueT];
|
||||
}
|
||||
|
||||
function pointerX(event) {
|
||||
return event.pageX || (event.clientX +
|
||||
(document.documentElement.scrollLeft || document.body.scrollLeft));
|
||||
}
|
||||
|
||||
function pointerY(event) {
|
||||
return event.pageY || (event.clientY +
|
||||
(document.documentElement.scrollTop || document.body.scrollTop));
|
||||
}
|
||||
|
||||
function elementPos(event){
|
||||
t=target(event)
|
||||
po=positionedOffset(t)
|
||||
return [(pointerX(event))-po[0],(pointerY(event))-po[1]]
|
||||
}
|
||||
|
||||
function elementPosObject(event,other){
|
||||
t=other
|
||||
po=positionedOffset(t)
|
||||
return [(pointerX(event))-po[0],(pointerY(event))-po[1]]
|
||||
}
|
||||
|
||||
function attachEvent(element,name,observer,useCapture){
|
||||
if (element.addEventListener) {
|
||||
element.addEventListener(name, observer, useCapture||false);
|
||||
} else if (element.attachEvent) {
|
||||
element.attachEvent('on' + name, observer);
|
||||
}
|
||||
}
|
||||
|
||||
function qstr(text){
|
||||
var temp;
|
||||
temp = text.toString();
|
||||
while (true){
|
||||
if (temp == '') return text;
|
||||
if (temp.indexOf("'") >= 0) break;
|
||||
if (temp.indexOf('"') >= 0) break;
|
||||
if (temp.indexOf(' ') >= 0) break;
|
||||
if (temp.indexOf(',') >= 0) break;
|
||||
return temp;
|
||||
}
|
||||
// temp = temp.replace(/\'/g,"''");
|
||||
// temp = temp.replace(/\"/g,"\"\"");
|
||||
return temp
|
||||
// return "\"" + temp + "\"";
|
||||
}
|
||||
|
||||
function CsvNextToken(dataobj){
|
||||
var i;
|
||||
var text;
|
||||
var c,n;
|
||||
var inside;
|
||||
var value;
|
||||
var q = '';
|
||||
inside = false;
|
||||
value = '';
|
||||
var skip = false;
|
||||
var data=dataobj[0]
|
||||
if (data == '') return '';
|
||||
text = '';
|
||||
for (i = 0; i < data.length; ++i){
|
||||
if (skip){
|
||||
skip = false;
|
||||
continue;
|
||||
}
|
||||
c = data.charAt(i);
|
||||
n = '';
|
||||
if (inside){
|
||||
if (c == q) {
|
||||
if (i < data.length-1) n = data.charAt(i+1);
|
||||
if (n == q){
|
||||
value = value + c;
|
||||
skip = true;
|
||||
continue;
|
||||
}
|
||||
inside = false;
|
||||
continue;
|
||||
}
|
||||
value = value + c;
|
||||
continue;
|
||||
}
|
||||
// if ((c == '"') || (c == "'")){
|
||||
// inside = true;
|
||||
// q = c;
|
||||
// continue;
|
||||
// }
|
||||
if (c == ',') break;
|
||||
value = value + c;
|
||||
}
|
||||
if (i >= (data.length-1)) { dataobj[0]= ''; }
|
||||
else{dataobj[0]=data.substr(i+1);}
|
||||
dataobj[0]=dataobj[0].replace(/^\s+/,"").replace(/\s+$/,"")
|
||||
return value;
|
||||
}
|
||||
|
||||
///////////////////////////
|
||||
function loadMapPoints(){
|
||||
mappoints=[]
|
||||
lines=document.f.data.value.split("\n")
|
||||
for(var i=0;i<lines.length;i++){
|
||||
lines[i]=lines[i].replace(/\s+$/,"")
|
||||
if(!/^\#/.test(lines[i])&&!/^\s*$/.test(lines[i])){
|
||||
esec=/^\s*\[\s*\d+\s*\]\s*$/.exec(lines[i])
|
||||
if(esec){
|
||||
continue;
|
||||
}
|
||||
e=/^\s*(\w+)\s*=\s*(.*)$/.exec(lines[i])
|
||||
if(!e){
|
||||
alert("Bad line syntax in line "+(i+1))
|
||||
}
|
||||
if(e[1]=="Filename"){
|
||||
o=document.getElementById("map")
|
||||
o.innerHTML='<img name="map" src="Graphics/UI/Town Map/'+e[2]+'" alt="" width="480" height="320"/'+'>'
|
||||
document.mf.filename.value=e[2]
|
||||
} else if(e[1]=="Name"){
|
||||
document.mf.name.value=e[2]
|
||||
} else if(e[1]=="Point"){
|
||||
data=[e[2]]
|
||||
mappt=[]
|
||||
mappt[0]=parseInt(CsvNextToken(data),10)
|
||||
mappt[1]=parseInt(CsvNextToken(data),10)
|
||||
mappt[2]=CsvNextToken(data)
|
||||
mappt[3]=CsvNextToken(data)
|
||||
mappt[4]=[CsvNextToken(data),CsvNextToken(data),CsvNextToken(data)]
|
||||
mappt[5]=CsvNextToken(data)
|
||||
mappoints[mappoints.length]=mappt
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function createMapPoint(imgfile,x,y){
|
||||
e=document.createElement("div")
|
||||
if(imgfile=="selpoint.bmp"){
|
||||
e.innerHTML="<img src='' alt=''/>"
|
||||
}
|
||||
if(imgfile=="knownpoint.bmp"){
|
||||
e.innerHTML="<img src='' alt=''/>"
|
||||
}
|
||||
// e.innerHTML="<img src='"+imgfile+"' alt=''/>"
|
||||
e.style.left=elempos[0]+x*document.mf.sqwidth.value+(document.mf.sqwidth.value-8)/2
|
||||
e.style.top=elempos[1]+y*document.mf.sqheight.value+(document.mf.sqheight.value-8)/2
|
||||
e.style.position="absolute"
|
||||
attachEvent(e,"mousemove",MapMouseMove)
|
||||
attachEvent(e,"click",MapClick)
|
||||
return e
|
||||
}
|
||||
|
||||
function showMapPoints(){
|
||||
for(var i=0;i < mpelements.length ; i++){ //>
|
||||
removeChild(mpelements[i])
|
||||
}
|
||||
mpelements=[]
|
||||
elempos=positionedOffset(document.images.map)
|
||||
for(var i=0;i<mappoints.length;i++){//>
|
||||
e=createMapPoint("knownpoint.bmp",mappoints[i][0],mappoints[i][1])
|
||||
addChild(e)
|
||||
mpelements[mpelements.length]=e
|
||||
}
|
||||
if(choiceX!=-1 || choiceY!=-1){
|
||||
e=createMapPoint("selpoint.bmp",choiceX,choiceY)
|
||||
addChild(e)
|
||||
mpelements[mpelements.length]=e
|
||||
}
|
||||
}
|
||||
|
||||
function MapMouseMove(e){
|
||||
if(choiceX==-1 && choiceY==-1){
|
||||
elempos=elementPosObject(e,document.getElementById("map"))
|
||||
if (elempos[0]>=0 && elempos[0]<480 && elempos[1]>=0 && elempos[1]<320){
|
||||
setMapPoint(Math.floor(elempos[0]/document.mf.sqwidth.value),
|
||||
Math.floor(elempos[1]/document.mf.sqheight.value))
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function MapClick(e){
|
||||
elempos=elementPosObject(e,document.getElementById("map"))
|
||||
if(elempos[0]>=0 && elempos[0]<480 && elempos[1]>=0 && elempos[1]<320){
|
||||
choiceX=Math.floor(elempos[0]/document.mf.sqwidth.value)
|
||||
choiceY=Math.floor(elempos[1]/document.mf.sqheight.value)
|
||||
setMapPoint(Math.floor(elempos[0]/document.mf.sqwidth.value),
|
||||
Math.floor(elempos[1]/document.mf.sqheight.value))
|
||||
document.f.btnSave.disabled=false
|
||||
showMapPoints()
|
||||
}
|
||||
}
|
||||
|
||||
function getbase(fn){
|
||||
if(fn.lastIndexOf("/")>=0){
|
||||
fn=fn.substr(fn.lastIndexOf("/")+1)
|
||||
}
|
||||
if(fn.lastIndexOf("\\")>=0){
|
||||
fn=fn.substr(fn.lastIndexOf("\\")+1)
|
||||
}
|
||||
return fn
|
||||
}
|
||||
|
||||
function genMapPoints(){
|
||||
ret=""
|
||||
ret+="Filename = "+qstr(getbase(document.images.map.src))+"\r\n"
|
||||
ret+="Name = "+qstr(document.mf.name.value)+"\r\n"
|
||||
for(var i=0;i<mappoints.length;i++){
|
||||
ret+="Point = "+[mappoints[i][0],mappoints[i][1],
|
||||
qstr(mappoints[i][2]),qstr(mappoints[i][3]),
|
||||
mappoints[i][4][0]!=null?mappoints[i][4][0]:"",
|
||||
mappoints[i][4][1]!=null?mappoints[i][4][1]:"",
|
||||
mappoints[i][4][2]!=null?mappoints[i][4][2]:"",
|
||||
mappoints[i][5]]+"\r\n"
|
||||
}
|
||||
document.f.data.value=ret
|
||||
showMapPoints()
|
||||
}
|
||||
|
||||
function setMapPoint(x,y){
|
||||
document.f.curpos.value=[x,y]
|
||||
for(var i=0;i<mappoints.length;i++){
|
||||
if(mappoints[i][0]==x && mappoints[i][1]==y){
|
||||
document.f.locname.value=mappoints[i][2]
|
||||
document.f.poi.value=mappoints[i][3]
|
||||
document.f.healing.value=mappoints[i][4]
|
||||
document.f.swtch.value=mappoints[i][5]
|
||||
return
|
||||
}
|
||||
}
|
||||
document.f.locname.value=""
|
||||
document.f.poi.value=""
|
||||
document.f.healing.value=""
|
||||
document.f.swtch.value=""
|
||||
}
|
||||
|
||||
function addMapPoint(x,y){
|
||||
for(var i=0;i<mappoints.length;i++){
|
||||
if(mappoints[i][0]==x && mappoints[i][1]==y){
|
||||
mappoints[i][2]=document.f.locname.value
|
||||
mappoints[i][3]=document.f.poi.value
|
||||
mappoints[i][4]=document.f.healing.value.split(",")
|
||||
mappoints[i][5]=document.f.swtch.value
|
||||
return
|
||||
}
|
||||
}
|
||||
mappoints[mappoints.length]=[x,y,
|
||||
document.f.locname.value,
|
||||
document.f.poi.value,
|
||||
document.f.healing.value.split(","),
|
||||
document.f.swtch.value,
|
||||
]
|
||||
}
|
||||
|
||||
attachEvent(window,"load",function(e){
|
||||
genMapPoints()
|
||||
attachEvent(document.images.map,"mouseout",function(e){
|
||||
if(choiceX==-1 && choiceY==-1){
|
||||
document.f.curpos.value=""
|
||||
}
|
||||
})
|
||||
attachEvent(document.getElementById("map"),"mousemove",MapMouseMove)
|
||||
attachEvent(document.getElementById("map"),"click",MapClick)
|
||||
attachEvent(document.f.btnSave,"click",function(e){
|
||||
if(choiceX!=-1 || choiceY!=-1){
|
||||
addMapPoint(choiceX,choiceY)
|
||||
genMapPoints()
|
||||
target(e).disabled=true
|
||||
choiceX=choiceY=-1
|
||||
showMapPoints()
|
||||
}
|
||||
})
|
||||
attachEvent(document.f.btnCancel,"click",function(e){
|
||||
if(choiceX!=-1||choiceY!=-1){
|
||||
setMapPoint(choiceX,choiceY)
|
||||
choiceX=choiceY=-1
|
||||
showMapPoints()
|
||||
}
|
||||
})
|
||||
attachEvent(document.f.btnLoad,"click",function(e){
|
||||
loadMapPoints()
|
||||
genMapPoints()
|
||||
choiceX=choiceY=-1
|
||||
showMapPoints()
|
||||
})
|
||||
attachEvent(document.mf.btnChange,"click",function(e){
|
||||
document.images.map.src="Graphics/UI/Town Map/"+document.mf.filename.value
|
||||
genMapPoints()
|
||||
showMapPoints()
|
||||
})
|
||||
attachEvent(document.mf.btnChange2,"click",function(e){
|
||||
genMapPoints()
|
||||
showMapPoints()
|
||||
})
|
||||
attachEvent(document.mf.btnRefreshWidth,"click",function(e){
|
||||
choiceX=choiceY=-1
|
||||
document.f.curpos.value=""
|
||||
showMapPoints()
|
||||
})
|
||||
attachEvent(document.mf.btnRefreshHeight,"click",function(e){
|
||||
choiceX=choiceY=-1
|
||||
document.f.curpos.value=""
|
||||
showMapPoints()
|
||||
})
|
||||
})
|
||||
</script>
|
||||
Reference in New Issue
Block a user