Browse Source

Improve CButton::block and fix CToggleGroup->selectedID

CToggleGroup. Originally when I added initialization for selectedID I didn't find out that -1 is used for "random" buttons. So as result I fixed uninitialized variable usage, but break initial button state change in RMG options because setSelected ignore state change request because it's see -1 button already marked as selected.
ArseniyShestakov 10 years ago
parent
commit
448fbe44e9
1 changed files with 3 additions and 2 deletions
  1. 3 2
      client/widgets/Buttons.cpp

+ 3 - 2
client/widgets/Buttons.cpp

@@ -144,7 +144,8 @@ bool CButton::isHighlighted()
 
 void CButton::block(bool on)
 {
-	setState(on?BLOCKED:NORMAL);
+	if(on || state == BLOCKED) //dont change button state if unblock requested, but it's not blocked
+		setState(on ? BLOCKED : NORMAL);
 }
 
 void CButton::onButtonClicked()
@@ -424,7 +425,7 @@ void CToggleGroup::addToggle(int identifier, CToggleBase* bt)
 }
 
 CToggleGroup::CToggleGroup(const CFunctionList<void(int)> &OnChange, bool musicLikeButtons)
-: onChange(OnChange), selectedID(-1), musicLike(musicLikeButtons)
+: onChange(OnChange), selectedID(-2), musicLike(musicLikeButtons)
 {}
 
 void CToggleGroup::setSelected(int id)