From f72cd3e9cb297734dc6ba6bdacc26e6a4775e45c Mon Sep 17 00:00:00 2001 From: SilicaAndPina Date: Tue, 20 Oct 2020 01:05:32 +1300 Subject: [PATCH] ROLLIN AROUND AT THE SPEED OF *TRANSPORT* --- DataCollection/gamedata.json | 279 +++++++++++++++--- Horse Isle Server/Horse Isle Server/Action.cs | 51 ++++ Horse Isle Server/Horse Isle Server/Client.cs | 3 + .../Horse Isle Server/Gamedata.cs | 36 ++- .../Horse Isle Server.csproj | 1 + .../Horse Isle Server/ItemObject.cs | 17 ++ Horse Isle Server/Horse Isle Server/Map.cs | 1 - .../Horse Isle Server/Messages.cs | 21 ++ Horse Isle Server/Horse Isle Server/Meta.cs | 138 +++++++++ .../Horse Isle Server/PacketBuilder.cs | 8 +- Horse Isle Server/Horse Isle Server/Server.cs | 198 ++++++++----- .../Horse Isle Server/Transport.cs | 57 ++++ Horse Isle Server/Horse Isle Server/User.cs | 3 +- 13 files changed, 701 insertions(+), 112 deletions(-) create mode 100644 Horse Isle Server/Horse Isle Server/Action.cs create mode 100644 Horse Isle Server/Horse Isle Server/ItemObject.cs create mode 100644 Horse Isle Server/Horse Isle Server/Meta.cs create mode 100644 Horse Isle Server/Horse Isle Server/Transport.cs diff --git a/DataCollection/gamedata.json b/DataCollection/gamedata.json index c71aa91..fced782 100644 --- a/DataCollection/gamedata.json +++ b/DataCollection/gamedata.json @@ -35,6 +35,7 @@ "location_format":" You are%META% ", "tile_format":"%TILENAME%", "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":"Welcome Newest Rider of Horse Isle!
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, diff --git a/Horse Isle Server/Horse Isle Server/Action.cs b/Horse Isle Server/Horse Isle Server/Action.cs new file mode 100644 index 0000000..71ae36e --- /dev/null +++ b/Horse Isle Server/Horse Isle Server/Action.cs @@ -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; + + } + + + } +} diff --git a/Horse Isle Server/Horse Isle Server/Client.cs b/Horse Isle Server/Horse Isle Server/Client.cs index da4a46c..665442a 100644 --- a/Horse Isle Server/Horse Isle Server/Client.cs +++ b/Horse Isle Server/Horse Isle Server/Client.cs @@ -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; diff --git a/Horse Isle Server/Horse Isle Server/Gamedata.cs b/Horse Isle Server/Horse Isle Server/Gamedata.cs index c92fe70..809c3f6 100644 --- a/Horse Isle Server/Horse Isle Server/Gamedata.cs +++ b/Horse Isle Server/Horse Isle Server/Gamedata.cs @@ -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(); + 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(); - Map.OverlayTilesetPassibility = gameData.tile_paramaters.overlay_tiles.passibility.ToObject(); List terrainTiles = new List(); 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; + } } diff --git a/Horse Isle Server/Horse Isle Server/Horse Isle Server.csproj b/Horse Isle Server/Horse Isle Server/Horse Isle Server.csproj index fa09904..d64c138 100644 --- a/Horse Isle Server/Horse Isle Server/Horse Isle Server.csproj +++ b/Horse Isle Server/Horse Isle Server/Horse Isle Server.csproj @@ -95,6 +95,7 @@ Resources.resx + diff --git a/Horse Isle Server/Horse Isle Server/ItemObject.cs b/Horse Isle Server/Horse Isle Server/ItemObject.cs new file mode 100644 index 0000000..74f4795 --- /dev/null +++ b/Horse Isle Server/Horse Isle Server/ItemObject.cs @@ -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; + } +} diff --git a/Horse Isle Server/Horse Isle Server/Map.cs b/Horse Isle Server/Horse Isle Server/Map.cs index a644989..a8c31a2 100644 --- a/Horse Isle Server/Horse Isle Server/Map.cs +++ b/Horse Isle Server/Horse Isle Server/Map.cs @@ -19,7 +19,6 @@ namespace Horse_Isle_Server public static int[] OverlayTileDepth; public static TerrainTile[] TerrainTiles; - public static bool[] OverlayTilesetPassibility; public static Bitmap MapData; diff --git a/Horse Isle Server/Horse Isle Server/Messages.cs b/Horse Isle Server/Horse Isle Server/Messages.cs index 7b7638a..1ec3f0e 100644 --- a/Horse Isle Server/Horse Isle Server/Messages.cs +++ b/Horse Isle Server/Horse Isle Server/Messages.cs @@ -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) { diff --git a/Horse Isle Server/Horse Isle Server/Meta.cs b/Horse Isle Server/Horse Isle Server/Meta.cs new file mode 100644 index 0000000..bc870b8 --- /dev/null +++ b/Horse Isle Server/Horse Isle Server/Meta.cs @@ -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; + } + + } +} diff --git a/Horse Isle Server/Horse Isle Server/PacketBuilder.cs b/Horse Isle Server/Horse Isle Server/PacketBuilder.cs index be1d83a..da2615c 100644 --- a/Horse Isle Server/Horse Isle Server/PacketBuilder.cs +++ b/Horse Isle Server/Horse Isle Server/PacketBuilder.cs @@ -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); diff --git a/Horse Isle Server/Horse Isle Server/Server.cs b/Horse Isle Server/Horse Isle Server/Server.cs index 8f5c405..2355d1e 100644 --- a/Horse Isle Server/Horse Isle Server/Server.cs +++ b/Horse Isle Server/Horse Isle Server/Server.cs @@ -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 users = new List(); - 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 users = new List(); + 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('-')) { diff --git a/Horse Isle Server/Horse Isle Server/Transport.cs b/Horse Isle Server/Horse Isle Server/Transport.cs new file mode 100644 index 0000000..e227ce0 --- /dev/null +++ b/Horse Isle Server/Horse Isle Server/Transport.cs @@ -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 TransportPoints = new List(); + public static List TransportLocations = new List(); + + + 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); + } + + } +} diff --git a/Horse Isle Server/Horse Isle Server/User.cs b/Horse Isle Server/Horse Isle Server/User.cs index 1cf28cc..49e1268 100644 --- a/Horse Isle Server/Horse Isle Server/User.cs +++ b/Horse Isle Server/Horse Isle Server/User.cs @@ -61,7 +61,8 @@ namespace Horse_Isle_Server } set { - Database.SetPlayerBankMoney(value, Id); + Database.SetPlayerMoney(value, Id); + Server.UpdatePlayer(LoggedinClient); money = value; } }