aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/lljoystickbutton.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/lljoystickbutton.cpp')
-rw-r--r--linden/indra/newview/lljoystickbutton.cpp73
1 files changed, 37 insertions, 36 deletions
diff --git a/linden/indra/newview/lljoystickbutton.cpp b/linden/indra/newview/lljoystickbutton.cpp
index dddbea8..b429ed2 100644
--- a/linden/indra/newview/lljoystickbutton.cpp
+++ b/linden/indra/newview/lljoystickbutton.cpp
@@ -36,6 +36,7 @@
36// Library includes 36// Library includes
37#include "llcoord.h" 37#include "llcoord.h"
38#include "indra_constants.h" 38#include "indra_constants.h"
39#include "llglimmediate.h"
39 40
40// Project includes 41// Project includes
41#include "llui.h" 42#include "llui.h"
@@ -72,18 +73,18 @@ LLJoystick::LLJoystick(
72 mHeldDown(FALSE), 73 mHeldDown(FALSE),
73 mHeldDownTimer() 74 mHeldDownTimer()
74{ 75{
75 mHeldDownCallback = &LLJoystick::onHeldDown; 76 setHeldDownCallback(&LLJoystick::onHeldDown);
76 mCallbackUserData = this; 77 setCallbackUserData(this);
77} 78}
78 79
79 80
80void LLJoystick::updateSlop() 81void LLJoystick::updateSlop()
81{ 82{
82 mVertSlopNear = mRect.getHeight(); 83 mVertSlopNear = getRect().getHeight();
83 mVertSlopFar = mRect.getHeight() * 2; 84 mVertSlopFar = getRect().getHeight() * 2;
84 85
85 mHorizSlopNear = mRect.getWidth(); 86 mHorizSlopNear = getRect().getWidth();
86 mHorizSlopFar = mRect.getWidth() * 2; 87 mHorizSlopFar = getRect().getWidth() * 2;
87 88
88 // Compute initial mouse offset based on initial quadrant. 89 // Compute initial mouse offset based on initial quadrant.
89 // Place the mouse evenly between the near and far zones. 90 // Place the mouse evenly between the near and far zones.
@@ -163,7 +164,7 @@ F32 LLJoystick::getElapsedHeldDownTime()
163{ 164{
164 if( mHeldDown ) 165 if( mHeldDown )
165 { 166 {
166 return mMouseDownTimer.getElapsedTimeF32(); 167 return getHeldDownTime();
167 } 168 }
168 else 169 else
169 { 170 {
@@ -244,13 +245,13 @@ LLXMLNodePtr LLJoystick::getXML(bool save_children) const
244{ 245{
245 LLXMLNodePtr node = LLUICtrl::getXML(); 246 LLXMLNodePtr node = LLUICtrl::getXML();
246 247
247 node->createChild("halign", TRUE)->setStringValue(LLFontGL::nameFromHAlign(mHAlign)); 248 node->createChild("halign", TRUE)->setStringValue(LLFontGL::nameFromHAlign(getHAlign()));
248 node->createChild("quadrant", TRUE)->setStringValue(nameFromQuadrant(mInitialQuadrant)); 249 node->createChild("quadrant", TRUE)->setStringValue(nameFromQuadrant(mInitialQuadrant));
249 250
250 addImageAttributeToXML(node,mImageUnselectedName,mImageUnselectedID,"image_unselected"); 251 addImageAttributeToXML(node,getImageUnselectedName(),getImageUnselectedID(),"image_unselected");
251 addImageAttributeToXML(node,mImageSelectedName,mImageSelectedID,"image_selected"); 252 addImageAttributeToXML(node,getImageSelectedName(),getImageSelectedID(),"image_selected");
252 253
253 node->createChild("scale_image", TRUE)->setBoolValue(mScaleImage); 254 node->createChild("scale_image", TRUE)->setBoolValue(getScaleImage());
254 255
255 return node; 256 return node;
256} 257}
@@ -504,8 +505,8 @@ BOOL LLJoystickCameraRotate::handleMouseDown(S32 x, S32 y, MASK mask)
504 updateSlop(); 505 updateSlop();
505 506
506 // Set initial offset based on initial click location 507 // Set initial offset based on initial click location
507 S32 horiz_center = mRect.getWidth() / 2; 508 S32 horiz_center = getRect().getWidth() / 2;
508 S32 vert_center = mRect.getHeight() / 2; 509 S32 vert_center = getRect().getHeight() / 2;
509 510
510 S32 dx = x - horiz_center; 511 S32 dx = x - horiz_center;
511 S32 dy = y - vert_center; 512 S32 dy = y - vert_center;
@@ -607,26 +608,26 @@ void LLJoystickCameraRotate::draw()
607 { 608 {
608 LLGLSUIDefault gls_ui; 609 LLGLSUIDefault gls_ui;
609 610
610 mImageUnselected->draw( 0, 0 ); 611 getImageUnselected()->draw( 0, 0 );
611 612
612 if( mInTop ) 613 if( mInTop )
613 { 614 {
614 drawRotatedImage( mImageSelected->getImage(), 0 ); 615 drawRotatedImage( getImageSelected()->getImage(), 0 );
615 } 616 }
616 617
617 if( mInRight ) 618 if( mInRight )
618 { 619 {
619 drawRotatedImage( mImageSelected->getImage(), 1 ); 620 drawRotatedImage( getImageSelected()->getImage(), 1 );
620 } 621 }
621 622
622 if( mInBottom ) 623 if( mInBottom )
623 { 624 {
624 drawRotatedImage( mImageSelected->getImage(), 2 ); 625 drawRotatedImage( getImageSelected()->getImage(), 2 );
625 } 626 }
626 627
627 if( mInLeft ) 628 if( mInLeft )
628 { 629 {
629 drawRotatedImage( mImageSelected->getImage(), 3 ); 630 drawRotatedImage( getImageSelected()->getImage(), 3 );
630 } 631 }
631 632
632 if (sDebugRects) 633 if (sDebugRects)
@@ -637,7 +638,7 @@ void LLJoystickCameraRotate::draw()
637} 638}
638 639
639// Draws image rotated by multiples of 90 degrees 640// Draws image rotated by multiples of 90 degrees
640void LLJoystickCameraRotate::drawRotatedImage( LLImageGL* image, S32 rotations ) 641void LLJoystickCameraRotate::drawRotatedImage( const LLImageGL* image, S32 rotations )
641{ 642{
642 S32 width = image->getWidth(); 643 S32 width = image->getWidth();
643 S32 height = image->getHeight(); 644 S32 height = image->getHeight();
@@ -652,23 +653,23 @@ void LLJoystickCameraRotate::drawRotatedImage( LLImageGL* image, S32 rotations )
652 653
653 image->bind(); 654 image->bind();
654 655
655 glColor4fv(UI_VERTEX_COLOR.mV); 656 gGL.color4fv(UI_VERTEX_COLOR.mV);
656 657
657 glBegin(GL_QUADS); 658 gGL.begin(GL_QUADS);
658 { 659 {
659 glTexCoord2fv( uv[ (rotations + 0) % 4]); 660 gGL.texCoord2fv( uv[ (rotations + 0) % 4]);
660 glVertex2i(width, height ); 661 gGL.vertex2i(width, height );
661 662
662 glTexCoord2fv( uv[ (rotations + 1) % 4]); 663 gGL.texCoord2fv( uv[ (rotations + 1) % 4]);
663 glVertex2i(0, height ); 664 gGL.vertex2i(0, height );
664 665
665 glTexCoord2fv( uv[ (rotations + 2) % 4]); 666 gGL.texCoord2fv( uv[ (rotations + 2) % 4]);
666 glVertex2i(0, 0); 667 gGL.vertex2i(0, 0);
667 668
668 glTexCoord2fv( uv[ (rotations + 3) % 4]); 669 gGL.texCoord2fv( uv[ (rotations + 3) % 4]);
669 glVertex2i(width, 0); 670 gGL.vertex2i(width, 0);
670 } 671 }
671 glEnd(); 672 gGL.end();
672} 673}
673 674
674 675
@@ -732,7 +733,7 @@ BOOL LLJoystickCameraZoom::handleMouseDown(S32 x, S32 y, MASK mask)
732 733
733 if( handled ) 734 if( handled )
734 { 735 {
735 if (mFirstMouse.mY > mRect.getHeight() / 2) 736 if (mFirstMouse.mY > getRect().getHeight() / 2)
736 { 737 {
737 mInitialQuadrant = JQ_UP; 738 mInitialQuadrant = JQ_UP;
738 } 739 }
@@ -801,7 +802,7 @@ void LLJoystickCameraZoom::draw()
801 } 802 }
802 else 803 else
803 { 804 {
804 mImageUnselected->draw( 0, 0 ); 805 getImageUnselected()->draw( 0, 0 );
805 } 806 }
806 807
807 if (sDebugRects) 808 if (sDebugRects)
@@ -813,11 +814,11 @@ void LLJoystickCameraZoom::draw()
813 814
814void LLJoystickCameraZoom::updateSlop() 815void LLJoystickCameraZoom::updateSlop()
815{ 816{
816 mVertSlopNear = mRect.getHeight() / 4; 817 mVertSlopNear = getRect().getHeight() / 4;
817 mVertSlopFar = mRect.getHeight() / 2; 818 mVertSlopFar = getRect().getHeight() / 2;
818 819
819 mHorizSlopNear = mRect.getWidth() / 4; 820 mHorizSlopNear = getRect().getWidth() / 4;
820 mHorizSlopFar = mRect.getWidth() / 2; 821 mHorizSlopFar = getRect().getWidth() / 2;
821 822
822 // Compute initial mouse offset based on initial quadrant. 823 // Compute initial mouse offset based on initial quadrant.
823 // Place the mouse evenly between the near and far zones. 824 // Place the mouse evenly between the near and far zones.