+void PushButton::OnSelected( bool selected )
+{
+ Actor& selectedImage = GetSelectedImage();
+ Actor& buttonImage = GetButtonImage();
+ Actor& fadeOutButtonImage = GetFadeOutButtonImage();
+
+ switch( mPaintState )
+ {
+ case UnselectedState:
+ {
+ StopFadeOutAnimation();
+ FadeOutImage( Foreground, buttonImage );
+ FadeInImage( selectedImage );
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( buttonImage || selectedImage )
+ {
+ mPaintState = UnselectedSelectedTransition;
+ }
+ else
+ {
+ mPaintState = SelectedState;
+ }
+ break;
+ }
+ case SelectedState:
+ {
+ StopFadeOutAnimation();
+ FadeOutImage( Foreground, selectedImage );
+ FadeInImage( buttonImage );
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( buttonImage || selectedImage )
+ {
+ mPaintState = SelectedUnselectedTransition;
+ }
+ else
+ {
+ mPaintState = UnselectedState;
+ }
+ break;
+ }
+ case UnselectedSelectedTransition:
+ {
+ float opacity = 1.f;
+ if( fadeOutButtonImage )
+ {
+ opacity = fadeOutButtonImage.GetCurrentOpacity();
+ }
+ StopFadeOutAnimation( false );
+ StopFadeInAnimation();
+
+ FadeOutImage( Foreground, selectedImage, 1.f - opacity );
+ FadeInImage( buttonImage, opacity );
+
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( buttonImage || selectedImage )
+ {
+ mPaintState = SelectedUnselectedTransition;
+ }
+ else
+ {
+ mPaintState = UnselectedState;
+ }
+ break;
+ }
+ case SelectedUnselectedTransition:
+ {
+ float opacity = 0.f;
+ if( fadeOutButtonImage )
+ {
+ opacity = 1.f - fadeOutButtonImage.GetCurrentOpacity();
+ }
+ StopFadeOutAnimation( false );
+ StopFadeInAnimation();
+
+ FadeOutImage( Foreground, buttonImage, 1.f - opacity );
+ FadeInImage( selectedImage, opacity );
+
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( buttonImage || selectedImage )
+ {
+ mPaintState = UnselectedSelectedTransition;
+ }
+ else
+ {
+ mPaintState = SelectedState;
+ }
+ break;
+ }
+ default:
+ {
+ break;
+ }
+ }
+}
+
+void PushButton::OnDisabled( bool disabled )
+{
+ Actor& buttonImage = GetButtonImage();
+ Actor& selectedImage = GetSelectedImage();
+ Actor& backgroundImage = GetBackgroundImage();
+ Actor& disabledImage = GetDisabledImage();
+ Actor& disabledBackgroundImage = GetDisabledBackgroundImage();
+ Actor& fadeOutButtonImage = GetFadeOutButtonImage();
+
+ switch( mPaintState )
+ {
+ case UnselectedState:
+ {
+ if( disabled )
+ {
+ StopFadeOutAnimation();
+ FadeOutImage( Background, backgroundImage );
+ FadeOutImage( Foreground, buttonImage );
+ FadeInImage( disabledBackgroundImage );
+ FadeInImage( disabledImage );
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( buttonImage || disabledImage || backgroundImage || disabledBackgroundImage )
+ {
+ mPaintState = UnselectedDisabledTransition;
+ }
+ else
+ {
+ mPaintState = DisabledUnselectedState;
+ }
+ }
+ break;
+ }
+ case SelectedState:
+ {
+ if( disabled )
+ {
+ StopFadeOutAnimation();
+ FadeOutImage( Background, backgroundImage );
+ FadeOutImage( Foreground, selectedImage );
+ FadeInImage( disabledBackgroundImage );
+ FadeInImage( disabledImage );
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( selectedImage || disabledImage || backgroundImage || disabledBackgroundImage )
+ {
+ mPaintState = SelectedDisabledTransition;
+ }
+ else
+ {
+ mPaintState = DisabledSelectedState;
+ }
+ }
+ break;
+ }
+ case DisabledUnselectedState:
+ {
+ if( !disabled )
+ {
+ StopFadeOutAnimation();
+ FadeOutImage( Background, disabledBackgroundImage );
+ FadeOutImage( Foreground, disabledImage );
+ FadeInImage( backgroundImage );
+ FadeInImage( buttonImage );
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( buttonImage || disabledImage || backgroundImage || disabledBackgroundImage )
+ {
+ mPaintState = DisabledUnselectedTransition;
+ }
+ else
+ {
+ mPaintState = UnselectedState;
+ }
+ }
+ break;
+ }
+ case DisabledSelectedState:
+ {
+ if( !disabled )
+ {
+ StopFadeOutAnimation();
+ FadeOutImage( Background, disabledBackgroundImage );
+ FadeOutImage( Foreground, disabledImage );
+ FadeInImage( backgroundImage );
+ FadeInImage( selectedImage );
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( selectedImage || disabledImage || backgroundImage || disabledBackgroundImage )
+ {
+ mPaintState = DisabledSelectedTransition;
+ }
+ else
+ {
+ mPaintState = SelectedState;
+ }
+ }
+ break;
+ }
+ case UnselectedSelectedTransition:
+ {
+ if( disabled )
+ {
+ float opacity = 1.f;
+ if( fadeOutButtonImage )
+ {
+ opacity = fadeOutButtonImage.GetCurrentOpacity();
+ }
+ StopFadeOutAnimation();
+ StopFadeInAnimation();
+
+ FadeOutImage( Foreground, selectedImage, 1.f - opacity );
+ FadeOutImage( Background, backgroundImage );
+
+ FadeInImage( disabledImage );
+ FadeInImage( disabledBackgroundImage );
+
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( selectedImage || disabledImage || backgroundImage || disabledBackgroundImage )
+ {
+ mPaintState = SelectedDisabledTransition;
+ }
+ else
+ {
+ mPaintState = DisabledSelectedState;
+ }
+ }
+ break;
+ }
+ case SelectedUnselectedTransition:
+ {
+ if( disabled )
+ {
+ float opacity = 1.f;
+ if( fadeOutButtonImage )
+ {
+ opacity = fadeOutButtonImage.GetCurrentOpacity();
+ }
+ StopFadeOutAnimation();
+ StopFadeInAnimation();
+
+ FadeOutImage( Foreground, buttonImage, 1.f - opacity );
+ FadeOutImage( Background, backgroundImage );
+
+ FadeInImage( disabledImage );
+ FadeInImage( disabledBackgroundImage );
+
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( buttonImage || disabledImage || backgroundImage || disabledBackgroundImage )
+ {
+ mPaintState = UnselectedDisabledTransition;
+ }
+ else
+ {
+ mPaintState = DisabledUnselectedState;
+ }
+ }
+ break;
+ }
+ case UnselectedDisabledTransition:
+ {
+ if( !disabled )
+ {
+ float opacity = 1.f;
+ if( fadeOutButtonImage )
+ {
+ opacity = fadeOutButtonImage.GetCurrentOpacity();
+ }
+ StopFadeOutAnimation( false );
+ StopFadeInAnimation();
+
+ FadeOutImage( Foreground, disabledImage, 1.f - opacity );
+ FadeOutImage( Background, disabledBackgroundImage, 1.f - opacity );
+ FadeInImage( buttonImage, opacity );
+ FadeInImage( backgroundImage, opacity );
+
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( buttonImage || disabledImage || backgroundImage || disabledBackgroundImage )
+ {
+ mPaintState = DisabledUnselectedTransition;
+ }
+ else
+ {
+ mPaintState = UnselectedState;
+ }
+ }
+ break;
+ }
+ case DisabledUnselectedTransition:
+ {
+ if( disabled )
+ {
+ float opacity = 1.f;
+ if( fadeOutButtonImage )
+ {
+ opacity = fadeOutButtonImage.GetCurrentOpacity();
+ }
+ StopFadeOutAnimation( false );
+ StopFadeInAnimation();
+
+ FadeOutImage( Foreground, buttonImage, 1.f - opacity );
+ FadeOutImage( Background, backgroundImage, 1.f - opacity );
+ FadeInImage( disabledImage, opacity );
+ FadeInImage( disabledBackgroundImage, opacity );
+
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( buttonImage || disabledImage || backgroundImage || disabledBackgroundImage )
+ {
+ mPaintState = UnselectedDisabledTransition;
+ }
+ else
+ {
+ mPaintState = DisabledUnselectedState;
+ }
+ }
+ break;
+ }
+ case SelectedDisabledTransition:
+ {
+ if( !disabled )
+ {
+ float opacity = 1.f;
+ if( fadeOutButtonImage )
+ {
+ opacity = fadeOutButtonImage.GetCurrentOpacity();
+ }
+ StopFadeOutAnimation( false );
+ StopFadeInAnimation();
+
+ FadeOutImage( Foreground, disabledImage, 1.f - opacity );
+ FadeOutImage( Background, disabledBackgroundImage, 1.f - opacity );
+ FadeInImage( selectedImage, opacity );
+ FadeInImage( backgroundImage, opacity );
+
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( selectedImage || disabledImage || backgroundImage || disabledBackgroundImage )
+ {
+ mPaintState = DisabledSelectedTransition;
+ }
+ else
+ {
+ mPaintState = SelectedState;
+ }
+ }
+ break;
+ }
+ case DisabledSelectedTransition:
+ {
+ if( disabled )
+ {
+ float opacity = 1.f;
+ if( fadeOutButtonImage )
+ {
+ opacity = fadeOutButtonImage.GetCurrentOpacity();
+ }
+ StopFadeOutAnimation( false );
+ StopFadeInAnimation();
+
+ FadeOutImage( Foreground, selectedImage, 1.f - opacity );
+ FadeOutImage( Background, backgroundImage, 1.f - opacity );
+ FadeInImage( disabledImage, opacity );
+ FadeInImage( disabledBackgroundImage, opacity );
+
+ StartFadeOutAnimation();
+ StartFadeInAnimation();
+
+ if( selectedImage || disabledImage || backgroundImage || disabledBackgroundImage )
+ {
+ mPaintState = SelectedDisabledTransition;
+ }
+ else
+ {
+ mPaintState = DisabledSelectedState;
+ }
+ }
+ break;
+ }
+ default:
+ break;
+ }
+}
+
+void PushButton::OnPressed()