diff --git a/assets/en.json b/assets/en.json index b9280570..db5467ac 100644 --- a/assets/en.json +++ b/assets/en.json @@ -8,15 +8,15 @@ "tiles": { "water": { "interact": "A refreshing body of water." + }, + "lamp": { + "interact": "An electric lamp.\nA real lightbulb idea." + }, + "rail": { + "interact": "Train tracks.\n...Better not cross them." } }, "entities": { - "sign": { - "name": "Sign" - }, - "bob": { - "name": "Bob" - } }, "maps": { "testmap": { @@ -26,6 +26,11 @@ "1": "This is another sign.", "2": "It has two lines." } + }, + "train_station": { + "stair_sign": { + "0": "Stairs slippery when wet.\n\n<- West to Town.\n-> East to lakefront." + } } } } \ No newline at end of file diff --git a/assets/maps/downtown.tmx b/assets/maps/downtown.tmx new file mode 100644 index 00000000..9381956e --- /dev/null +++ b/assets/maps/downtown.tmx @@ -0,0 +1,17 @@ + + + + +0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,0 + + + diff --git a/assets/maps/train_station.tmx b/assets/maps/train_station.tmx index 086ca2c2..a3b06e51 100644 --- a/assets/maps/train_station.tmx +++ b/assets/maps/train_station.tmx @@ -1,7 +1,8 @@ - + - + + 0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,0,0,0,0,0,0, @@ -18,16 +19,16 @@ 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, 10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,8,8,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10, -0,0,0,0,11,0,12,13,12,11,12,13,12,0,11,0,0,0,0,11,0,9,9,0,11,0,0,0,0,11,0,0,0,0,11,0,0,0,0,0, -0,0,0,0,11,0,12,13,12,11,12,13,12,0,11,0,0,0,0,11,0,9,9,0,11,0,0,0,0,11,0,6,6,6,6,6,0,0,0,0, -0,0,10,8,11,8,12,13,12,11,12,13,12,8,11,8,8,8,8,11,8,9,9,8,11,8,8,8,8,11,8,6,6,6,6,6,0,0,0,0, -0,0,10,8,8,8,12,13,12,0,12,13,12,8,8,8,15,8,8,8,8,9,9,8,8,8,8,8,8,8,8,6,6,6,6,6,0,0,0,0, -0,0,10,8,8,8,12,13,12,0,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,6,6,6,6,6,0,0,0,0, -0,0,10,8,8,8,12,13,12,0,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,6,6,6,6,6,0,0,0,0, -0,0,10,8,8,8,12,13,12,10,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,14,6,6,6,6,6,0,0,0,0, -0,0,10,8,15,8,12,13,12,8,12,13,12,8,8,8,15,8,8,8,8,8,8,8,8,8,8,8,8,8,14,5,5,5,5,5,0,0,0,0, -0,0,10,8,8,8,12,13,12,8,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,5,5,5,5,5,0,0,0,0, -0,0,10,10,10,10,12,13,12,10,12,13,12,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,0,0,0,0, +0,0,0,0,11,0,12,13,12,11,12,13,12,0,11,0,0,0,0,11,0,9,9,0,11,0,0,0,0,11,0,0,0,0,11,0,0,0,0,11, +0,0,0,0,11,0,12,13,12,11,12,13,12,0,11,0,0,0,0,11,0,9,9,0,11,0,0,0,0,11,0,0,6,6,6,6,0,0,0,11, +0,0,10,8,11,8,12,13,12,11,12,13,12,8,11,8,8,8,8,11,8,9,9,8,11,8,8,8,8,11,8,6,6,6,6,6,6,0,0,11, +0,0,10,8,8,8,12,13,12,0,12,13,12,8,8,8,15,8,8,8,8,9,9,8,8,8,8,15,8,8,8,6,6,6,6,6,6,0,0,0, +0,0,10,8,8,8,12,13,12,0,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,6,6,6,6,6,6,0,0,0, +0,0,10,8,8,8,12,13,12,0,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,6,6,6,6,6,6,0,0,0, +0,0,10,8,8,8,12,13,12,10,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,14,6,6,5,5,6,6,0,0,0, +0,0,10,8,15,8,12,13,12,8,12,13,12,8,8,8,15,8,8,8,8,8,8,8,8,8,8,15,8,8,14,5,5,5,5,5,5,0,0,0, +0,0,10,8,8,8,12,13,12,8,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,5,5,5,5,5,5,0,0,0, +0,0,10,10,10,10,12,13,12,10,12,13,12,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,5,5,5,5,5,5,0,0,0, 0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, @@ -35,5 +36,12 @@ 0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - + + + + + + + + diff --git a/assets/tiled_project.tiled-session b/assets/tiled_project.tiled-session index 53fc9afe..06e1e928 100644 --- a/assets/tiled_project.tiled-session +++ b/assets/tiled_project.tiled-session @@ -3,10 +3,11 @@ "height": 4300, "width": 2 }, - "activeFile": "maps/train_station.tmx", + "activeFile": "tilemaps/entities.tsx", "expandedProjectPaths": [ "maps", - "." + ".", + "tilemaps" ], "file.lastUsedOpenFilter": "All Files (*)", "fileStates": { @@ -17,6 +18,14 @@ "scaleInDock": 1, "scaleInEditor": 1 }, + "maps/downtown.tmx": { + "scale": 4.9072, + "selectedLayer": 0, + "viewCenter": { + "x": 49.31529181610695, + "y": 54.002282360612995 + } + }, "maps/testmap.tmx": { "expandedObjectLayers": [ 2 @@ -40,11 +49,14 @@ } }, "maps/train_station.tmx": { - "scale": 3, - "selectedLayer": 0, + "expandedObjectLayers": [ + 2 + ], + "scale": 2.7603, + "selectedLayer": 1, "viewCenter": { - "x": 67.66666666666666, - "y": 49.333333333333314 + "x": 85.49795312103754, + "y": 157.22928667173855 } }, "testmap.tmx": { @@ -68,10 +80,11 @@ "scaleInEditor": 4 }, "tilemaps/entities.tsx": { - "scaleInDock": 1 + "scaleInDock": 2, + "scaleInEditor": 9.7785 }, "tilemaps/tilemap.tsx": { - "scaleInDock": 1 + "scaleInDock": 2 } }, "last.externalTilesetPath": "/home/yourwishes/htdocs/Dawn/assets", @@ -82,16 +95,18 @@ "map.tileWidth": 8, "map.width": 10, "openFiles": [ - "maps/testmap.tmx", - "maps/testmap2.tmx", - "maps/train_station.tmx" + "maps/train_station.tmx", + "tilemaps/entities.tsx", + "maps/downtown.tmx" ], "project": "tiled_project.tiled-project", "property.type": "string", "recentFiles": [ + "maps/train_station.tmx", + "maps/downtown.tmx", + "tilemaps/entities.tsx", "maps/testmap.tmx", - "maps/testmap2.tmx", - "maps/train_station.tmx" + "maps/testmap2.tmx" ], "tileset.lastUsedFilter": "All Files (*)", "tileset.lastUsedFormat": "tsx", diff --git a/assets/tilemaps/entities.tsx b/assets/tilemaps/entities.tsx index a48b47ee..731d034a 100644 --- a/assets/tilemaps/entities.tsx +++ b/assets/tilemaps/entities.tsx @@ -1,4 +1,8 @@ + + + + diff --git a/src/dawn/rpg/conversation/conversationinteracttile.c b/src/dawn/rpg/conversation/conversationinteracttile.c index 90a88670..681a1d4c 100644 --- a/src/dawn/rpg/conversation/conversationinteracttile.c +++ b/src/dawn/rpg/conversation/conversationinteracttile.c @@ -21,6 +21,15 @@ uint16_t conversationInteractTileInit( case TILE_WATER: textboxSetText(NULL, "tiles.water.interact"); break; + + case TILE_LAMP: + textboxSetText(NULL, "tiles.lamp.interact"); + break; + + case TILE_RAIL_SLEEPER: + case TILE_RAIL_TRACK: + textboxSetText(NULL, "tiles.rail.interact"); + break; default: assertUnreachable("Invalid tile interaction!"); diff --git a/src/dawn/rpg/entity/interact.c b/src/dawn/rpg/entity/interact.c index a4f405ae..e1a9d14c 100644 --- a/src/dawn/rpg/entity/interact.c +++ b/src/dawn/rpg/entity/interact.c @@ -68,6 +68,9 @@ void entityInteractTile( switch(tile) { case TILE_WATER: + case TILE_LAMP: + case TILE_RAIL_SLEEPER: + case TILE_RAIL_TRACK: source->state = ENTITY_STATE_TALKING; conversationSet( conversationInteractTileInit, diff --git a/src/dawn/rpg/world/tile.c b/src/dawn/rpg/world/tile.c index 5e922c19..6594623d 100644 --- a/src/dawn/rpg/world/tile.c +++ b/src/dawn/rpg/world/tile.c @@ -74,6 +74,11 @@ bool_t tileIsSolid(const tile_t tile) { case TILE_WATER: case TILE_BUILDING_WALL: case TILE_ROOF: + case TILE_RAILING: + case TILE_COLUMN: + case TILE_RAIL_SLEEPER: + case TILE_RAIL_TRACK: + case TILE_LAMP: return true;