aboutsummaryrefslogtreecommitdiffstats
path: root/bounce.cpp
diff options
context:
space:
mode:
authorMatt Kohls <mattkohls13@gmail.com>2019-03-05 23:31:51 -0500
committerMatt Kohls <mattkohls13@gmail.com>2019-03-05 23:31:51 -0500
commitd946bdd242c89516f335d174374e7d5cb05d826b (patch)
tree62d5456b612a6dcb5f1a7e4b956fe1d83d934664 /bounce.cpp
parented43e93464b72c7e1b210ec96a21aa1d2733dee0 (diff)
downloadbounce-d946bdd242c89516f335d174374e7d5cb05d826b.tar.gz
bounce-d946bdd242c89516f335d174374e7d5cb05d826b.tar.bz2
bounce-d946bdd242c89516f335d174374e7d5cb05d826b.zip
Ball moves around window now
Diffstat (limited to 'bounce.cpp')
-rw-r--r--bounce.cpp52
1 files changed, 28 insertions, 24 deletions
diff --git a/bounce.cpp b/bounce.cpp
index 33b1a2e..08368ec 100644
--- a/bounce.cpp
+++ b/bounce.cpp
@@ -24,7 +24,7 @@
// Constants
const uint16_t SCREEN_WIDTH = 100;
const uint16_t SCREEN_HEIGHT = 100;
-const uint16_t POSX = 10;
+const uint16_t POSX = 10;
const uint16_t POSY = 10;
/**
@@ -98,29 +98,33 @@ class AmigaWindow {
}
/**
- * Draws the bouncing ball no screen
+ * Draws the bouncing ball on screen
*/
void drawBounce() {
BallPos oldPos = ballpos;
- if(ballpos.posx == 0) {
+ if(ballpos.posx == 10) {
bounceDirX = 1;
- } else if(ballpos.posx == winsize.width) {
+ } else if(ballpos.posx == winsize.width - 10) {
bounceDirX = -1;
}
- if(ballpos.posy == 0) {
+ if(ballpos.posy == 10) {
bounceDirY = 1;
- } else if(ballpos.posy == winsize.height) {
+ } else if(ballpos.posy == winsize.height - 10) {
bounceDirY = -1;
}
ballpos.posx += bounceDirX;
ballpos.posy += bounceDirY;
+ SetAPen(rp, (ULONG) 0);
+ DrawEllipse(rp, oldPos.posx + 1, oldPos.posy + 1, 5, 5);
+ DrawEllipse(rp, oldPos.posx, oldPos.posy, 5, 5);
+
SetAPen(rp, (ULONG) 1);
- WritePixel(rp, oldPos.posx, oldPos.posy);
+ DrawEllipse(rp, ballpos.posx + 1, ballpos.posy + 1, 5, 5);
- SetAPen(rp, (ULONG) 16);
- WritePixel(rp, ballpos.posx, ballpos.posy);
+ SetAPen(rp, (ULONG) 2);
+ DrawEllipse(rp, ballpos.posx, ballpos.posy, 5, 5);
}
@@ -159,27 +163,27 @@ class AmigaWindow {
* Window loop for program
*/
void runLoop() {
- ballpos = {15, 15}; // Temp for now
+ ballpos = {15, 20}; // Temp for now
bounceDirX = 1; // Temp for now
bounceDirY = -1; // Temp for now
-
-
+ drawBounce();
bool stop = false;
while(!bad && !stop) {
- Wait(1L << window->UserPort->mp_SigBit);
- msg = GT_GetIMsg(window->UserPort);
- msgClass = msg->Class;
- GT_ReplyIMsg(msg);
- if(msgClass == IDCMP_CLOSEWINDOW) {
- CloseWindow(window);
- stop = true;
- window = nullptr;
- } else if(msgClass == IDCMP_REFRESHWINDOW) {
- RefreshWindowFrame(window);
+ // If there is a message in the queue, handle it
+ if(msg = GT_GetIMsg(window->UserPort)) {
+ msgClass = msg->Class;
+ GT_ReplyIMsg(msg);
+ if(msgClass == IDCMP_CLOSEWINDOW) {
+ CloseWindow(window);
+ stop = true;
+ window = nullptr;
+ } else if(msgClass == IDCMP_REFRESHWINDOW) {
+ RefreshWindowFrame(window);
+ }
}
-
- //drawBounce();
+ drawBounce();
+ Delay(10);
}
}