From d796c9dd933ab96ec83b9a634feedd5d32e1ba3f Mon Sep 17 00:00:00 2001 From: Timothy Pearson Date: Tue, 8 Nov 2011 12:31:36 -0600 Subject: Test conversion to TQt3 from Qt3 8c6fc1f8e35fd264dd01c582ca5e7549b32ab731 --- doc/html/t11-cannon-cpp.html | 198 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 198 insertions(+) create mode 100644 doc/html/t11-cannon-cpp.html (limited to 'doc/html/t11-cannon-cpp.html') diff --git a/doc/html/t11-cannon-cpp.html b/doc/html/t11-cannon-cpp.html new file mode 100644 index 000000000..bd2f1f4ea --- /dev/null +++ b/doc/html/t11-cannon-cpp.html @@ -0,0 +1,198 @@ + + + + + +t11/cannon.cpp Example File + + + + + + + +
+ +Home + | +All Classes + | +Main Classes + | +Annotated + | +Grouped Classes + | +Functions +

t11/cannon.cpp Example File

+ + +
/****************************************************************
+**
+** Implementation CannonField class, TQt tutorial 11
+**
+****************************************************************/
+
+#include "cannon.h"
+#include <qtimer.h>
+#include <qpainter.h>
+#include <qpixmap.h>
+
+#include <math.h>
+
+
+CannonField::CannonField( TQWidget *parent, const char *name )
+        : TQWidget( parent, name )
+{
+    ang = 45;
+    f = 0;
+    timerCount = 0;
+    autoShootTimer = new TQTimer( this, "movement handler" );
+    connect( autoShootTimer, SIGNAL(timeout()),
+             this, SLOT(moveShot()) );
+    shoot_ang = 0;
+    shoot_f = 0;
+    setPalette( TQPalette( TQColor( 250, 250, 200) ) );
+}
+
+
+void CannonField::setAngle( int degrees )
+{
+    if ( degrees < 5 )
+        degrees = 5;
+    if ( degrees > 70 )
+        degrees = 70;
+    if ( ang == degrees )
+        return;
+    ang = degrees;
+    repaint( cannonRect(), FALSE );
+    emit angleChanged( ang );
+}
+
+
+void CannonField::setForce( int newton )
+{
+    if ( newton < 0 )
+        newton = 0;
+    if ( f == newton )
+        return;
+    f = newton;
+    emit forceChanged( f );
+}
+
+
+void CannonField::shoot()
+{
+    if ( autoShootTimer->isActive() )
+        return;
+    timerCount = 0;
+    shoot_ang = ang;
+    shoot_f = f;
+    autoShootTimer->start( 50 );
+}
+
+
+void CannonField::moveShot()
+{
+    TQRegion r( shotRect() );
+    timerCount++;
+
+    TQRect shotR = shotRect();
+
+    if ( shotR.x() > width() || shotR.y() > height() )
+        autoShootTimer->stop();
+    else
+        r = r.unite( TQRegion( shotR ) );
+    repaint( r );
+}
+
+
+void CannonField::paintEvent( TQPaintEvent *e )
+{
+    TQRect updateR = e->rect();
+    TQPainter p( this );
+
+    if ( updateR.intersects( cannonRect() ) )
+        paintCannon( &p );
+    if ( autoShootTimer->isActive() &&
+         updateR.intersects( shotRect() ) )
+        paintShot( &p );
+}
+
+
+void CannonField::paintShot( TQPainter *p )
+{
+    p->setBrush( black );
+    p->setPen( NoPen );
+    p->drawRect( shotRect() );
+}
+
+
+const TQRect barrelRect(33, -4, 15, 8);
+
+void CannonField::paintCannon( TQPainter *p )
+{
+    TQRect cr = cannonRect();
+    TQPixmap pix( cr.size() );
+    pix.fill( this, cr.topLeft() );
+
+    TQPainter tmp( &pix );
+    tmp.setBrush( blue );
+    tmp.setPen( NoPen );
+
+    tmp.translate( 0, pix.height() - 1 );
+    tmp.drawPie( TQRect( -35,-35, 70, 70 ), 0, 90*16 );
+    tmp.rotate( -ang );
+    tmp.drawRect( barrelRect );
+    tmp.end();
+
+    p->drawPixmap( cr.topLeft(), pix );
+}
+
+
+TQRect CannonField::cannonRect() const
+{
+    TQRect r( 0, 0, 50, 50 );
+    r.moveBottomLeft( rect().bottomLeft() );
+    return r;
+}
+
+
+TQRect CannonField::shotRect() const
+{
+    const double gravity = 4;
+
+    double time      = timerCount / 4.0;
+    double velocity  = shoot_f;
+    double radians   = shoot_ang*3.14159265/180;
+
+    double velx      = velocity*cos( radians );
+    double vely      = velocity*sin( radians );
+    double x0        = ( barrelRect.right()  + 5 )*cos(radians);
+    double y0        = ( barrelRect.right()  + 5 )*sin(radians);
+    double x         = x0 + velx*time;
+    double y         = y0 + vely*time - 0.5*gravity*time*time;
+
+    TQRect r = TQRect( 0, 0, 6, 6 );
+    r.moveCenter( TQPoint( qRound(x), height() - 1 - qRound(y) ) );
+    return r;
+}
+
+
+TQSizePolicy CannonField::sizePolicy() const
+{
+    return TQSizePolicy( TQSizePolicy::Expanding, TQSizePolicy::Expanding );
+}
+
+


+ +
Copyright © 2007 +TrolltechTrademarks +
TQt 3.3.8
+
+ -- cgit v1.2.1