mirror of
				https://github.com/zenorogue/hyperrogue.git
				synced 2025-10-25 10:57:59 +00:00 
			
		
		
		
	rogueviz::ads:: better handling of param changes
This commit is contained in:
		| @@ -85,6 +85,7 @@ void restart() { | ||||
|  | ||||
|   paused = false; | ||||
|   ship_pt = 0; | ||||
|   no_param_change = all_params_default(); | ||||
|   init_gamedata(); | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -159,6 +159,7 @@ bool ads_turn(int idelta) { | ||||
|   hybrid::in_actual([&] { | ||||
|  | ||||
|   handle_crashes(); | ||||
|   if(no_param_change && !all_params_default()) no_param_change = false; | ||||
|  | ||||
|   auto& act = multi::action_states[1]; | ||||
|  | ||||
|   | ||||
| @@ -345,6 +345,7 @@ bool ds_turn(int idelta) { | ||||
|   if(!(cmode & sm::NORMAL)) return false; | ||||
|  | ||||
|   ds_handle_crashes(); | ||||
|   if(no_param_change && !all_params_default()) no_param_change = false; | ||||
|  | ||||
|   auto& act = multi::action_states[1]; | ||||
|  | ||||
| @@ -396,7 +397,7 @@ bool ds_turn(int idelta) { | ||||
|     if(mshift) { | ||||
|       #if RVCOL | ||||
|       constexpr ld win_time = 60; | ||||
|       if(current.shift < win_time && (current.shift + mshift) >= win_time && !game_over && all_params_default()) | ||||
|       if(current.shift < win_time && (current.shift + mshift) >= win_time && !game_over && no_param_change) | ||||
|         rogueviz::rv_achievement("DSGAME"); | ||||
|       #endif | ||||
|       current.shift += mshift; | ||||
| @@ -741,6 +742,7 @@ void ds_restart() { | ||||
|     } | ||||
|  | ||||
|   ship_pt = 0; | ||||
|   no_param_change = all_params_default(); | ||||
|  | ||||
|   rocks.clear(); | ||||
|   history.clear(); | ||||
|   | ||||
| @@ -251,6 +251,8 @@ string get_main_help(); | ||||
| int generate_mouseovers(); | ||||
|  | ||||
| bool all_params_default(); | ||||
| bool no_param_change; | ||||
| bool params_changed(); | ||||
|  | ||||
| void start_relhell_tour(); | ||||
|  | ||||
|   | ||||
| @@ -66,9 +66,9 @@ void game_over_with_message(const string& reason) { | ||||
|   if(pdata.ammo <= 0) cur.deathreason += " while out of ammo"; | ||||
|   game_over = true; | ||||
|   #if RVCOL | ||||
|   if(main_rock && all_params_default()) | ||||
|   if(main_rock && no_param_change) | ||||
|     rogueviz::rv_leaderboard("de Sitter", current.shift * 1000, 1, rvlc::ms); | ||||
|   if(!main_rock && all_params_default()) { | ||||
|   if(!main_rock && no_param_change) { | ||||
|     auto& s = pdata.score; | ||||
|     string data = lalign(0, s[0], " ", s[1], " ", s[2]); | ||||
|     rogueviz::rv_leaderboard("anti de Sitter: total score", s[0] + s[1] + s[2], 1, rvlc::num, data); | ||||
|   | ||||
| @@ -81,8 +81,11 @@ void edit_difficulty() { | ||||
|       }); | ||||
|     } | ||||
|  | ||||
|   dialog::addBoolItem(XLAT("all default"), all_params_default(), 'D'); | ||||
|   dialog::add_action([] { all_params_reset(); restart(); }); | ||||
|   bool pa = all_params_default(); | ||||
|   dialog::addSelItem(XLAT("all default"), | ||||
|     (pa && !no_param_change) ? XLAT("PARTIAL") : ONOFF(pa), 'd'); | ||||
|   if(pa) | ||||
|     dialog::add_action([] { all_params_reset(); restart(); }); | ||||
|  | ||||
|   dialog::addBack(); | ||||
|   dialog::display(); | ||||
|   | ||||
| @@ -201,7 +201,7 @@ void gain_resource(eResourceType rsrc) { | ||||
|   for(auto r: {rtGoldGate, rtGoldRocks, rtGoldTurret}) { | ||||
|     D(r, score[treasure_id(r)]) | ||||
|     #ifdef RVCOL | ||||
|     if(pdata.score[0] + pdata.score[1] + pdata.score[2] == 30 && all_params_default()) rogueviz::rv_achievement("ADSGAME"); | ||||
|     if(pdata.score[0] + pdata.score[1] + pdata.score[2] == 30 && no_param_change) rogueviz::rv_achievement("ADSGAME"); | ||||
|     #endif | ||||
|     } | ||||
|   playSound(nullptr, rsrc_sound[rsrc]); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Zeno Rogue
					Zeno Rogue