2017-05-02 15:21:32 -04:00
|
|
|
/* Based on code from "32 BASIC Programs for the Apple Computer" */
|
|
|
|
/* by Tom Rugg and Phil Feldman */
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#include "gr-sim.h"
|
|
|
|
|
|
|
|
static int r[11];
|
2017-07-10 11:24:00 -04:00
|
|
|
static int xx,yy,j,aa,b,x2,y2,n;
|
2017-05-02 15:21:32 -04:00
|
|
|
|
|
|
|
static void tooo(void) {
|
|
|
|
|
|
|
|
color_equals(r[n]);
|
2017-05-04 14:59:25 -04:00
|
|
|
basic_plot(x2,y2);
|
2017-05-02 17:11:27 -04:00
|
|
|
grsim_update();
|
2017-05-02 15:21:32 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void noo(void) {
|
2017-07-10 11:24:00 -04:00
|
|
|
//int t;
|
|
|
|
int w;
|
2017-05-02 15:21:32 -04:00
|
|
|
|
|
|
|
// 900
|
|
|
|
color_equals(r[0]);
|
2017-07-10 11:24:00 -04:00
|
|
|
basic_plot(xx,yy);
|
2017-05-02 15:21:32 -04:00
|
|
|
grsim_update();
|
|
|
|
if (j==1) return;
|
|
|
|
// 920
|
|
|
|
w=j/2;
|
2017-07-10 11:24:00 -04:00
|
|
|
//t=j-w-1;
|
|
|
|
|
2017-05-02 15:21:32 -04:00
|
|
|
// 930
|
|
|
|
for(n=1;n<=w;n++) {
|
2017-07-10 11:24:00 -04:00
|
|
|
if (xx==aa) {
|
|
|
|
y2=yy; x2=xx+n; tooo();
|
|
|
|
x2=xx-n; tooo();
|
2017-05-02 15:21:32 -04:00
|
|
|
continue;
|
|
|
|
}
|
2017-07-10 11:24:00 -04:00
|
|
|
if (yy==b) {
|
|
|
|
x2=xx; y2=yy+n; tooo();
|
|
|
|
y2=yy-n; tooo();
|
2017-05-02 15:21:32 -04:00
|
|
|
continue;
|
|
|
|
}
|
2017-07-10 11:24:00 -04:00
|
|
|
y2=yy;
|
|
|
|
if (xx<aa) {
|
|
|
|
x2=xx+n; tooo();
|
2017-05-02 15:21:32 -04:00
|
|
|
}
|
|
|
|
else {
|
2017-07-10 11:24:00 -04:00
|
|
|
x2=xx-n; tooo();
|
2017-05-02 15:21:32 -04:00
|
|
|
}
|
|
|
|
// 990
|
2017-07-10 11:24:00 -04:00
|
|
|
x2=xx;
|
|
|
|
if (yy<b) {
|
|
|
|
y2=yy+n; tooo();
|
2017-05-02 15:21:32 -04:00
|
|
|
}
|
|
|
|
else {
|
2017-07-10 11:24:00 -04:00
|
|
|
y2=yy-n; tooo();
|
2017-05-02 15:21:32 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
|
|
|
|
int ch;
|
|
|
|
int p,d,m,k,l;
|
|
|
|
|
|
|
|
grsim_init();
|
|
|
|
|
|
|
|
// 120
|
2018-01-08 14:01:19 -05:00
|
|
|
home();
|
2017-05-02 15:21:32 -04:00
|
|
|
gr();
|
|
|
|
// 125
|
|
|
|
p=19;
|
|
|
|
|
|
|
|
// 130
|
2017-07-10 11:24:00 -04:00
|
|
|
aa=p; b=p; d=-1;
|
2017-05-02 15:21:32 -04:00
|
|
|
|
|
|
|
// 135
|
|
|
|
m=15;
|
|
|
|
|
|
|
|
label150:
|
|
|
|
|
|
|
|
// 150
|
|
|
|
for(j=0;j<=10;j++) {
|
|
|
|
r[j]=rand()%m;
|
|
|
|
}
|
|
|
|
|
|
|
|
// 180
|
|
|
|
d=-d; k=1; l=p;
|
|
|
|
if (d<=0) {
|
|
|
|
k=p;l=1;
|
|
|
|
}
|
|
|
|
// 200
|
|
|
|
for(j=k;j<=l;j+=d) {
|
2017-07-10 11:24:00 -04:00
|
|
|
xx=aa+j; yy=b; noo();
|
|
|
|
xx=aa-j; noo();
|
|
|
|
xx=aa; yy=b+j; noo();
|
|
|
|
yy=b-j; noo();
|
|
|
|
xx=aa+j;yy=b+j; noo();
|
|
|
|
xx=aa-j;yy=b-j; noo();
|
|
|
|
yy=b+j; noo();
|
|
|
|
xx=aa+j; yy=b-j; noo();
|
2017-05-02 15:21:32 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
for(j=1;j<10;j++) {
|
|
|
|
ch=grsim_input();
|
|
|
|
if (ch=='q') exit(0);
|
|
|
|
if (ch==' ') {
|
|
|
|
while(grsim_input()!=' ') usleep(10000);
|
|
|
|
}
|
|
|
|
usleep(10000);
|
|
|
|
}
|
|
|
|
|
|
|
|
goto label150;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|