Fixed how sprites/textures are loaded so tehy default to frame 0 of any multi-frame textures.
This commit is contained in:
		
							parent
							
								
									6d73c87c4e
								
							
						
					
					
						commit
						b832bbd78a
					
				
					 7 changed files with 294 additions and 70 deletions
				
			
		
							
								
								
									
										2
									
								
								Makefile
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								Makefile
									
										
									
									
									
								
							|  | @ -41,7 +41,7 @@ clean: | |||
| 	meson compile --clean -C builddir | ||||
| 
 | ||||
| debug_test: build | ||||
| 	gdb --nx -x .gdbinit --ex run --args builddir/runtests.exe -e | ||||
| 	gdb --nx -x .gdbinit --ex run --args builddir/runtests.exe -e "[animation-fail]" | ||||
| 
 | ||||
| win_installer: | ||||
| 	powershell 'start "C:\Program Files (x86)\solicus\InstallForge\bin\ifbuilderenvx86.exe" win_installer.ifp' | ||||
|  |  | |||
|  | @ -20,68 +20,288 @@ | |||
|     "ambient_1": "assets/sounds/ambient_1.ogg" | ||||
|   }, | ||||
|   "sprites": { | ||||
|     "armored_knight": "assets/armored_knight_1-256.png", | ||||
|     "sword": "assets/cinqueda_1-512.png", | ||||
|     "rat_with_sword": "assets/rat_with_sword-256.png", | ||||
|     "rat_king": "assets/rat_king-256.png", | ||||
|     "rat_king_boss": "assets/rat_king_2_frame_animation.png", | ||||
|     "barrel_small": "assets/wood_barrel_small-256.png", | ||||
|     "hanging_brazier": "assets/hanging_brazier-256.png", | ||||
|     "torch_pillar": "assets/torch_pillar-256.png", | ||||
|     "torch_crappy": "assets/torch_crappy-256.png", | ||||
|     "torch_horizontal_floor": "assets/torch_horizontal_floor-256.png", | ||||
|     "evil_eye": "assets/evil_eye-sprites.png", | ||||
|     "peasant_girl": "assets/undead_peasant-256.png", | ||||
|     "grave_stone": "assets/grave_stone-256.png", | ||||
|     "floor": "assets/floor_tile_test-256.png", | ||||
|     "ceiling": "assets/ceiling_test-256.png", | ||||
|     "healing_potion_small": "assets/healing_potion_small-256.png", | ||||
|     "well_down": "assets/well_down-256.png", | ||||
|     "rope_vines_up": "assets/rope_vines_up-256.png", | ||||
|     "tripwire_trap": "assets/tripwire_trap-256.png", | ||||
|     "cinqueda": "assets/cinqueda_1-256.png", | ||||
|     "left_gui": "assets/left_gui.png", | ||||
|     "blood_splatter": "assets/blood_splatter-256.png", | ||||
|     "trash_button": "assets/trash_button.png", | ||||
|     "axe_ranger": "assets/axe_ranger-256.png", | ||||
|     "hairy_spider": "assets/hairy_spider-256.png", | ||||
|     "down_the_well": "assets/down_the_well.jpg", | ||||
|     "boss_fight_background": "assets/rat_king_boss_fight_background.jpg", | ||||
|     "devils_fingers_background": "assets/devils_fingers_background.jpg", | ||||
|     "devils_fingers_sprite": "assets/devils_fingers_sprite.png", | ||||
|     "devils_fingers_stage": "assets/devils_fingers_stage.png", | ||||
|     "tunnel_with_rocks": "assets/tunnel_with_rocks.png", | ||||
|     "tunnel_with_rocks_stage": "assets/tunnel_with_rocks_stage.png", | ||||
|     "ritual_crafting_area": "assets/ritual_crafting_area.png", | ||||
|     "the_ritual_circle": "assets/the_ritual_circle.png", | ||||
|     "paper_ui_background": "assets/paper_ui_background.png", | ||||
|     "full_screen_paper": "assets/full_screen_paper.png", | ||||
|     "broken_locket-64": "assets/rituals/broken_locket-64.png", | ||||
|     "broken_locket-128": "assets/rituals/broken_locket-128.png", | ||||
|     "broken_pen_knife-64": "assets/rituals/broken_pen_knife-64.png", | ||||
|     "broken_pen_knife-128": "assets/rituals/broken_pen_knife-128.png", | ||||
|     "broken_yoyo-64": "assets/rituals/broken_yoyo-64.png", | ||||
|     "broken_yoyo-128": "assets/rituals/broken_yoyo-128.png", | ||||
|     "chess_pawn-64": "assets/rituals/chess_pawn-64.png", | ||||
|     "chess_pawn-128": "assets/rituals/chess_pawn-128.png", | ||||
|     "dirty_kerchief-64": "assets/rituals/dirty_kerchief-64.png", | ||||
|     "dirty_kerchief-128": "assets/rituals/dirty_kerchief-128.png", | ||||
|     "leather_pouch-64": "assets/rituals/leather_pouch-64.png", | ||||
|     "leather_pouch-128": "assets/rituals/leather_pouch-128.png", | ||||
|     "mushroom-64": "assets/rituals/mushroom-64.png", | ||||
|     "mushroom-128": "assets/rituals/mushroom-128.png", | ||||
|     "pocket_watch-64": "assets/rituals/pocket_watch-64.png", | ||||
|     "pocket_watch-128": "assets/rituals/pocket_watch-128.png", | ||||
|     "rusty_nails-64": "assets/rituals/rusty_nails-64.png", | ||||
|     "rusty_nails-128": "assets/rituals/rusty_nails-128.png", | ||||
|     "severed_finger-64": "assets/rituals/severed_finger-64.png", | ||||
|     "severed_finger-128": "assets/rituals/severed_finger-128.png", | ||||
|     "stone_doll_cursed-64": "assets/rituals/stone_doll_cursed-64.png", | ||||
|     "stone_doll_cursed-128": "assets/rituals/stone_doll_cursed-128.png" | ||||
|     "armored_knight": | ||||
|     {"path": "assets/armored_knight_1-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "sword": | ||||
|     {"path": "assets/cinqueda_1-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "rat_with_sword": | ||||
|     {"path": "assets/rat_with_sword-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "rat_king": | ||||
|     {"path": "assets/rat_king-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "rat_king_boss": | ||||
|     {"path": "assets/rat_king_2_frame_animation.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "barrel_small": | ||||
|     {"path": "assets/wood_barrel_small-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "torch_pillar": | ||||
|     {"path": "assets/torch_pillar-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "torch_crappy": | ||||
|     {"path": "assets/torch_crappy-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "torch_horizontal_floor": | ||||
|     {"path": "assets/torch_horizontal_floor-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "evil_eye": | ||||
|     {"path": "assets/evil_eye-sprites.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "peasant_girl": | ||||
|     {"path": "assets/undead_peasant-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "grave_stone": | ||||
|     {"path": "assets/grave_stone-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "floor": | ||||
|     {"path": "assets/floor_tile_test-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "ceiling": | ||||
|     {"path": "assets/ceiling_test-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "healing_potion_small": | ||||
|     {"path": "assets/healing_potion_small-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "well_down": | ||||
|     {"path": "assets/well_down-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "rope_vines_up": | ||||
|     {"path": "assets/rope_vines_up-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "tripwire_trap": | ||||
|     {"path": "assets/tripwire_trap-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "cinqueda": | ||||
|     {"path": "assets/cinqueda_1-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "blood_splatter": | ||||
|     {"path": "assets/blood_splatter-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "axe_ranger": | ||||
|     {"path": "assets/axe_ranger-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "hairy_spider": | ||||
|     {"path": "assets/hairy_spider-256.png", | ||||
|       "frame_width": 256, | ||||
|       "frame_height": 256 | ||||
|     }, | ||||
|     "down_the_well": | ||||
|     {"path": "assets/down_the_well.jpg", | ||||
|       "frame_width": 900, | ||||
|       "frame_height": 600 | ||||
|     }, | ||||
|     "boss_fight_background": | ||||
|     {"path": "assets/rat_king_boss_fight_background.jpg", | ||||
|       "frame_width": 1080, | ||||
|       "frame_height": 720 | ||||
|     }, | ||||
|     "devils_fingers_background": | ||||
|     {"path": "assets/devils_fingers_background.jpg", | ||||
|       "frame_width": 1080, | ||||
|       "frame_height": 720 | ||||
|     }, | ||||
|     "devils_fingers_sprite": | ||||
|     {"path": "assets/devils_fingers_sprite.png", | ||||
|       "frame_width": 720, | ||||
|       "frame_height": 720 | ||||
|     }, | ||||
|     "devils_fingers_stage": | ||||
|     {"path": "assets/devils_fingers_stage.png", | ||||
|       "frame_width": 1080, | ||||
|       "frame_height": 720 | ||||
|     }, | ||||
|     "tunnel_with_rocks": | ||||
|     {"path": "assets/tunnel_with_rocks.png", | ||||
|       "frame_width": 1080, | ||||
|       "frame_height": 720 | ||||
|     }, | ||||
|     "tunnel_with_rocks_stage": | ||||
|     {"path": "assets/tunnel_with_rocks_stage.png", | ||||
|       "frame_width": 1080, | ||||
|       "frame_height": 720 | ||||
|     }, | ||||
|     "ritual_crafting_area": | ||||
|     {"path": "assets/ritual_crafting_area.png", | ||||
|       "frame_width": 380, | ||||
|       "frame_height": 720 | ||||
|     }, | ||||
|     "the_ritual_circle": | ||||
|     {"path": "assets/the_ritual_circle.png", | ||||
|       "frame_width": 380, | ||||
|       "frame_height": 380 | ||||
|     }, | ||||
|     "paper_ui_background": | ||||
|     {"path": "assets/paper_ui_background.png", | ||||
|       "frame_width": 380, | ||||
|       "frame_height": 720 | ||||
|     }, | ||||
|     "full_screen_paper": | ||||
|     {"path": "assets/full_screen_paper.png", | ||||
|       "frame_width": 1280, | ||||
|       "frame_height": 720 | ||||
|     }, | ||||
|     "broken_locket-64": | ||||
|     {"path": "assets/rituals/broken_locket-64.png", | ||||
|       "frame_width": 64, | ||||
|       "frame_height": 64 | ||||
|     }, | ||||
|     "broken_locket-128": | ||||
|     {"path": "assets/rituals/broken_locket-128.png", | ||||
|       "frame_width": 128, | ||||
|       "frame_height": 128 | ||||
|     }, | ||||
|     "broken_pen_knife-64": | ||||
|     {"path": "assets/rituals/broken_pen_knife-64.png", | ||||
|       "frame_width": 64, | ||||
|       "frame_height": 64 | ||||
|     }, | ||||
|     "broken_pen_knife-128": | ||||
|     {"path": "assets/rituals/broken_pen_knife-128.png", | ||||
|       "frame_width": 128, | ||||
|       "frame_height": 128 | ||||
|     }, | ||||
|     "broken_yoyo-64": | ||||
|     {"path": "assets/rituals/broken_yoyo-64.png", | ||||
|       "frame_width": 64, | ||||
|       "frame_height": 64 | ||||
|     }, | ||||
|     "broken_yoyo-128": | ||||
|     {"path": "assets/rituals/broken_yoyo-128.png", | ||||
|       "frame_width": 128, | ||||
|       "frame_height": 128 | ||||
|     }, | ||||
|     "chess_pawn-64": | ||||
|     {"path": "assets/rituals/chess_pawn-64.png", | ||||
|       "frame_width": 64, | ||||
|       "frame_height": 64 | ||||
|     }, | ||||
|     "chess_pawn-128": | ||||
|     {"path": "assets/rituals/chess_pawn-128.png", | ||||
|       "frame_width": 128, | ||||
|       "frame_height": 128 | ||||
|     }, | ||||
|     "dirty_kerchief-64": | ||||
|     {"path": "assets/rituals/dirty_kerchief-64.png", | ||||
|       "frame_width": 64, | ||||
|       "frame_height": 64 | ||||
|     }, | ||||
|     "dirty_kerchief-128": | ||||
|     {"path": "assets/rituals/dirty_kerchief-128.png", | ||||
|       "frame_width": 128, | ||||
|       "frame_height": 128 | ||||
|     }, | ||||
|     "leather_pouch-64": | ||||
|     {"path": "assets/rituals/leather_pouch-64.png", | ||||
|       "frame_width": 64, | ||||
|       "frame_height": 64 | ||||
|     }, | ||||
|     "leather_pouch-128": | ||||
|     {"path": "assets/rituals/leather_pouch-128.png", | ||||
|       "frame_width": 128, | ||||
|       "frame_height": 128 | ||||
|     }, | ||||
|     "mushroom-64": | ||||
|     {"path": "assets/rituals/mushroom-64.png", | ||||
|       "frame_width": 64, | ||||
|       "frame_height": 64 | ||||
|     }, | ||||
|     "mushroom-128": | ||||
|     {"path": "assets/rituals/mushroom-128.png", | ||||
|       "frame_width": 128, | ||||
|       "frame_height": 128 | ||||
|     }, | ||||
|     "pocket_watch-64": | ||||
|     {"path": "assets/rituals/pocket_watch-64.png", | ||||
|       "frame_width": 64, | ||||
|       "frame_height": 64 | ||||
|     }, | ||||
|     "pocket_watch-128": | ||||
|     {"path": "assets/rituals/pocket_watch-128.png", | ||||
|       "frame_width": 128, | ||||
|       "frame_height": 128 | ||||
|     }, | ||||
|     "rusty_nails-64": | ||||
|     {"path": "assets/rituals/rusty_nails-64.png", | ||||
|       "frame_width": 64, | ||||
|       "frame_height": 64 | ||||
|     }, | ||||
|     "rusty_nails-128": | ||||
|     {"path": "assets/rituals/rusty_nails-128.png", | ||||
|       "frame_width": 128, | ||||
|       "frame_height": 128 | ||||
|     }, | ||||
|     "severed_finger-64": | ||||
|     {"path": "assets/rituals/severed_finger-64.png", | ||||
|       "frame_width": 64, | ||||
|       "frame_height": 64 | ||||
|     }, | ||||
|     "severed_finger-128": | ||||
|     {"path": "assets/rituals/severed_finger-128.png", | ||||
|       "frame_width": 128, | ||||
|       "frame_height": 128 | ||||
|     }, | ||||
|     "stone_doll_cursed-64": | ||||
|     {"path": "assets/rituals/stone_doll_cursed-64.png", | ||||
|       "frame_width": 64, | ||||
|       "frame_height": 64 | ||||
|     }, | ||||
|     "stone_doll_cursed-128": | ||||
|     {"path": "assets/rituals/stone_doll_cursed-128.png", | ||||
|       "frame_width": 128, | ||||
|       "frame_height": 128 | ||||
|     } | ||||
|   }, | ||||
|   "worldgen": { | ||||
|     "enemy_probability": 50, | ||||
|     "empty_room_probability": 1, | ||||
|     "device_probability": 10 | ||||
|   }, | ||||
|   "graphics": { | ||||
|     "smooth_textures": true | ||||
|   } | ||||
| } | ||||
|  |  | |||
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 85 KiB | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 36 KiB | 
|  | @ -28,14 +28,16 @@ namespace guecs { | |||
| 
 | ||||
|   void Sprite::init(lel::Cell &cell) { | ||||
|     auto sprite_texture = textures::get(name); | ||||
|     texture = sprite_texture.texture; | ||||
|     sprite = make_shared<sf::Sprite>(*texture); | ||||
| 
 | ||||
|     sprite = make_shared<sf::Sprite>( | ||||
|         *sprite_texture.texture, | ||||
|         sprite_texture.sprite->getTextureRect()); | ||||
| 
 | ||||
|     sprite->setPosition({ | ||||
|         float(cell.x + padding), | ||||
|         float(cell.y + padding)}); | ||||
| 
 | ||||
|     auto bounds = sprite->getGlobalBounds(); | ||||
|     auto bounds = sprite->getLocalBounds(); | ||||
| 
 | ||||
|     sprite->setScale({ | ||||
|         float(cell.w - padding * 2) / bounds.size.x, | ||||
|  |  | |||
|  | @ -38,7 +38,7 @@ TEST_CASE("animation easing tests", "[animation]") { | |||
| } | ||||
| 
 | ||||
| 
 | ||||
| TEST_CASE("animation utility API", "[animation]") { | ||||
| TEST_CASE("animation utility API", "[animation-fail]") { | ||||
|   textures::init(); | ||||
|   animation::init(); | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										16
									
								
								textures.cpp
									
										
									
									
									
								
							
							
						
						
									
										16
									
								
								textures.cpp
									
										
									
									
									
								
							|  | @ -15,19 +15,21 @@ namespace textures { | |||
|   void load_sprites() { | ||||
|     Config assets("assets/config.json"); | ||||
| 
 | ||||
|     for(auto& el : assets["sprites"].items()) { | ||||
|       string path = el.value(); | ||||
|       auto texture = make_shared<sf::Texture>(path); | ||||
|     for(auto& [name, settings] : assets["sprites"].items()) { | ||||
|       auto texture = make_shared<sf::Texture>(settings["path"]); | ||||
| 
 | ||||
|       texture->setSmooth(false); | ||||
|       texture->setSmooth(assets["graphics"]["smooth_textures"]); | ||||
|       auto sprite = make_shared<sf::Sprite>(*texture); | ||||
| 
 | ||||
|       string name = el.key(); | ||||
|       int width = settings["frame_width"]; | ||||
|       int height = settings["frame_height"]; | ||||
|       sprite->setTextureRect({{0,0}, {width, height}}); | ||||
| 
 | ||||
|       TMGR.sprite_textures.try_emplace(name, name, sprite, texture); | ||||
|     } | ||||
| 
 | ||||
|     TMGR.floor = load_image(assets["sprites"]["floor"]); | ||||
|     TMGR.ceiling = load_image(assets["sprites"]["ceiling"]); | ||||
|     TMGR.floor = load_image(assets["sprites"]["floor"]["path"]); | ||||
|     TMGR.ceiling = load_image(assets["sprites"]["ceiling"]["path"]); | ||||
|   } | ||||
| 
 | ||||
|   void load_tiles() { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zed A. Shaw
						Zed A. Shaw