Mario Editor: formatting

This commit is contained in:
zv0n 2021-05-31 14:04:28 +02:00
parent cd0a301e52
commit 5d20757d43

View File

@ -96,7 +96,6 @@ struct GlobalVars {
GlobalVars global_vars; GlobalVars global_vars;
std::mutex destruction_mutex; std::mutex destruction_mutex;
void updateTool() { void updateTool() {
auto tool_index = global_vars.tool.index; auto tool_index = global_vars.tool.index;
uint64_t tool_id = 0; uint64_t tool_id = 0;
@ -128,7 +127,8 @@ void updateTool() {
break; break;
} }
global_vars.current_tool->setTexture( global_vars.current_tool->setTexture(
target_texture, getSourceRectByID( tool_id, global_vars.current_world_type ) ); target_texture,
getSourceRectByID( tool_id, global_vars.current_world_type ) );
global_vars.current_tool->setId( tool_id ); global_vars.current_tool->setId( tool_id );
global_vars.current_tool->getCollisions()[0]->setId( tool_id ); global_vars.current_tool->getCollisions()[0]->setId( tool_id );
} }
@ -395,16 +395,22 @@ bool getFlag( uint64_t flag ) {
} }
void updateWorld() { void updateWorld() {
for(auto &block : global_vars.tools) { for ( auto &block : global_vars.tools ) {
block->setTextureSourceRect(getSourceRectByID(block->getId(), global_vars.current_world_type)); block->setTextureSourceRect( getSourceRectByID(
dynamic_cast<MarioBlock *>(block.get())->setType(global_vars.current_world_type); block->getId(), global_vars.current_world_type ) );
dynamic_cast< MarioBlock * >( block.get() )
->setType( global_vars.current_world_type );
} }
for(auto &block : global_vars.characters) { for ( auto &block : global_vars.characters ) {
block->setTextureSourceRect(getSourceRectByID(block->getId(), global_vars.current_world_type)); block->setTextureSourceRect( getSourceRectByID(
dynamic_cast<MarioBlock *>(block.get())->setType(global_vars.current_world_type); block->getId(), global_vars.current_world_type ) );
dynamic_cast< MarioBlock * >( block.get() )
->setType( global_vars.current_world_type );
} }
global_vars.current_tool->setTextureSourceRect(getSourceRectByID(global_vars.current_tool->getId(), global_vars.current_world_type)); global_vars.current_tool->setTextureSourceRect( getSourceRectByID(
dynamic_cast<MarioBlock *>(global_vars.current_tool.get())->setType(global_vars.current_world_type); global_vars.current_tool->getId(), global_vars.current_world_type ) );
dynamic_cast< MarioBlock * >( global_vars.current_tool.get() )
->setType( global_vars.current_world_type );
} }
// TODO add mouse wheel control for modifiers // TODO add mouse wheel control for modifiers
@ -539,7 +545,7 @@ void placeTool( SDLPP::Scene &scene ) {
std::lock_guard< std::mutex > lock( destruction_mutex ); std::lock_guard< std::mutex > lock( destruction_mutex );
ToolVisitor visitor; ToolVisitor visitor;
visitor.setSourceType(global_vars.current_world_type); visitor.setSourceType( global_vars.current_world_type );
auto tool_type = getBlockRole( global_vars.current_tool->getId() ); auto tool_type = getBlockRole( global_vars.current_tool->getId() );
switch ( tool_type ) { switch ( tool_type ) {
case BlockRole::TERRAIN: case BlockRole::TERRAIN:
@ -555,7 +561,8 @@ void placeTool( SDLPP::Scene &scene ) {
auto &obj = getSelectedObject(); auto &obj = getSelectedObject();
switch ( visitor.getVisitorType() ) { switch ( visitor.getVisitorType() ) {
case VisitorType::Terrain: case VisitorType::Terrain:
std::get< MapObject::TERRAIN_TYPE >( obj ) = global_vars.current_world_type; std::get< MapObject::TERRAIN_TYPE >( obj ) =
global_vars.current_world_type;
std::get< MapObject::TERRAIN_ID >( obj ) = 0; std::get< MapObject::TERRAIN_ID >( obj ) = 0;
break; break;
case VisitorType::Modifier: case VisitorType::Modifier:
@ -574,14 +581,16 @@ void placeTool( SDLPP::Scene &scene ) {
std::shared_ptr< SDLPP::RenderObject > new_obj = nullptr; std::shared_ptr< SDLPP::RenderObject > new_obj = nullptr;
switch ( visitor.getVisitorType() ) { switch ( visitor.getVisitorType() ) {
case VisitorType::Terrain: case VisitorType::Terrain:
std::get< MapObject::TERRAIN_TYPE >( obj ) = global_vars.current_world_type; std::get< MapObject::TERRAIN_TYPE >( obj ) =
global_vars.current_world_type;
std::get< MapObject::TERRAIN_ID >( obj ) = std::get< MapObject::TERRAIN_ID >( obj ) =
global_vars.current_tool->getId(); global_vars.current_tool->getId();
// TODO why 1 +? // TODO why 1 +?
new_obj = createTerrainBlock( new_obj =
global_vars.current_tool->getId(), global_vars.current_world_type, createTerrainBlock( global_vars.current_tool->getId(),
renderer, 1 + global_vars.mouse.edit_box.getX(), global_vars.current_world_type, renderer,
global_vars.mouse.edit_box.getY(), true ); 1 + global_vars.mouse.edit_box.getX(),
global_vars.mouse.edit_box.getY(), true );
new_obj->getCollisions()[0]->setId( EDITOR_TERRAIN_ID ); new_obj->getCollisions()[0]->setId( EDITOR_TERRAIN_ID );
break; break;
case VisitorType::Modifier: case VisitorType::Modifier:
@ -607,8 +616,9 @@ void placeTool( SDLPP::Scene &scene ) {
global_vars.current_tool->getId(); global_vars.current_tool->getId();
std::get< MapObject::MODIFIER_DATA >( obj ) = 0; std::get< MapObject::MODIFIER_DATA >( obj ) = 0;
new_obj = createTerrainBlock( new_obj = createTerrainBlock(
global_vars.current_tool->getId(), global_vars.current_world_type, global_vars.current_tool->getId(),
renderer, 1 + global_vars.mouse.edit_box.getX(), global_vars.current_world_type, renderer,
1 + global_vars.mouse.edit_box.getX(),
global_vars.mouse.edit_box.getY(), global_vars.mouse.edit_box.getY(),
global_vars.translucent_terrain_texture, true ); global_vars.translucent_terrain_texture, true );
new_obj->getCollisions()[0]->setId( EDITOR_TERRAIN_ID ); new_obj->getCollisions()[0]->setId( EDITOR_TERRAIN_ID );
@ -679,7 +689,7 @@ void pollEvents( SDLPP::Scene &scene ) {
} }
size_t index = size_t index =
tool_box.getY() * ( multiplier / 2 ) + tool_box.getX(); tool_box.getY() * ( multiplier / 2 ) + tool_box.getX();
if(global_vars.mouse.tool_type == ToolType::WORLD) { if ( global_vars.mouse.tool_type == ToolType::WORLD ) {
global_vars.current_world_type = possibleLands[index]; global_vars.current_world_type = possibleLands[index];
updateWorld(); updateWorld();
} else if ( index < max_index ) { } else if ( index < max_index ) {
@ -778,7 +788,8 @@ void populateToolGrid(
ToolType::Value type, const std::vector< uint64_t > &blocks, ToolType::Value type, const std::vector< uint64_t > &blocks,
std::vector< std::shared_ptr< SDLPP::RenderObject > > &tool_store, std::vector< std::shared_ptr< SDLPP::RenderObject > > &tool_store,
std::vector< std::shared_ptr< SDLPP::RenderObject > > &tool_box_store, std::vector< std::shared_ptr< SDLPP::RenderObject > > &tool_box_store,
std::shared_ptr< SDLPP::Scene > &scene, const std::string &title, const std::shared_ptr<SDLPP::FontConfiguration> &font_config ) { std::shared_ptr< SDLPP::Scene > &scene, const std::string &title,
const std::shared_ptr< SDLPP::FontConfiguration > &font_config ) {
auto renderer = scene->getRendererShared(); auto renderer = scene->getRendererShared();
for ( int j = 0; j < count_y; j++ ) { for ( int j = 0; j < count_y; j++ ) {
for ( int i = 0; i < count_x; i++ ) { for ( int i = 0; i < count_x; i++ ) {
@ -792,15 +803,15 @@ void populateToolGrid(
switch ( type ) { switch ( type ) {
case ToolType::CHARACTER: case ToolType::CHARACTER:
if ( block == MARIO_ID ) if ( block == MARIO_ID )
tool_store.push_back( tool_store.push_back( createMario(
createMario( global_vars.current_world_type, renderer, 0, 0 ) ); global_vars.current_world_type, renderer, 0, 0 ) );
else else
case ToolType::BLOCK: case ToolType::BLOCK:
case ToolType::MOD: case ToolType::MOD:
tool_store.push_back( createTerrainBlock( tool_store.push_back( createTerrainBlock(
block, global_vars.current_world_type, renderer, false ) ); block, global_vars.current_world_type, renderer, false ) );
default: default:
break; break;
} }
tool_store.back()->setHidden( true ); tool_store.back()->setHidden( true );
tool_store.back()->setPermanent(); tool_store.back()->setPermanent();
@ -821,21 +832,25 @@ void populateToolGrid(
tool_box_store.push_back( tool_box ); tool_box_store.push_back( tool_box );
} }
} }
auto tool_text = std::make_shared<SDLPP::TextRenderer>(start_x - BLOCK_SIZE, start_y - BLOCK_SIZE, (count_x + 2) * BLOCK_SIZE, BLOCK_SIZE, renderer, title, font_config, SDLPP_TEXT_CENTER); auto tool_text = std::make_shared< SDLPP::TextRenderer >(
tool_text->setAlignment(SDLPP::OBJ_CENTER, SDLPP::OBJ_CENTER); start_x - BLOCK_SIZE, start_y - BLOCK_SIZE,
( count_x + 2 ) * BLOCK_SIZE, BLOCK_SIZE, renderer, title, font_config,
SDLPP_TEXT_CENTER );
tool_text->setAlignment( SDLPP::OBJ_CENTER, SDLPP::OBJ_CENTER );
tool_text->setPermanent(); tool_text->setPermanent();
scene->addObject(tool_text); scene->addObject( tool_text );
} }
void populateWorldType( void populateWorldType(
int count_x, int count_y, float start_x, float start_y, int count_x, int count_y, float start_x, float start_y,
std::shared_ptr< SDLPP::Scene > &scene, const std::string &title, const std::shared_ptr<SDLPP::FontConfiguration> &font_config ) { std::shared_ptr< SDLPP::Scene > &scene, const std::string &title,
const std::shared_ptr< SDLPP::FontConfiguration > &font_config ) {
auto renderer = scene->getRendererShared(); auto renderer = scene->getRendererShared();
for ( int j = 0; j < count_y; j++ ) { for ( int j = 0; j < count_y; j++ ) {
for ( int i = 0; i < count_x; i++ ) { for ( int i = 0; i < count_x; i++ ) {
auto tool_box = std::make_shared< ToolBox >( i, j, start_x, start_y, auto tool_box =
renderer ); std::make_shared< ToolBox >( i, j, start_x, start_y, renderer );
tool_box->setType(ToolType::WORLD); tool_box->setType( ToolType::WORLD );
scene->addObject( tool_box ); scene->addObject( tool_box );
} }
} }
@ -844,17 +859,18 @@ void populateWorldType(
auto land = createTerrainBlock( BRICK_ID, type, renderer, false ); auto land = createTerrainBlock( BRICK_ID, type, renderer, false );
auto x = tool_index % count_x; auto x = tool_index % count_x;
auto y = tool_index / count_x; auto y = tool_index / count_x;
land->setId(EDITOR_WORLD_CHANGE_ID); land->setId( EDITOR_WORLD_CHANGE_ID );
land->setPermanent(); land->setPermanent();
land->setPos( start_x + x * BLOCK_SIZE, land->setPos( start_x + x * BLOCK_SIZE, start_y + y * BLOCK_SIZE );
start_y + y * BLOCK_SIZE );
scene->addObject( land ); scene->addObject( land );
tool_index = ( tool_index + 1 ) % ( 2 * count_x ); tool_index = ( tool_index + 1 ) % ( 2 * count_x );
} }
auto tool_text = std::make_shared<SDLPP::TextRenderer>(start_x, start_y - BLOCK_SIZE, count_x * BLOCK_SIZE, BLOCK_SIZE, renderer, title, font_config, SDLPP_TEXT_CENTER); auto tool_text = std::make_shared< SDLPP::TextRenderer >(
tool_text->setAlignment(SDLPP::OBJ_CENTER, SDLPP::OBJ_CENTER); start_x, start_y - BLOCK_SIZE, count_x * BLOCK_SIZE, BLOCK_SIZE,
renderer, title, font_config, SDLPP_TEXT_CENTER );
tool_text->setAlignment( SDLPP::OBJ_CENTER, SDLPP::OBJ_CENTER );
tool_text->setPermanent(); tool_text->setPermanent();
scene->addObject(tool_text); scene->addObject( tool_text );
} }
void checkArrowsEnabled( uint64_t cur_page, uint64_t max_page, void checkArrowsEnabled( uint64_t cur_page, uint64_t max_page,
@ -953,7 +969,8 @@ int main() {
// tools // tools
populateToolGrid( TOOLS_WIDTH, 2, ( MAP_WIDTH - TOOLS_WIDTH ) * BLOCK_SIZE, populateToolGrid( TOOLS_WIDTH, 2, ( MAP_WIDTH - TOOLS_WIDTH ) * BLOCK_SIZE,
BLOCK_SIZE, ToolType::BLOCK, possibleBlocks, BLOCK_SIZE, ToolType::BLOCK, possibleBlocks,
global_vars.tools, global_vars.tool_boxes, scene, "TERRAIN", font_config ); global_vars.tools, global_vars.tool_boxes, scene,
"TERRAIN", font_config );
arrows = createArrowControls( ( MAP_WIDTH - TOOLS_WIDTH - 1 ) * BLOCK_SIZE, arrows = createArrowControls( ( MAP_WIDTH - TOOLS_WIDTH - 1 ) * BLOCK_SIZE,
MAP_WIDTH * BLOCK_SIZE, BLOCK_SIZE, MAP_WIDTH * BLOCK_SIZE, BLOCK_SIZE,
2 * BLOCK_SIZE, EDITOR_LEFT_TOOL_ID, 2 * BLOCK_SIZE, EDITOR_LEFT_TOOL_ID,
@ -966,9 +983,10 @@ int main() {
populateToolGrid( MOD_WIDTH, 2, 4 * BLOCK_SIZE, BLOCK_SIZE, ToolType::MOD, populateToolGrid( MOD_WIDTH, 2, 4 * BLOCK_SIZE, BLOCK_SIZE, ToolType::MOD,
possibleMods, global_vars.mods, global_vars.mod_boxes, possibleMods, global_vars.mods, global_vars.mod_boxes,
scene, "MODS", font_config ); scene, "MODS", font_config );
arrows = createArrowControls( arrows =
3 * BLOCK_SIZE, ( MOD_WIDTH + 4 ) * BLOCK_SIZE, BLOCK_SIZE, 2 * BLOCK_SIZE, createArrowControls( 3 * BLOCK_SIZE, ( MOD_WIDTH + 4 ) * BLOCK_SIZE,
EDITOR_LEFT_MOD_ID, EDITOR_RIGHT_MOD_ID, scene, font_config ); BLOCK_SIZE, 2 * BLOCK_SIZE, EDITOR_LEFT_MOD_ID,
EDITOR_RIGHT_MOD_ID, scene, font_config );
auto left_mod_arrow = arrows.first; auto left_mod_arrow = arrows.first;
auto right_mod_arrow = arrows.second; auto right_mod_arrow = arrows.second;
createGrid( 4 * BLOCK_SIZE, BLOCK_SIZE, MOD_WIDTH, 2, scene ); createGrid( 4 * BLOCK_SIZE, BLOCK_SIZE, MOD_WIDTH, 2, scene );
@ -988,7 +1006,8 @@ int main() {
scene ); scene );
// world type // world type
populateWorldType(OVERWORLD_WIDTH, 2, 0, BLOCK_SIZE, scene, "WORLD", font_config); populateWorldType( OVERWORLD_WIDTH, 2, 0, BLOCK_SIZE, scene, "WORLD",
font_config );
createGrid( 0, BLOCK_SIZE, OVERWORLD_WIDTH, 2, scene ); createGrid( 0, BLOCK_SIZE, OVERWORLD_WIDTH, 2, scene );
global_vars.map.max_page = global_vars.objects.size() - MAP_WIDTH; global_vars.map.max_page = global_vars.objects.size() - MAP_WIDTH;
@ -1018,8 +1037,8 @@ int main() {
renderer, "sprites/mario.png", MARIO_OVERWORLD_COLORKEY ); renderer, "sprites/mario.png", MARIO_OVERWORLD_COLORKEY );
global_vars.translucent_mario_texture->setAlpha( 100 ); global_vars.translucent_mario_texture->setAlpha( 100 );
global_vars.current_tool = createTerrainBlock( global_vars.current_tool = createTerrainBlock(
possibleBlocks[global_vars.tool.index], global_vars.current_world_type, renderer, possibleBlocks[global_vars.tool.index], global_vars.current_world_type,
global_vars.translucent_terrain_texture, false ); renderer, global_vars.translucent_terrain_texture, false );
global_vars.current_tool->addCollision( global_vars.current_tool->addCollision(
SDLPP::RectColider( 0.1, 0.1, 0.8, 0.8 ) ); SDLPP::RectColider( 0.1, 0.1, 0.8, 0.8 ) );
dynamic_cast< MarioBlock & >( *global_vars.current_tool ).setTool(); dynamic_cast< MarioBlock & >( *global_vars.current_tool ).setTool();