mirror of
https://github.com/islehorse/HISP.git
synced 2025-04-06 05:05:40 +12:00
ROLLIN AROUND AT THE SPEED OF *TRANSPORT*
This commit is contained in:
parent
f3f59d26eb
commit
f72cd3e9cb
13 changed files with 701 additions and 112 deletions
|
@ -35,6 +35,7 @@
|
|||
"location_format":" <I>You are%META% </I>",
|
||||
"tile_format":"<B>%TILENAME%</B>",
|
||||
"nothing_message":"^LYou see nothing on the ground of interest.^R1",
|
||||
"transport_format":"^R1^LTransport via %METHOD% to %PLACE%^R1^I%ICON%^T4Trip Costs $%COST% one way. ^B1M%XY%^BY%ID%",
|
||||
"exit_this_place":"^X",
|
||||
"end_of_meta":"^Z",
|
||||
"nearby":{
|
||||
|
@ -470,40 +471,7 @@
|
|||
{"passable":true,"tile_type":"LAVA"},
|
||||
{"passable":true,"tile_type":"LAVA"}
|
||||
],
|
||||
"overlay_tiles":{
|
||||
"passibility":[true,false,false,false,false,false,false,false,false,false,false,
|
||||
false,false,false,false,false,true,false,false,false,false,false,true,true,true,
|
||||
false,false,false,false,true,true,true,true,true,true,true,true,true,true,true,
|
||||
true,true,true,true,true,false,false,false,true,false,false,false,false,true,true,
|
||||
true,false,true,true,true,true,true,true,true,true,true,true,true,true,true,true,
|
||||
true,true,true,true,true,false,false,false,true,true,true,true,true,true,true,true,
|
||||
true,true,true,true,true,true,true,true,true,true,true,true,true,true,true,true,
|
||||
false,true,true,true,true,true,true,true,true,true,true,true,true,true,true,true,
|
||||
true,true,true,true,true,true,true,true,true,true,true,true,true,true,true,true,
|
||||
true,false,true,true,true,true,true,true,true,true,true,true,true,true,true,true,
|
||||
true,true,true,true,true,true,true,true,true,true,true,true,true,true,true,true,
|
||||
true,true,true,true,true,true,true,true,true,true,true,true,true,true,true,true,
|
||||
false,false,true,true,true,true,false,false,true,true,true,true,true,true,true,
|
||||
true,true,true,true,true,true,true,true,true,true,true,true,true,true,true,true,
|
||||
true,true,true,true,true,true,false,false,true,true,true,true,true,true,true,true,
|
||||
true,true,true,false,false,false,false,false,false,false,false,true,true,true,
|
||||
true,true,true,true,true,true,true,true,true,true,true,false,false,false,false,
|
||||
true,false,true,true,true,true,true,true,true,true,true,true,true,true,false,false,
|
||||
true,true,true,false,true,false,false,false,false,false,false,false,false,false,true,
|
||||
true,true,true,true,true,true,true,true,true,true,true,false,false,true,true,true,
|
||||
true,false,false,true,false,true,true,true,true,true,true,true,true,true,true,true,
|
||||
true,true,true,true,true,true,true,false,false,false,false,false,false,false,false,
|
||||
false,false,false,false,false,false,false,false,false,false,false,false,false,false,
|
||||
false,false,false,false,false,false,false,true,true,false,false,false,false,false,false,
|
||||
false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,
|
||||
false,false,false,true,true,true,true,true,true,true,true,false,false,false,false,false,
|
||||
false,true,true,true,true,true,false,true,false,false,true,true,true,true,true,true,true,
|
||||
true,false,true,true,true,true,true,false,false,true,true,true,true,true,true,true,false,
|
||||
false,false,false,false,false,false,false,false,false,false,false,true,true,true,true,true,
|
||||
true,false,true,true,true,false,false,false,false,false,true,false,false,false,false,false,
|
||||
false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,
|
||||
false,false,false,false,false,false,false,true,false,true,true,true,true,true,true,true,true,
|
||||
true,false,false,false,false,true],
|
||||
"overlay_tiles":{
|
||||
"tile_depth":[3,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,3,0,0,0,1,1,3,3,3,1,1,1,1,3,3,3,
|
||||
3,3,3,3,3,3,3,3,3,3,3,3,3,1,1,1,3,1,1,1,1,3,2,3,1,3,3,3,3,3,3,3,3,3,3,3,3,3,3,
|
||||
3,2,2,2,2,1,1,1,3,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,1,3,2,2,2,2,2,
|
||||
|
@ -525,6 +493,249 @@
|
|||
3,3,1,1,1,1,3,3,3,3],
|
||||
}
|
||||
},
|
||||
"transport":
|
||||
{
|
||||
"wagon_cutscene":"wagoncutscene",
|
||||
"boat_cutscene":"boatcutscene",
|
||||
"ballon_cutscene":"ballooncutscene",
|
||||
"transport_points":[
|
||||
{"x":507,"y":179,"places":[7,8,50,52,65,70,98,144]},
|
||||
{"x":570,"y":255,"places":[9]},
|
||||
{"x":413,"y":320,"places":[10,11,43,48]},
|
||||
{"x":447,"y":149,"places":[12,36,57,140]},
|
||||
{"x":520,"y":67,"places":[13,38,66,72,156]},
|
||||
{"x":571,"y":308,"places":[14,25]},
|
||||
{"x":384,"y":259,"places":[15,42,61]},
|
||||
{"x":472,"y":409,"places":[16,96,124]},
|
||||
{"x":518,"y":139,"places":[17]},
|
||||
{"x":524,"y":187,"places":[18,19,112]},
|
||||
{"x":433,"y":318,"places":[20,22,34,113]},
|
||||
{"x":557,"y":231,"places":[21,23,114]},
|
||||
{"x":548,"y":346,"places":[24,95,126]},
|
||||
{"x":521,"y":61,"places":[27,28]},
|
||||
{"x":468,"y":35,"places":[26]},
|
||||
{"x":555,"y":40,"places":[29]},
|
||||
{"x":473,"y":425,"places":[30]},
|
||||
{"x":550,"y":440,"places":[31]},
|
||||
{"x":636,"y":252,"places":[32]},
|
||||
{"x":536,"y":359,"places":[33]},
|
||||
{"x":384,"y":98,"places":[37,39,55]},
|
||||
{"x":35,"y":15,"places":[40]},
|
||||
{"x":332,"y":318,"places":[41,44]},
|
||||
{"x":395,"y":341,"places":[45]},
|
||||
{"x":389,"y":351,"places":[46]},
|
||||
{"x":266,"y":370,"places":[47]},
|
||||
{"x":329,"y":189,"places":[49,53,97]},
|
||||
{"x":384,"y":170,"places":[51,54,56,58,62]},
|
||||
{"x":372,"y":418,"places":[59,149]},
|
||||
{"x":386,"y":418,"places":[60]},
|
||||
{"x":616,"y":145,"places":[63,64,71,132,146]},
|
||||
{"x":627,"y":72,"places":[67,68,69,130]},
|
||||
{"x":941,"y":56,"places":[73]},
|
||||
{"x":936,"y":55,"places":[74]},
|
||||
{"x":947,"y":62,"places":[75]},
|
||||
{"x":951,"y":66,"places":[76]},
|
||||
{"x":944,"y":48,"places":[77]},
|
||||
{"x":940,"y":50,"places":[78]},
|
||||
{"x":896,"y":95,"places":[79]},
|
||||
{"x":894,"y":98,"places":[80]},
|
||||
{"x":956,"y":47,"places":[81,133,148]},
|
||||
{"x":961,"y":46,"places":[82]},
|
||||
{"x":701,"y":154,"places":[83]},
|
||||
{"x":705,"y":154,"places":[84]},
|
||||
{"x":442,"y":126,"places":[85]},
|
||||
{"x":447,"y":125,"places":[86]},
|
||||
{"x":924,"y":44,"places":[87]},
|
||||
{"x":920,"y":43,"places":[88]},
|
||||
{"x":962,"y":73,"places":[89]},
|
||||
{"x":967,"y":73,"places":[90]},
|
||||
{"x":929,"y":98,"places":[91]},
|
||||
{"x":931,"y":95,"places":[92]},
|
||||
{"x":869,"y":71,"places":[93]},
|
||||
{"x":870,"y":74,"places":[94]},
|
||||
{"x":244,"y":164,"places":[99,100,128]},
|
||||
{"x":625,"y":230,"places":[101]},
|
||||
{"x":677,"y":314,"places":[102]},
|
||||
{"x":634,"y":210,"places":[103]},
|
||||
{"x":623,"y":220,"places":[104,105,106]},
|
||||
{"x":640,"y":216,"places":[107]},
|
||||
{"x":616,"y":209,"places":[108]},
|
||||
{"x":658,"y":273,"places":[109]},
|
||||
{"x":715,"y":222,"places":[110]},
|
||||
{"x":677,"y":210,"places":[111]},
|
||||
{"x":470,"y":285,"places":[115,116,117]},
|
||||
{"x":650,"y":315,"places":[118,120,121]},
|
||||
{"x":633,"y":344,"places":[119]},
|
||||
{"x":204,"y":356,"places":[122]},
|
||||
{"x":618,"y":448,"places":[123,125]},
|
||||
{"x":115,"y":179,"places":[127,137]},
|
||||
{"x":722,"y":68,"places":[129,131,136]},
|
||||
{"x":974,"y":39,"places":[134]},
|
||||
{"x":774,"y":105,"places":[135,154]},
|
||||
{"x":153,"y":65,"places":[138]},
|
||||
{"x":490,"y":142,"places":[139]},
|
||||
{"x":969,"y":276,"places":[141]},
|
||||
{"x":965,"y":387,"places":[142]},
|
||||
{"x":565,"y":168,"places":[143,145]},
|
||||
{"x":873,"y":20,"places":[147]},
|
||||
{"x":336,"y":471,"places":[150]},
|
||||
{"x":73,"y":274,"places":[151]},
|
||||
{"x":59,"y":261,"places":[152]},
|
||||
{"x":752,"y":248,"places":[153]},
|
||||
{"x":406,"y":28,"places":[155]}
|
||||
],
|
||||
"transport_places":[
|
||||
{"id":7,"cost":300,"goto_x":446,"goto_y":149,"type":"BOAT","place_title":"Wington on Bird Isle"},
|
||||
{"id":8,"cost":400,"goto_x":520,"goto_y":66,"type":"BOAT","place_title":"Snow Isle"},
|
||||
{"id":9,"cost":300,"goto_x":572,"goto_y":308,"type":"BOAT","place_title":"Shellton on Turtle Isle"},
|
||||
{"id":10,"cost":400,"goto_x":383,"goto_y":259,"type":"BOAT","place_title":"Flipperton on Dolphin Isle"},
|
||||
{"id":11,"cost":300,"goto_x":472,"goto_y":410,"type":"BOAT","place_title":"Hotton on Desert Isle"},
|
||||
{"id":12,"cost":300,"goto_x":508,"goto_y":179,"type":"BOAT","place_title":"Earton on Horse Isle"},
|
||||
{"id":13,"cost":400,"goto_x":508,"goto_y":179,"type":"BOAT","place_title":"Earton on Horse Isle"},
|
||||
{"id":14,"cost":300,"goto_x":570,"goto_y":254,"type":"BOAT","place_title":"Treeton on Horse Isle"},
|
||||
{"id":15,"cost":400,"goto_x":414,"goto_y":320,"type":"BOAT","place_title":"Appleton on Horse Isle"},
|
||||
{"id":16,"cost":300,"goto_x":414,"goto_y":320,"type":"BOAT","place_title":"Appleton on Horse Isle"},
|
||||
{"id":17,"cost":100,"goto_x":508,"goto_y":179,"type":"BOAT","place_title":"Earton on Horse Isle"},
|
||||
{"id":18,"cost":200,"goto_x":434,"goto_y":318,"type":"WAGON","place_title":"Appleton"},
|
||||
{"id":19,"cost":100,"goto_x":557,"goto_y":232,"type":"WAGON","place_title":"Treeton"},
|
||||
{"id":20,"cost":200,"goto_x":525,"goto_y":187,"type":"WAGON","place_title":"Earton"},
|
||||
{"id":21,"cost":100,"goto_x":525,"goto_y":187,"type":"WAGON","place_title":"Earton"},
|
||||
{"id":23,"cost":250,"goto_x":434,"goto_y":318,"type":"WAGON","place_title":"Appleton"},
|
||||
{"id":22,"cost":250,"goto_x":557,"goto_y":232,"type":"WAGON","place_title":"Treeton"},
|
||||
{"id":24,"cost":200,"goto_x":572,"goto_y":308,"type":"BOAT","place_title":"Shellton on Turtle Isle"},
|
||||
{"id":25,"cost":200,"goto_x":548,"goto_y":347,"type":"BOAT","place_title":"Hoof Isle"},
|
||||
{"id":27,"cost":150,"goto_x":469,"goto_y":35,"type":"WAGON","place_title":"Chillton"},
|
||||
{"id":26,"cost":150,"goto_x":522,"goto_y":61,"type":"WAGON","place_title":"Snow Isle Docks"},
|
||||
{"id":28,"cost":150,"goto_x":556,"goto_y":40,"type":"WAGON","place_title":"Christmas Isle"},
|
||||
{"id":29,"cost":150,"goto_x":522,"goto_y":61,"type":"WAGON","place_title":"Snow Isle Docks"},
|
||||
{"id":30,"cost":100,"goto_x":550,"goto_y":441,"type":"WAGON","place_title":"Santon"},
|
||||
{"id":31,"cost":100,"goto_x":472,"goto_y":425,"type":"WAGON","place_title":"Hotton"},
|
||||
{"id":32,"cost":25,"goto_x":611,"goto_y":240,"type":"BOAT","place_title":"Nearest Horse Isle Coast"},
|
||||
{"id":33,"cost":200,"goto_x":434,"goto_y":318,"type":"WAGON","place_title":"Appleton on Horse Isle"},
|
||||
{"id":34,"cost":200,"goto_x":537,"goto_y":359,"type":"WAGON","place_title":"Horseshoe Village"},
|
||||
{"id":36,"cost":300,"goto_x":383,"goto_y":98,"type":"BOAT","place_title":"Inkton on Art Isle"},
|
||||
{"id":37,"cost":300,"goto_x":446,"goto_y":149,"type":"BOAT","place_title":"Wington on Bird Isle"},
|
||||
{"id":38,"cost":300,"goto_x":383,"goto_y":98,"type":"BOAT","place_title":"Inkton on Art Isle"},
|
||||
{"id":39,"cost":300,"goto_x":520,"goto_y":66,"type":"BOAT","place_title":"Snow Isle"},
|
||||
{"id":40,"cost":0,"goto_x":508,"goto_y":179,"type":"BOAT","place_title":"Earton on Horse Isle"},
|
||||
{"id":42,"cost":300,"goto_x":331,"goto_y":318,"type":"BOAT","place_title":"Flower Isle"},
|
||||
{"id":41,"cost":300,"goto_x":383,"goto_y":259,"type":"BOAT","place_title":"Flipperton on Dolphin Isle"},
|
||||
{"id":43,"cost":400,"goto_x":331,"goto_y":318,"type":"BOAT","place_title":"Flower Isle"},
|
||||
{"id":44,"cost":400,"goto_x":414,"goto_y":320,"type":"BOAT","place_title":"Appleton on Horse Isle"},
|
||||
{"id":45,"cost":200,"goto_x":414,"goto_y":320,"type":"BOAT","place_title":"Appleton on Horse Isle"},
|
||||
{"id":46,"cost":50,"goto_x":267,"goto_y":370,"type":"WAGON","place_title":"Tail End"},
|
||||
{"id":47,"cost":50,"goto_x":388,"goto_y":351,"type":"WAGON","place_title":"Tail Isle Station"},
|
||||
{"id":48,"cost":200,"goto_x":394,"goto_y":341,"type":"BOAT","place_title":"Tail Isle"},
|
||||
{"id":49,"cost":400,"goto_x":508,"goto_y":179,"type":"BOAT","place_title":"Earton on Horse Isle"},
|
||||
{"id":50,"cost":400,"goto_x":328,"goto_y":189,"type":"BOAT","place_title":"Carrotton on Hare Isle"},
|
||||
{"id":51,"cost":300,"goto_x":508,"goto_y":179,"type":"BOAT","place_title":"Earton on Horse Isle"},
|
||||
{"id":52,"cost":300,"goto_x":383,"goto_y":170,"type":"BOAT","place_title":"Whiskerton on Cat Isle"},
|
||||
{"id":53,"cost":200,"goto_x":383,"goto_y":170,"type":"BOAT","place_title":"Whiskerton on Cat Isle"},
|
||||
{"id":54,"cost":200,"goto_x":328,"goto_y":189,"type":"BOAT","place_title":"Carrotton on Hare Isle"},
|
||||
{"id":55,"cost":200,"goto_x":383,"goto_y":170,"type":"BOAT","place_title":"Whiskerton on Cat Isle"},
|
||||
{"id":56,"cost":200,"goto_x":383,"goto_y":98,"type":"BOAT","place_title":"Inkton on Art Isle"},
|
||||
{"id":57,"cost":200,"goto_x":383,"goto_y":170,"type":"BOAT","place_title":"Whiskerton on Cat Isle"},
|
||||
{"id":58,"cost":200,"goto_x":446,"goto_y":149,"type":"BOAT","place_title":"Wington on Bird Isle"},
|
||||
{"id":59,"cost":100,"goto_x":387,"goto_y":418,"type":"BOAT","place_title":"Desert Isle"},
|
||||
{"id":60,"cost":100,"goto_x":371,"goto_y":418,"type":"BOAT","place_title":"Sand Isles"},
|
||||
{"id":61,"cost":250,"goto_x":383,"goto_y":170,"type":"BOAT","place_title":"Whiskerton on Cat Isle"},
|
||||
{"id":62,"cost":250,"goto_x":383,"goto_y":259,"type":"BOAT","place_title":"Flipperton on Dolphin Isle"},
|
||||
{"id":63,"cost":400,"goto_x":508,"goto_y":179,"type":"BOAT","place_title":"Earton on Horse Isle"},
|
||||
{"id":64,"cost":300,"goto_x":520,"goto_y":66,"type":"BOAT","place_title":"Snow Isle"},
|
||||
{"id":66,"cost":300,"goto_x":617,"goto_y":145,"type":"BOAT","place_title":"Witherton on Rider Isle"},
|
||||
{"id":65,"cost":400,"goto_x":617,"goto_y":145,"type":"BOAT","place_title":"Witherton on Rider Isle"},
|
||||
{"id":67,"cost":300,"goto_x":617,"goto_y":145,"type":"BOAT","place_title":"Witherton on Rider Isle"},
|
||||
{"id":68,"cost":200,"goto_x":520,"goto_y":66,"type":"BOAT","place_title":"Snow Isle"},
|
||||
{"id":69,"cost":500,"goto_x":508,"goto_y":179,"type":"BOAT","place_title":"Earton on Horse Isle"},
|
||||
{"id":70,"cost":500,"goto_x":627,"goto_y":71,"type":"BOAT","place_title":"Crystalton on Ice Isle"},
|
||||
{"id":71,"cost":300,"goto_x":627,"goto_y":71,"type":"BOAT","place_title":"Crystalton on Ice Isle"},
|
||||
{"id":72,"cost":200,"goto_x":627,"goto_y":71,"type":"BOAT","place_title":"Crystalton on Ice Isle"},
|
||||
{"id":73,"cost":1,"goto_x":936,"goto_y":55,"type":"ROWBOAT","place_title":"Ghost Ship"},
|
||||
{"id":74,"cost":0,"goto_x":941,"goto_y":56,"type":"ROWBOAT","place_title":"the shore"},
|
||||
{"id":75,"cost":1,"goto_x":951,"goto_y":66,"type":"ROWBOAT","place_title":"Ghost Ship"},
|
||||
{"id":76,"cost":0,"goto_x":947,"goto_y":62,"type":"ROWBOAT","place_title":"the shore"},
|
||||
{"id":77,"cost":1,"goto_x":940,"goto_y":50,"type":"ROWBOAT","place_title":"Ghost Ship"},
|
||||
{"id":78,"cost":0,"goto_x":944,"goto_y":48,"type":"ROWBOAT","place_title":"the shore"},
|
||||
{"id":79,"cost":1,"goto_x":894,"goto_y":97,"type":"ROWBOAT","place_title":"Pirate Ship to Bird Isle"},
|
||||
{"id":80,"cost":0,"goto_x":897,"goto_y":95,"type":"ROWBOAT","place_title":"the shore"},
|
||||
{"id":81,"cost":1,"goto_x":961,"goto_y":45,"type":"ROWBOAT","place_title":"Pirate Ship to Saddle Isle"},
|
||||
{"id":82,"cost":0,"goto_x":956,"goto_y":48,"type":"ROWBOAT","place_title":"the shore"},
|
||||
{"id":83,"cost":5,"goto_x":705,"goto_y":154,"type":"ROWBOAT","place_title":"Pirate Ship"},
|
||||
{"id":84,"cost":0,"goto_x":701,"goto_y":155,"type":"ROWBOAT","place_title":"the shore"},
|
||||
{"id":85,"cost":5,"goto_x":447,"goto_y":125,"type":"ROWBOAT","place_title":"Pirate Ship"},
|
||||
{"id":86,"cost":0,"goto_x":441,"goto_y":126,"type":"ROWBOAT","place_title":"the shore"},
|
||||
{"id":87,"cost":1,"goto_x":920,"goto_y":43,"type":"ROWBOAT","place_title":"Jolly Roger's Stationary Pirate Ship"},
|
||||
{"id":88,"cost":0,"goto_x":924,"goto_y":44,"type":"ROWBOAT","place_title":"the shore"},
|
||||
{"id":89,"cost":1,"goto_x":967,"goto_y":73,"type":"ROWBOAT","place_title":"Rough Jenning's Stationary Pirate Ship"},
|
||||
{"id":90,"cost":0,"goto_x":962,"goto_y":73,"type":"ROWBOAT","place_title":"the shore"},
|
||||
{"id":91,"cost":1,"goto_x":931,"goto_y":95,"type":"ROWBOAT","place_title":"Big George's Stationary Pirate Ship"},
|
||||
{"id":92,"cost":0,"goto_x":929,"goto_y":98,"type":"ROWBOAT","place_title":"the shore"},
|
||||
{"id":93,"cost":0,"goto_x":870,"goto_y":74,"type":"ROWBOAT","place_title":"the shore"},
|
||||
{"id":94,"cost":1,"goto_x":869,"goto_y":71,"type":"ROWBOAT","place_title":"Green-eyed Breanan's Pirate Ship"},
|
||||
{"id":95,"cost":500,"goto_x":472,"goto_y":410,"type":"BOAT","place_title":"Hotton on Desert Isle"},
|
||||
{"id":96,"cost":500,"goto_x":548,"goto_y":347,"type":"BOAT","place_title":"Hoof Isle"},
|
||||
{"id":97,"cost":250,"goto_x":243,"goto_y":164,"type":"BOAT","place_title":"Tropicton on Jungle Isle"},
|
||||
{"id":98,"cost":550,"goto_x":243,"goto_y":164,"type":"BOAT","place_title":"Tropicton on Jungle Isle"},
|
||||
{"id":99,"cost":250,"goto_x":328,"goto_y":189,"type":"BOAT","place_title":"Carrotton on Hare Isle"},
|
||||
{"id":100,"cost":550,"goto_x":508,"goto_y":179,"type":"BOAT","place_title":"Earton on Horse Isle"},
|
||||
{"id":101,"cost":25,"goto_x":606,"goto_y":235,"type":"BOAT","place_title":"Nearest Horse Isle Coast"},
|
||||
{"id":102,"cost":0,"goto_x":572,"goto_y":308,"type":"BOAT","place_title":"Shellton on Turtle Isle"},
|
||||
{"id":103,"cost":0,"goto_x":622,"goto_y":220,"type":"ROWBOAT","place_title":"Palm Isle"},
|
||||
{"id":104,"cost":0,"goto_x":633,"goto_y":210,"type":"ROWBOAT","place_title":"Ardent Isle"},
|
||||
{"id":105,"cost":0,"goto_x":641,"goto_y":216,"type":"ROWBOAT","place_title":"Atropos Isle"},
|
||||
{"id":106,"cost":0,"goto_x":615,"goto_y":209,"type":"ROWBOAT","place_title":"Shimmer Isle"},
|
||||
{"id":107,"cost":0,"goto_x":622,"goto_y":220,"type":"ROWBOAT","place_title":"Palm Isle"},
|
||||
{"id":108,"cost":0,"goto_x":622,"goto_y":220,"type":"ROWBOAT","place_title":"Palm Isle"},
|
||||
{"id":109,"cost":0,"goto_x":570,"goto_y":254,"type":"BOAT","place_title":"Treeton on Horse Isle"},
|
||||
{"id":110,"cost":0,"goto_x":570,"goto_y":254,"type":"BOAT","place_title":"Treeton on Horse Isle"},
|
||||
{"id":111,"cost":0,"goto_x":617,"goto_y":145,"type":"BOAT","place_title":"Witherton on Rider Isle"},
|
||||
{"id":112,"cost":100,"goto_x":470,"goto_y":284,"type":"WAGON","place_title":"Equestrian Park"},
|
||||
{"id":113,"cost":100,"goto_x":470,"goto_y":284,"type":"WAGON","place_title":"Equestrian Park"},
|
||||
{"id":114,"cost":100,"goto_x":470,"goto_y":284,"type":"WAGON","place_title":"Equestrian Park"},
|
||||
{"id":115,"cost":100,"goto_x":525,"goto_y":187,"type":"WAGON","place_title":"Earton"},
|
||||
{"id":116,"cost":100,"goto_x":557,"goto_y":232,"type":"WAGON","place_title":"Treeton"},
|
||||
{"id":117,"cost":100,"goto_x":434,"goto_y":318,"type":"WAGON","place_title":"Appleton"},
|
||||
{"id":118,"cost":0,"goto_x":632,"goto_y":344,"type":"BOAT","place_title":"Drill Isle"},
|
||||
{"id":119,"cost":0,"goto_x":649,"goto_y":315,"type":"BOAT","place_title":"Serenity Isle"},
|
||||
{"id":120,"cost":0,"goto_x":572,"goto_y":308,"type":"BOAT","place_title":"Shellton on Turtle Isle"},
|
||||
{"id":121,"cost":0,"goto_x":508,"goto_y":179,"type":"BOAT","place_title":"Earton on Horse Isle"},
|
||||
{"id":122,"cost":50,"goto_x":196,"goto_y":338,"type":"BOAT","place_title":"the southeastern tip of Jungle Isle"},
|
||||
{"id":123,"cost":250,"goto_x":472,"goto_y":410,"type":"BOAT","place_title":"Hotton on Desert Isle"},
|
||||
{"id":124,"cost":250,"goto_x":618,"goto_y":449,"type":"BOAT","place_title":"Torrid Isle"},
|
||||
{"id":125,"cost":550,"goto_x":548,"goto_y":347,"type":"BOAT","place_title":"Hoof Isle"},
|
||||
{"id":126,"cost":550,"goto_x":618,"goto_y":449,"type":"BOAT","place_title":"Torrid Isle"},
|
||||
{"id":127,"cost":200,"goto_x":243,"goto_y":164,"type":"BOAT","place_title":"Tropicton on Jungle Isle"},
|
||||
{"id":128,"cost":200,"goto_x":114,"goto_y":179,"type":"BOAT","place_title":"Vine Isle"},
|
||||
{"id":129,"cost":200,"goto_x":627,"goto_y":71,"type":"BOAT","place_title":"Crystalton on Ice Isle"},
|
||||
{"id":130,"cost":200,"goto_x":722,"goto_y":67,"type":"BOAT","place_title":"Polar Isle"},
|
||||
{"id":131,"cost":400,"goto_x":617,"goto_y":145,"type":"BOAT","place_title":"Witherton on Rider Isle"},
|
||||
{"id":132,"cost":400,"goto_x":722,"goto_y":67,"type":"BOAT","place_title":"Polar Isle"},
|
||||
{"id":133,"cost":2,"goto_x":873,"goto_y":21,"type":"ROWBOAT","place_title":"Treasure Isle"},
|
||||
{"id":134,"cost":0,"goto_x":956,"goto_y":48,"type":"ROWBOAT","place_title":"Skullton on Pirate Isle"},
|
||||
{"id":135,"cost":300,"goto_x":722,"goto_y":67,"type":"BOAT","place_title":"Polar Isle"},
|
||||
{"id":136,"cost":300,"goto_x":775,"goto_y":105,"type":"BOAT","place_title":"Whorl Isle"},
|
||||
{"id":137,"cost":250,"goto_x":153,"goto_y":66,"type":"BOAT","place_title":"Web Isle"},
|
||||
{"id":138,"cost":250,"goto_x":114,"goto_y":179,"type":"BOAT","place_title":"Vine Isle"},
|
||||
{"id":139,"cost":200,"goto_x":446,"goto_y":149,"type":"BOAT","place_title":"Wington on Bird Isle"},
|
||||
{"id":140,"cost":200,"goto_x":490,"goto_y":141,"type":"BOAT","place_title":"Ring Isle"},
|
||||
{"id":141,"cost":3,"goto_x":965,"goto_y":388,"type":"ROWBOAT","place_title":"Basalt Isle"},
|
||||
{"id":142,"cost":3,"goto_x":969,"goto_y":275,"type":"ROWBOAT","place_title":"Scoria Isle"},
|
||||
{"id":143,"cost":300,"goto_x":508,"goto_y":179,"type":"BOAT","place_title":"Earton"},
|
||||
{"id":144,"cost":300,"goto_x":565,"goto_y":167,"type":"BOAT","place_title":"Horn Isle"},
|
||||
{"id":145,"cost":200,"goto_x":617,"goto_y":145,"type":"BOAT","place_title":"Witherton on Rider Isle"},
|
||||
{"id":146,"cost":200,"goto_x":565,"goto_y":167,"type":"BOAT","place_title":"Horn Isle"},
|
||||
{"id":147,"cost":1,"goto_x":956,"goto_y":48,"type":"ROWBOAT","place_title":"Skullton on Pirate Isle"},
|
||||
{"id":148,"cost":1,"goto_x":974,"goto_y":40,"type":"ROWBOAT","place_title":"Hat Isle"},
|
||||
{"id":149,"cost":500,"goto_x":335,"goto_y":471,"type":"BOAT","place_title":"Yellow Brick Isle"},
|
||||
{"id":150,"cost":500,"goto_x":371,"goto_y":418,"type":"BOAT","place_title":"Sand Isles Docks"},
|
||||
{"id":151,"cost":2,"goto_x":59,"goto_y":260,"type":"ROWBOAT","place_title":"Vine Isle"},
|
||||
{"id":152,"cost":2,"goto_x":73,"goto_y":275,"type":"ROWBOAT","place_title":"Dog Isle"},
|
||||
{"id":153,"cost":200,"goto_x":775,"goto_y":105,"type":"BOAT","place_title":"Whorl Isle"},
|
||||
{"id":154,"cost":200,"goto_x":753,"goto_y":248,"type":"BOAT","place_title":"Cabin Isle"},
|
||||
{"id":155,"cost":250,"goto_x":520,"goto_y":66,"type":"BOAT","place_title":"Snow Isle"},
|
||||
{"id":156,"cost":250,"goto_x":405,"goto_y":28,"type":"BOAT","place_title":"Glacier Isle"}
|
||||
]
|
||||
},
|
||||
"new_user":{
|
||||
"starting_message":"<B>Welcome Newest Rider of Horse Isle!</B><BR>Start by talking to Welcome Willy in the cabin. Click the TALK button by his name in the right hand window. He will know the location of a buried treasure on this island! Move to the spot he describes using the arrow keys. Then Click the WRENCH Icon at the lower right.",
|
||||
"starting_x":522,
|
||||
|
|
51
Horse Isle Server/Horse Isle Server/Action.cs
Normal file
51
Horse Isle Server/Horse Isle Server/Action.cs
Normal file
|
@ -0,0 +1,51 @@
|
|||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Horse_Isle_Server
|
||||
{
|
||||
class Action
|
||||
{
|
||||
public enum ActivationMethod
|
||||
{
|
||||
MANUAL,
|
||||
SHOVEL,
|
||||
BINOCULARS,
|
||||
MAGNIFYING_GLASS,
|
||||
RAKE
|
||||
}
|
||||
public struct AltActivation
|
||||
{
|
||||
public ActivationMethod Method;
|
||||
public int ActivationX;
|
||||
public int ActivationY;
|
||||
}
|
||||
|
||||
public struct Requirements
|
||||
{
|
||||
public bool Track;
|
||||
public int MaxCompletions;
|
||||
public int MoneyRequired;
|
||||
public int[] CompletedRequired;
|
||||
public int[] NotCompletedRequired;
|
||||
public int RequiredAward;
|
||||
|
||||
}
|
||||
public struct GameAction
|
||||
{
|
||||
public int Id;
|
||||
public string Notes;
|
||||
public string AdventurousTitle;
|
||||
public string Difficulty;
|
||||
public string Author;
|
||||
public int[] ActionIdRequired;
|
||||
|
||||
AltActivation Activation;
|
||||
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
}
|
|
@ -155,6 +155,9 @@ namespace Horse_Isle_Server
|
|||
case PacketBuilder.PACKET_KEEP_ALIVE:
|
||||
Server.OnKeepAlive(this, Packet);
|
||||
break;
|
||||
case PacketBuilder.PACKET_TRANSPORT:
|
||||
Server.OnTransportUsed(this, Packet);
|
||||
break;
|
||||
default:
|
||||
Logger.ErrorPrint("Unimplemented Packet: " + BitConverter.ToString(Packet).Replace('-', ' '));
|
||||
break;
|
||||
|
|
|
@ -129,6 +129,35 @@ namespace Horse_Isle_Server
|
|||
Logger.DebugPrint("Registered Word Correction: " + correction.FilteredWord + " to "+correction.ReplacedWord);
|
||||
}
|
||||
|
||||
// Register Transports
|
||||
|
||||
int totalTransportPoints = gameData.transport.transport_points.Count;
|
||||
for (int i = 0; i < totalTransportPoints; i++)
|
||||
{
|
||||
Transport.TransportPoint transportPoint = new Transport.TransportPoint();
|
||||
transportPoint.X = gameData.transport.transport_points[i].x;
|
||||
transportPoint.Y = gameData.transport.transport_points[i].y;
|
||||
transportPoint.Locations = gameData.transport.transport_points[i].places.ToObject<int[]>();
|
||||
Transport.TransportPoints.Add(transportPoint);
|
||||
|
||||
Logger.DebugPrint("Registered Transport Point: At X: " + transportPoint.X + " Y: " + transportPoint.Y);
|
||||
}
|
||||
|
||||
int totalTransportPlaces = gameData.transport.transport_places.Count;
|
||||
for (int i = 0; i < totalTransportPlaces; i++)
|
||||
{
|
||||
Transport.TransportLocation transportPlace = new Transport.TransportLocation();
|
||||
transportPlace.Id = gameData.transport.transport_places[i].id;
|
||||
transportPlace.Cost = gameData.transport.transport_places[i].cost;
|
||||
transportPlace.GotoX = gameData.transport.transport_places[i].goto_x;
|
||||
transportPlace.GotoY = gameData.transport.transport_places[i].goto_y;
|
||||
transportPlace.Type = gameData.transport.transport_places[i].type;
|
||||
transportPlace.LocationTitle = gameData.transport.transport_places[i].place_title;
|
||||
Transport.TransportLocations.Add(transportPlace);
|
||||
|
||||
Logger.DebugPrint("Registered Transport Location: "+ transportPlace.LocationTitle+" To Goto X: " + transportPlace.GotoX + " Y: " + transportPlace.GotoY);
|
||||
}
|
||||
|
||||
|
||||
|
||||
// New Users
|
||||
|
@ -182,6 +211,7 @@ namespace Horse_Isle_Server
|
|||
Messages.AreaFormat = gameData.messages.meta.area_format;
|
||||
Messages.Seperator = gameData.messages.meta.seperator;
|
||||
Messages.TileFormat = gameData.messages.meta.tile_format;
|
||||
Messages.TransportFormat = gameData.messages.meta.transport_format;
|
||||
Messages.NothingMessage = gameData.messages.meta.nothing_message;
|
||||
Messages.ExitThisPlace = gameData.messages.meta.exit_this_place;
|
||||
Messages.MetaTerminator = gameData.messages.meta.end_of_meta;
|
||||
|
@ -195,7 +225,6 @@ namespace Horse_Isle_Server
|
|||
// Map Data
|
||||
|
||||
Map.OverlayTileDepth = gameData.tile_paramaters.overlay_tiles.tile_depth.ToObject<int[]>();
|
||||
Map.OverlayTilesetPassibility = gameData.tile_paramaters.overlay_tiles.passibility.ToObject<bool[]>();
|
||||
|
||||
List<Map.TerrainTile> terrainTiles = new List<Map.TerrainTile>();
|
||||
int totalTerrainTiles = gameData.tile_paramaters.terrain_tiles.Count;
|
||||
|
@ -219,6 +248,11 @@ namespace Horse_Isle_Server
|
|||
Server.IdleWarning = gameData.messages.disconnect.client_timeout.warn_after;
|
||||
Server.IdleTimeout = gameData.messages.disconnect.client_timeout.kick_after;
|
||||
|
||||
// Swf
|
||||
Messages.WagonCutscene = gameData.transport.wagon_cutscene;
|
||||
Messages.BoatCutscene = gameData.transport.boat_cutscene;
|
||||
Messages.BallonCutscene = gameData.transport.ballon_cutscene;
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -95,6 +95,7 @@
|
|||
<DependentUpon>Resources.resx</DependentUpon>
|
||||
</Compile>
|
||||
<Compile Include="Server.cs" />
|
||||
<Compile Include="Transport.cs" />
|
||||
<Compile Include="User.cs" />
|
||||
<Compile Include="World.cs" />
|
||||
</ItemGroup>
|
||||
|
|
17
Horse Isle Server/Horse Isle Server/ItemObject.cs
Normal file
17
Horse Isle Server/Horse Isle Server/ItemObject.cs
Normal file
|
@ -0,0 +1,17 @@
|
|||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Horse_Isle_Server
|
||||
{
|
||||
class ItemObject
|
||||
{
|
||||
public int IconId;
|
||||
public int Price;
|
||||
public string ItemName;
|
||||
public string ItemDescription;
|
||||
public string ItemCategory;
|
||||
}
|
||||
}
|
|
@ -19,7 +19,6 @@ namespace Horse_Isle_Server
|
|||
public static int[] OverlayTileDepth;
|
||||
|
||||
public static TerrainTile[] TerrainTiles;
|
||||
public static bool[] OverlayTilesetPassibility;
|
||||
|
||||
public static Bitmap MapData;
|
||||
|
||||
|
|
|
@ -51,6 +51,7 @@ namespace Horse_Isle_Server
|
|||
public static string TownFormat;
|
||||
public static string AreaFormat;
|
||||
public static string LocationFormat;
|
||||
public static string TransportFormat;
|
||||
|
||||
public static string NearbyPlayers;
|
||||
public static string North;
|
||||
|
@ -68,11 +69,31 @@ namespace Horse_Isle_Server
|
|||
public static string BanMessage;
|
||||
public static string IdleKickMessageFormat;
|
||||
|
||||
// Swf
|
||||
public static string BoatCutscene;
|
||||
public static string WagonCutscene;
|
||||
public static string BallonCutscene;
|
||||
|
||||
public static string FormatGlobalChatViolationMessage(Chat.Reason violationReason)
|
||||
{
|
||||
return ChatViolationMessageFormat.Replace("%AMOUNT%", RequiredChatViolations.ToString()).Replace("%REASON%", violationReason.Message);
|
||||
}
|
||||
|
||||
// Meta
|
||||
public static string FormatTransportMessage(string method, string place, int cost, int id, int x, int y)
|
||||
{
|
||||
byte[] xy = new byte[4];
|
||||
xy[0] = (byte)(((x - 4) / 64) + 20);
|
||||
xy[1] = (byte)(((x - 4) % 64) + 20);
|
||||
|
||||
xy[2] = (byte)(((y - 1) / 64) + 20);
|
||||
xy[3] = (byte)(((y - 1) % 64) + 20);
|
||||
|
||||
int iconId = 253;
|
||||
if(method == "WAGON")
|
||||
iconId = 254;
|
||||
return TransportFormat.Replace("%METHOD%", method).Replace("%PLACE%", place).Replace("%COST%", cost.ToString()).Replace("%ID%", id.ToString()).Replace("%ICON%",iconId.ToString()).Replace(" % XY%",Encoding.UTF8.GetString(xy));
|
||||
}
|
||||
// For all
|
||||
public static string FormatGlobalChatMessage(string username, string message)
|
||||
{
|
||||
|
|
138
Horse Isle Server/Horse Isle Server/Meta.cs
Normal file
138
Horse Isle Server/Horse Isle Server/Meta.cs
Normal file
|
@ -0,0 +1,138 @@
|
|||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Horse_Isle_Server
|
||||
{
|
||||
class Meta
|
||||
{
|
||||
// Meta
|
||||
|
||||
private static string buildLocationString(int x, int y)
|
||||
{
|
||||
string locationString = "";
|
||||
|
||||
if (World.InArea(x, y))
|
||||
locationString += Messages.AreaFormat.Replace("%AREA%", World.GetArea(x, y).Name);
|
||||
if (World.InTown(x, y))
|
||||
locationString += Messages.TownFormat.Replace("%TOWN%", World.GetTown(x, y).Name);
|
||||
if (World.InIsle(x, y))
|
||||
locationString += Messages.IsleFormat.Replace("%ISLE%", World.GetIsle(x, y).Name);
|
||||
if (locationString != "")
|
||||
locationString = Messages.LocationFormat.Replace("%META%", locationString);
|
||||
return locationString;
|
||||
}
|
||||
|
||||
|
||||
private static string buildNearbyString(int x, int y)
|
||||
{
|
||||
string playersNearby = "";
|
||||
|
||||
User[] nearbyUsers = Server.GetNearbyUsers(x, y, true, true);
|
||||
if (nearbyUsers.Length > 1)
|
||||
{
|
||||
playersNearby += Messages.NearbyPlayers;
|
||||
playersNearby += Messages.Seperator;
|
||||
|
||||
string usersWest = "";
|
||||
string usersNorth = "";
|
||||
string usersEast = "";
|
||||
string usersSouth = "";
|
||||
foreach (User nearbyUser in nearbyUsers)
|
||||
{
|
||||
if (nearbyUser.X < x)
|
||||
{
|
||||
usersWest += " " + nearbyUser.Username + " ";
|
||||
}
|
||||
else if (nearbyUser.X > x)
|
||||
{
|
||||
usersEast += " " + nearbyUser.Username + " ";
|
||||
}
|
||||
else if (nearbyUser.Y > y)
|
||||
{
|
||||
usersSouth += " " + nearbyUser.Username + " ";
|
||||
}
|
||||
else if (nearbyUser.Y < y)
|
||||
{
|
||||
usersNorth += " " + nearbyUser.Username + " ";
|
||||
}
|
||||
}
|
||||
|
||||
if (usersEast != "")
|
||||
playersNearby += " " + Messages.East + usersEast + Messages.Seperator;
|
||||
if (usersWest != "")
|
||||
playersNearby += " " + Messages.West + usersWest + Messages.Seperator;
|
||||
if (usersSouth != "")
|
||||
playersNearby += " " + Messages.South + usersSouth + Messages.Seperator;
|
||||
if (usersNorth != "")
|
||||
playersNearby += " " + Messages.North + usersNorth + Messages.Seperator;
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
return playersNearby;
|
||||
|
||||
}
|
||||
private static string buildCommonInfo(int x, int y)
|
||||
{
|
||||
string message = "";
|
||||
|
||||
message += Messages.Seperator + buildNearbyString(x, y);
|
||||
// Dropped Items
|
||||
int[] itemIds = World.GetDroppedItems(x, y);
|
||||
if (itemIds.Length == 0)
|
||||
message += Messages.NothingMessage;
|
||||
|
||||
|
||||
return message;
|
||||
}
|
||||
public static string BuildTransportInfo(Transport.TransportPoint transportPoint)
|
||||
{
|
||||
string message = "";
|
||||
// Build list of locations
|
||||
foreach(int transportLocationId in transportPoint.Locations)
|
||||
{
|
||||
Transport.TransportLocation transportLocation = Transport.GetTransportLocation(transportLocationId);
|
||||
message += Messages.FormatTransportMessage(transportLocation.Type, transportLocation.LocationTitle, transportLocation.Cost, transportLocation.Id, transportLocation.GotoX, transportLocation.GotoY);
|
||||
}
|
||||
return message;
|
||||
}
|
||||
public static string BuildSpecialTileInfo(World.SpecialTile specialTile)
|
||||
{
|
||||
string message = "";
|
||||
|
||||
if (specialTile.Title != null)
|
||||
message += Messages.TileFormat.Replace("%TILENAME%", specialTile.Title);
|
||||
else
|
||||
message += buildLocationString(specialTile.X, specialTile.Y);
|
||||
|
||||
if (specialTile.Description != null)
|
||||
message += Messages.Seperator + specialTile.Description;
|
||||
|
||||
if (specialTile.Code == null)
|
||||
message += buildCommonInfo(specialTile.X, specialTile.Y);
|
||||
if (specialTile.Code == "TRANSPORT")
|
||||
{
|
||||
Transport.TransportPoint point = Transport.GetTransportPoint(specialTile.X, specialTile.Y);
|
||||
message += Meta.BuildTransportInfo(point)+ "^R1";
|
||||
}
|
||||
|
||||
if (specialTile.ExitX != 0 && specialTile.ExitY != 0)
|
||||
message += Messages.ExitThisPlace + Messages.MetaTerminator;
|
||||
|
||||
return message;
|
||||
}
|
||||
public static string BuildMetaInfo(int x, int y)
|
||||
{
|
||||
string message = "";
|
||||
message += buildLocationString(x, y);
|
||||
|
||||
message += buildCommonInfo(x, y);
|
||||
return message;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
|
@ -17,7 +17,8 @@ namespace Horse_Isle_Server
|
|||
public const byte PACKET_USERINFO = 0x81;
|
||||
public const byte PACKET_WORLD = 0x7A;
|
||||
public const byte PACKET_BASE_STATS = 0x7B;
|
||||
public const byte PACKET_SWF_MODULE = 0x2A;
|
||||
public const byte PACKET_SWF_CUTSCENE = 0x29;
|
||||
public const byte PACKET_SWF_MODULE_GENTLE = 0x2A;
|
||||
public const byte PACKET_PLACE_INFO = 0x1E;
|
||||
public const byte PACKET_AREA_DEFS = 0x79;
|
||||
public const byte PACKET_ANNOUNCEMENT = 0x7E;
|
||||
|
@ -25,6 +26,7 @@ namespace Horse_Isle_Server
|
|||
public const byte PACKET_PLAYSOUND = 0x23;
|
||||
public const byte PACKET_KEEP_ALIVE = 0x7C;
|
||||
public const byte PACKET_PROFILE = 0x18;
|
||||
public const byte PACKET_TRANSPORT = 0x29;
|
||||
public const byte PACKET_KICK = 0x80;
|
||||
public const byte PACKET_LEAVE = 0x7D;
|
||||
|
||||
|
@ -560,10 +562,10 @@ namespace Horse_Isle_Server
|
|||
|
||||
return Packet;
|
||||
}
|
||||
public static byte[] CreateSwfModulePacket(string swf)
|
||||
public static byte[] CreateSwfModulePacket(string swf,byte type)
|
||||
{
|
||||
MemoryStream ms = new MemoryStream();
|
||||
ms.WriteByte(PACKET_SWF_MODULE);
|
||||
ms.WriteByte(type);
|
||||
byte[] strBytes = Encoding.UTF8.GetBytes(swf);
|
||||
ms.Write(strBytes, 0x00, strBytes.Length);
|
||||
ms.WriteByte(PACKET_TERMINATOR);
|
||||
|
|
|
@ -299,6 +299,55 @@ namespace Horse_Isle_Server
|
|||
Update(sender);
|
||||
}
|
||||
|
||||
public static void OnTransportUsed(Client sender, byte[] packet)
|
||||
{
|
||||
if (!sender.LoggedIn)
|
||||
{
|
||||
Logger.ErrorPrint(sender.RemoteIp + " Sent transport packet when not logged in.");
|
||||
return;
|
||||
}
|
||||
if (packet.Length < 3)
|
||||
{
|
||||
Logger.ErrorPrint(sender.RemoteIp + " Sent an invalid transport packet.");
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
string packetStr = Encoding.UTF8.GetString(packet);
|
||||
string number = packetStr.Substring(1, packetStr.Length - 3);
|
||||
|
||||
int transportid;
|
||||
try
|
||||
{
|
||||
transportid = Int32.Parse(number);
|
||||
}
|
||||
catch(InvalidOperationException)
|
||||
{
|
||||
Logger.ErrorPrint(sender.RemoteIp + " Tried to use a transport with id that is NaN.");
|
||||
return;
|
||||
}
|
||||
|
||||
Transport.TransportLocation transportLocation = Transport.GetTransportLocation(transportid);
|
||||
if (sender.LoggedinUser.Money >= transportLocation.Cost)
|
||||
{
|
||||
|
||||
string swfToLoad = Messages.BoatCutscene;
|
||||
if (transportLocation.Type == "WAGON")
|
||||
swfToLoad = Messages.WagonCutscene;
|
||||
|
||||
if (transportLocation.Type != "ROWBOAT")
|
||||
{
|
||||
byte[] swfModulePacket = PacketBuilder.CreateSwfModulePacket(swfToLoad, PacketBuilder.PACKET_SWF_CUTSCENE);
|
||||
sender.SendPacket(swfModulePacket);
|
||||
}
|
||||
|
||||
Teleport(sender, transportLocation.GotoX, transportLocation.GotoY);
|
||||
|
||||
sender.LoggedinUser.Money -= transportLocation.Cost;
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
public static void OnChatPacket(Client sender, byte[] packet)
|
||||
{
|
||||
if (!sender.LoggedIn)
|
||||
|
@ -435,6 +484,8 @@ namespace Horse_Isle_Server
|
|||
|
||||
}
|
||||
|
||||
|
||||
|
||||
public static void OnDisconnect(Client sender)
|
||||
{
|
||||
if (sender.LoggedIn)
|
||||
|
@ -457,77 +508,6 @@ namespace Horse_Isle_Server
|
|||
connectedClients.Remove(sender);
|
||||
}
|
||||
|
||||
public static void UpdateArea(Client forClient, bool justArea=false)
|
||||
{
|
||||
if (!forClient.LoggedIn)
|
||||
{
|
||||
Logger.ErrorPrint(forClient.RemoteIp + "tried to update tile information when not logged in.");
|
||||
return;
|
||||
}
|
||||
|
||||
string LocationStr = "";
|
||||
if (!World.InSpecialTile(forClient.LoggedinUser.X, forClient.LoggedinUser.Y))
|
||||
{
|
||||
LocationStr = Meta.BuildMetaInfo(forClient.LoggedinUser.X, forClient.LoggedinUser.Y);
|
||||
}
|
||||
else
|
||||
{
|
||||
World.SpecialTile specialTile = World.GetSpecialTile(forClient.LoggedinUser.X, forClient.LoggedinUser.Y);
|
||||
if(specialTile.AutoplaySwf != null && specialTile.AutoplaySwf != "" && !justArea)
|
||||
{
|
||||
byte[] swfModulePacket = PacketBuilder.CreateSwfModulePacket(specialTile.AutoplaySwf);
|
||||
forClient.SendPacket(swfModulePacket);
|
||||
}
|
||||
if(specialTile.Code != null && !justArea)
|
||||
if (!ProcessMapCode(forClient, specialTile.Code))
|
||||
return;
|
||||
LocationStr = Meta.BuildSpecialTileInfo(specialTile);
|
||||
}
|
||||
byte[] AreaMessage = PacketBuilder.CreatePlaceInfo(LocationStr);
|
||||
forClient.SendPacket(AreaMessage);
|
||||
|
||||
}
|
||||
|
||||
public static void UpdateWorld(Client forClient)
|
||||
{
|
||||
if (!forClient.LoggedIn)
|
||||
{
|
||||
Logger.ErrorPrint(forClient.RemoteIp + "tried to update world information when not logged in.");
|
||||
return;
|
||||
}
|
||||
|
||||
byte[] WorldData = PacketBuilder.CreateWorldData(World.ServerTime.Minutes, World.ServerTime.Days, World.ServerTime.Years, World.GetWeather());
|
||||
forClient.SendPacket(WorldData);
|
||||
}
|
||||
|
||||
public static void UpdatePlayer(Client forClient)
|
||||
{
|
||||
if (!forClient.LoggedIn)
|
||||
{
|
||||
Logger.ErrorPrint(forClient.RemoteIp + "tried to update player information when not logged in.");
|
||||
return;
|
||||
}
|
||||
byte[] PlayerData = PacketBuilder.CreatePlayerData(forClient.LoggedinUser.Money, Server.GetNumberOfPlayers(), forClient.LoggedinUser.MailBox.MailCount);
|
||||
forClient.SendPacket(PlayerData);
|
||||
}
|
||||
|
||||
public static void UpdateUserInfo(User user)
|
||||
{
|
||||
byte[] playerInfoBytes = PacketBuilder.CreatePlayerInfoUpdateOrCreate(user.X, user.Y, user.Facing, user.CharacterId, user.Username);
|
||||
|
||||
|
||||
|
||||
List<User> users = new List<User>();
|
||||
foreach (Client client in ConnectedClients)
|
||||
if (client.LoggedIn)
|
||||
{
|
||||
if (client.LoggedinUser.Id != user.Id)
|
||||
client.SendPacket(playerInfoBytes);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
public static User[] GetUsersUsersInIsle(World.Isle isle, bool includeStealth = false, bool includeMuted = false)
|
||||
{
|
||||
|
@ -638,7 +618,81 @@ namespace Horse_Isle_Server
|
|||
UpdateUserInfo(client.LoggedinUser);
|
||||
}
|
||||
|
||||
public static bool ProcessMapCode(Client forClient, string mapCode)
|
||||
|
||||
|
||||
public static void UpdateWorld(Client forClient)
|
||||
{
|
||||
if (!forClient.LoggedIn)
|
||||
{
|
||||
Logger.ErrorPrint(forClient.RemoteIp + "tried to update world information when not logged in.");
|
||||
return;
|
||||
}
|
||||
|
||||
byte[] WorldData = PacketBuilder.CreateWorldData(World.ServerTime.Minutes, World.ServerTime.Days, World.ServerTime.Years, World.GetWeather());
|
||||
forClient.SendPacket(WorldData);
|
||||
}
|
||||
|
||||
public static void UpdatePlayer(Client forClient)
|
||||
{
|
||||
if (!forClient.LoggedIn)
|
||||
{
|
||||
Logger.ErrorPrint(forClient.RemoteIp + "tried to update player information when not logged in.");
|
||||
return;
|
||||
}
|
||||
byte[] PlayerData = PacketBuilder.CreatePlayerData(forClient.LoggedinUser.Money, Server.GetNumberOfPlayers(), forClient.LoggedinUser.MailBox.MailCount);
|
||||
forClient.SendPacket(PlayerData);
|
||||
}
|
||||
|
||||
public static void UpdateUserInfo(User user)
|
||||
{
|
||||
byte[] playerInfoBytes = PacketBuilder.CreatePlayerInfoUpdateOrCreate(user.X, user.Y, user.Facing, user.CharacterId, user.Username);
|
||||
|
||||
|
||||
|
||||
List<User> users = new List<User>();
|
||||
foreach (Client client in ConnectedClients)
|
||||
if (client.LoggedIn)
|
||||
{
|
||||
if (client.LoggedinUser.Id != user.Id)
|
||||
client.SendPacket(playerInfoBytes);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
public static void UpdateArea(Client forClient, bool justArea = false)
|
||||
{
|
||||
if (!forClient.LoggedIn)
|
||||
{
|
||||
Logger.ErrorPrint(forClient.RemoteIp + "tried to update tile information when not logged in.");
|
||||
return;
|
||||
}
|
||||
|
||||
string LocationStr = "";
|
||||
if (!World.InSpecialTile(forClient.LoggedinUser.X, forClient.LoggedinUser.Y))
|
||||
{
|
||||
LocationStr = Meta.BuildMetaInfo(forClient.LoggedinUser.X, forClient.LoggedinUser.Y);
|
||||
}
|
||||
else
|
||||
{
|
||||
World.SpecialTile specialTile = World.GetSpecialTile(forClient.LoggedinUser.X, forClient.LoggedinUser.Y);
|
||||
if (specialTile.AutoplaySwf != null && specialTile.AutoplaySwf != "" && !justArea)
|
||||
{
|
||||
byte[] swfModulePacket = PacketBuilder.CreateSwfModulePacket(specialTile.AutoplaySwf,PacketBuilder.PACKET_SWF_MODULE_GENTLE);
|
||||
forClient.SendPacket(swfModulePacket);
|
||||
}
|
||||
if (specialTile.Code != null && !justArea)
|
||||
if (!ProcessMapCodeWithArg(forClient, specialTile.Code))
|
||||
return;
|
||||
LocationStr = Meta.BuildSpecialTileInfo(specialTile);
|
||||
}
|
||||
byte[] AreaMessage = PacketBuilder.CreatePlaceInfo(LocationStr);
|
||||
forClient.SendPacket(AreaMessage);
|
||||
|
||||
}
|
||||
|
||||
public static bool ProcessMapCodeWithArg(Client forClient, string mapCode)
|
||||
{
|
||||
if(mapCode.Contains('-'))
|
||||
{
|
||||
|
|
57
Horse Isle Server/Horse Isle Server/Transport.cs
Normal file
57
Horse Isle Server/Horse Isle Server/Transport.cs
Normal file
|
@ -0,0 +1,57 @@
|
|||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Horse_Isle_Server
|
||||
{
|
||||
class Transport
|
||||
{
|
||||
public struct TransportLocation
|
||||
{
|
||||
public int Id;
|
||||
public int Cost;
|
||||
public int GotoX;
|
||||
public int GotoY;
|
||||
public string Type;
|
||||
public string LocationTitle;
|
||||
}
|
||||
|
||||
public struct TransportPoint
|
||||
{
|
||||
public int X;
|
||||
public int Y;
|
||||
public int[] Locations;
|
||||
}
|
||||
|
||||
public static List<TransportPoint> TransportPoints = new List<TransportPoint>();
|
||||
public static List<TransportLocation> TransportLocations = new List<TransportLocation>();
|
||||
|
||||
|
||||
public static TransportPoint GetTransportPoint(int x, int y)
|
||||
{
|
||||
foreach(TransportPoint transportPoint in TransportPoints)
|
||||
{
|
||||
if (transportPoint.X == x && transportPoint.Y == y)
|
||||
{
|
||||
return transportPoint;
|
||||
}
|
||||
}
|
||||
throw new KeyNotFoundException("Cannot find transport port at x:" + x + "y:" + y);
|
||||
}
|
||||
|
||||
public static TransportLocation GetTransportLocation(int id)
|
||||
{
|
||||
foreach (TransportLocation transportLocation in TransportLocations)
|
||||
{
|
||||
if (transportLocation.Id == id)
|
||||
{
|
||||
return transportLocation;
|
||||
}
|
||||
}
|
||||
throw new KeyNotFoundException("Cannot find transport location at Id:" + id);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
|
@ -61,7 +61,8 @@ namespace Horse_Isle_Server
|
|||
}
|
||||
set
|
||||
{
|
||||
Database.SetPlayerBankMoney(value, Id);
|
||||
Database.SetPlayerMoney(value, Id);
|
||||
Server.UpdatePlayer(LoggedinClient);
|
||||
money = value;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue