1763 lines
43 KiB
C
1763 lines
43 KiB
C
|
/*-
|
||
|
* Copyright (c) 1991, 1993
|
||
|
* The Regents of the University of California. All rights reserved.
|
||
|
*
|
||
|
* Redistribution and use in source and binary forms, with or without
|
||
|
* modification, are permitted provided that the following conditions
|
||
|
* are met:
|
||
|
* 1. Redistributions of source code must retain the above copyright
|
||
|
* notice, this list of conditions and the following disclaimer.
|
||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||
|
* notice, this list of conditions and the following disclaimer in the
|
||
|
* documentation and/or other materials provided with the distribution.
|
||
|
* 3. All advertising materials mentioning features or use of this software
|
||
|
* must display the following acknowledgement:
|
||
|
* This product includes software developed by the University of
|
||
|
* California, Berkeley and its contributors.
|
||
|
* 4. Neither the name of the University nor the names of its contributors
|
||
|
* may be used to endorse or promote products derived from this software
|
||
|
* without specific prior written permission.
|
||
|
*
|
||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||
|
* SUCH DAMAGE.
|
||
|
*/
|
||
|
|
||
|
#ifndef lint
|
||
|
static char copyright[] =
|
||
|
"@(#) Copyright (c) 1991, 1993\n\
|
||
|
The Regents of the University of California. All rights reserved.\n";
|
||
|
#endif /* not lint */
|
||
|
|
||
|
#ifndef lint
|
||
|
static char sccsid[] = "@(#)xneko.c 8.1 (Berkeley) 5/31/93";
|
||
|
#endif /* not lint */
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* xneko - X11 G-
|
||
|
*
|
||
|
* Original Writer: Masayuki Koba
|
||
|
* Programmed by Masayuki Koba, 1990
|
||
|
*
|
||
|
*--------------------------------------------------------------
|
||
|
*
|
||
|
*!!Introduction:
|
||
|
*
|
||
|
*!!!!K\@(#)xneko.c 8.1m%0%i%`$O Macintosh $N5/31/939%/%"%/%;%5%j!< "neko" $N
|
||
|
*!!F0:n$r X11 $G%^%M$?$b$N$G$9!#
|
||
|
*
|
||
|
*!!!!Macintosh "neko" $N=(0o$J5/31/936%$%s$K7I0U$rI=$7$D$D!"$3$N
|
||
|
*!!@(#)xneko.c 8.1m%0%i%`$r3'$5$s$KJ{$2$^$9!#
|
||
|
*
|
||
|
*--------------------------------------------------------------
|
||
|
*
|
||
|
*!!Special Thanks to
|
||
|
*
|
||
|
* toshi-w !D!!Macintosh neko $N>R2p<T
|
||
|
* shio-m !D!!!VX11 $N neko $,M_$7$$!*!W$H%?%@$r$3$M$??M
|
||
|
* disco !D!!X11 SCCS/s.xneko.c/%K%+%k!&%"8.1P%$%6!<
|
||
|
*
|
||
|
* HOMY !D!!/usr/src/games/xneko/SCCS/s.xneko.c0;XE&<T
|
||
|
* BNS !D!!J#?t@(#)xneko.c 8.1l!<%sBP1~May 31, 1993C%ADs6!<T
|
||
|
*
|
||
|
* "xneko" Presented by Masayuki Koba (masa-k).
|
||
|
*
|
||
|
*--------------------------------------------------------------
|
||
|
*
|
||
|
*!!Manifest:
|
||
|
*
|
||
|
*!!!!K\@(#)xneko.c 8.1m%0%i%`$O Public Domain Software $G$9!#E>:\!&2~NI$O
|
||
|
*!!<+M3$K9T$C$F2<$5$$!#
|
||
|
*
|
||
|
*!!!!$J$*!"86:n<T$O!"K\@(#)xneko.c 8.1m%0%i%`$r;HMQ$9$k$3$H$K$h$C$F@8$8$?
|
||
|
*!!>c32$dITMx1W$K$D$$$F$$$C$5$$@UG$$r;}$A$^$;$s!#
|
||
|
*
|
||
|
*--------------------------------------------------------------
|
||
|
*
|
||
|
*!!Bugs:
|
||
|
*
|
||
|
*!!!!!J#1!KX11 $N .Xdefaults $N@_Dj$r$^$k$C$-$jL5;k$7$F$$$^$9!#
|
||
|
*
|
||
|
*!!!!!J#2!KG-$NF0:n$,;~4V$HF14|$7$F$$$k$?$a!"%^%&%9$N0\F0>pJs
|
||
|
*!!!!!!!!$r%]!<%j%s%0$7$F$$$^$9!#=>$C$F!"%^%&%9$,A4$/F0:n$7$F
|
||
|
*!!!!!!!!$$$J$$;~$OL5BL$J%^%&%9:BI8FI$_<h$j$r9T$C$F$7$^$$$^$9!#
|
||
|
*
|
||
|
*!!!!!J#3!K%&%#%s8.1&$,%"%$%3%s2=$5$l$F$b!"$7$i$s$W$j$GIA2h$7
|
||
|
*!!!!!!!!$D$E$1$^$9!#$3$NItJ,$O!"8=:_$N%&%#%s8.1&$N>uBV$r@(#) xneko.c 8.1@(#)'
|
||
|
*!!!!!!!!70/$7$F!"%"%$%3%s2=$5$l$F$$$k;~$O40A4$K%$s%HBT$A
|
||
|
*!!!!!!!!$K$J$k$h$&$K=q$-JQ$($J$1$l$P$J$j$^$;$s!# ($=$s$J$3$H!"
|
||
|
*!!!!!!!!$G$-$k$N$+$J$!!#X10 $G$O$G$-$^$7$?$,!#)
|
||
|
*
|
||
|
*!!!!!J#4!K%j%5%$%:8e$N%&%#%s8.1&$,6KC<$K>.$5$/$J$C$?;~$NF0:n
|
||
|
*!!!!!!!!$OJ]>Z$G$-$^$;$s!#
|
||
|
*
|
||
|
*!!!!!J#5!KK\Mh$J$i$P3NJ]$7$?%&%#%s8.1&$d Pixmap $O@(#)xneko.c 8.1m%0%i%`
|
||
|
*!!!!!!!!=*N;;~$K2rJ|$9$kI,MW$,$"$j$^$9$,!"K\@(#)xneko.c 8.1m%0%i%`$O$=$N
|
||
|
*!!!!!!!!$X$s$r%5%\$C$F$*$j!"Hs>o$K$*9T57$,0-$/$J$C$F$$$^$9!#
|
||
|
*!!!!!!!!IaDL$O exit() ;~$K%7%9SCCS/s.xneko.c`$,M>J,$J%j%=!<%9$r2rJ|$7$F
|
||
|
*!!!!!!!!$/$l$^$9$,!"#O#S$K/usr/src/games/xneko/SCCS/s.xneko.c0$,$"$k>l9g$O xneko $r2?EY$b5/
|
||
|
*!!!!!!!!F0$9$k$H!"$=$N$&$A%9%o82WNN0h$,ITB-$7$F$7$^$&$3$H$K
|
||
|
*!!!!!!!!$J$k$+$b$7$l$^$;$s!#
|
||
|
*
|
||
|
*!!!!!J#6!K;~4V$KF14|$7$FI,$:IA2h=hM}$r<B9T$9$k$?$a!"0BDj>uBV
|
||
|
*!!!!!!!!$G$b Idle 90 !A 95% $H$J$j!"%7%9SCCS/s.xneko.c`#C#P#U$r 5 !A 10%
|
||
|
*!!!!!!!!Dx>CHq$7$^$9!#!Jxtachos $GD4$Y$^$7$?!#!K
|
||
|
*
|
||
|
*--------------------------------------------------------------
|
||
|
*
|
||
|
*!!System (Machine):
|
||
|
*
|
||
|
*!!!!K\@(#)xneko.c 8.1m%0%i%`$NF0:n$r3NG'$7$?%7%9SCCS/s.xneko.c`9=@.$O0J2<$NDL$j!#
|
||
|
*
|
||
|
* !&NWS-1750!"NWS-1720 (NEWS)!"NWP-512D
|
||
|
* !!NEWS-OS 3.2a (UNIX 4.3BSD)!"X11 Release 2
|
||
|
*
|
||
|
* !&NWS-1750!"NWS-1720 (NEWS)!"NWP-512D
|
||
|
* !!NEWS-OS 3.3 (UNIX 4.3BSD)!"X11 Release 3
|
||
|
*
|
||
|
* !&Sun 3!"X11 Release 4
|
||
|
*
|
||
|
* !&LUNA!"X11 Release 3
|
||
|
*
|
||
|
* !&DECstation 3100!"ULTRIX!"X11
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
|
||
|
#include <X11/Xlib.h>
|
||
|
#include <X11/Xutil.h>
|
||
|
#include <X11/keysym.h>
|
||
|
|
||
|
#include <stdio.h>
|
||
|
|
||
|
#include <signal.h>
|
||
|
#include <math.h>
|
||
|
#include <sys/time.h>
|
||
|
|
||
|
|
||
|
#ifndef lint
|
||
|
static char
|
||
|
rcsid[] = "$Header: /afs/athena.mit.edu/user/j/jik/sipbsrc/src/xneko/RCS/xneko.c,v 1.2 90/09/01 23:40:01 jik Exp $";
|
||
|
static char WriterMessage[] = "xneko: Programmed by Masayuki Koba, 1990";
|
||
|
#endif
|
||
|
|
||
|
|
||
|
/*
|
||
|
* X11 G- 0C5/31/93^129W18:45:36!%$%k0lMw!'
|
||
|
*
|
||
|
* "icon.xbm" !D!!%"%$%3%s
|
||
|
* "cursor.xbm" !D!!%+!<%=%k
|
||
|
* "cursor_mask.xbm" !D!!%+!<%=%k!J%^%9%/!K
|
||
|
*
|
||
|
* "space.xbm" !D!!%9%Z!<%9
|
||
|
*
|
||
|
* "mati2.xbm" !D!!BT$A#2
|
||
|
* "jare2.xbm" !D!!$8$c$l#2
|
||
|
* "kaki1.xbm" !D!!A_$-#1
|
||
|
* "kaki2.xbm" !D!!A_$-#2
|
||
|
* "mati3.xbm" !D!!BT$A#3!J$"$/$S!K
|
||
|
* "sleep1.xbm" !D!!?2$k#1
|
||
|
* "sleep2.xbm" !D!!?2$k#2
|
||
|
*
|
||
|
* "awake.xbm" !D!!L\3P$a
|
||
|
*
|
||
|
* "up1.xbm" !D!!>e#1
|
||
|
* "up2.xbm" !D!!>e#2
|
||
|
* "down1.xbm" !D!!2<#1
|
||
|
* "down2.xbm" !D!!2<#2
|
||
|
* "left1.xbm" !D!!:8#1
|
||
|
* "left2.xbm" !D!!:8#2
|
||
|
* "right1.xbm" !D!!1
|
||
|
* "right2.xbm" !D!!1
|
||
|
* "upleft1.xbm" !D!!:8>e#1
|
||
|
* "upleft2.xbm" !D!!:8>e#2
|
||
|
* "upright1.xbm" !D!!1&>e#1
|
||
|
* "upright2.xbm" !D!!1&>e#2
|
||
|
* "dwleft1.xbm" !D!!:82<#1
|
||
|
* "dwleft2.xbm" !D!!:82<#2
|
||
|
* "dwright1.xbm" !D!!1&2<#1
|
||
|
* "dwright2.xbm" !D!!1&2<#2
|
||
|
*
|
||
|
* "utogi1.xbm" !D!!>eKa$.#1
|
||
|
* "utogi2.xbm" !D!!>eKa$.#2
|
||
|
* "dtogi1.xbm" !D!!2<Ka$.#1
|
||
|
* "dtogi2.xbm" !D!!2<Ka$.#2
|
||
|
* "ltogi1.xbm" !D!!:8Ka$.#1
|
||
|
* "ltogi2.xbm" !D!!:8Ka$.#2
|
||
|
* "rtogi1.xbm" !D!!1&Ka$.#1
|
||
|
* "rtogi2.xbm" !D!!1&Ka$.#2
|
||
|
*
|
||
|
* !!$3$l$i$N18:45:36!%$%k$O bitmap %3%^%s%I$GJT=82DG=$G$9!#
|
||
|
*
|
||
|
* (bitmap size "* 32x32 ... Macintosh ICON resource size.)
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
|
||
|
#include "bitmaps/icon.xbm"
|
||
|
#include "bitmaps/cursor.xbm"
|
||
|
#include "bitmaps/cursor_mask.xbm"
|
||
|
|
||
|
#include "bitmaps/space.xbm"
|
||
|
|
||
|
#include "bitmaps/mati2.xbm"
|
||
|
#include "bitmaps/jare2.xbm"
|
||
|
#include "bitmaps/kaki1.xbm"
|
||
|
#include "bitmaps/kaki2.xbm"
|
||
|
#include "bitmaps/mati3.xbm"
|
||
|
#include "bitmaps/sleep1.xbm"
|
||
|
#include "bitmaps/sleep2.xbm"
|
||
|
|
||
|
#include "bitmaps/awake.xbm"
|
||
|
|
||
|
#include "bitmaps/up1.xbm"
|
||
|
#include "bitmaps/up2.xbm"
|
||
|
#include "bitmaps/down1.xbm"
|
||
|
#include "bitmaps/down2.xbm"
|
||
|
#include "bitmaps/left1.xbm"
|
||
|
#include "bitmaps/left2.xbm"
|
||
|
#include "bitmaps/right1.xbm"
|
||
|
#include "bitmaps/right2.xbm"
|
||
|
#include "bitmaps/upright1.xbm"
|
||
|
#include "bitmaps/upright2.xbm"
|
||
|
#include "bitmaps/upleft1.xbm"
|
||
|
#include "bitmaps/upleft2.xbm"
|
||
|
#include "bitmaps/dwleft1.xbm"
|
||
|
#include "bitmaps/dwleft2.xbm"
|
||
|
#include "bitmaps/dwright1.xbm"
|
||
|
#include "bitmaps/dwright2.xbm"
|
||
|
|
||
|
#include "bitmaps/utogi1.xbm"
|
||
|
#include "bitmaps/utogi2.xbm"
|
||
|
#include "bitmaps/dtogi1.xbm"
|
||
|
#include "bitmaps/dtogi2.xbm"
|
||
|
#include "bitmaps/ltogi1.xbm"
|
||
|
#include "bitmaps/ltogi2.xbm"
|
||
|
#include "bitmaps/rtogi1.xbm"
|
||
|
#include "bitmaps/rtogi2.xbm"
|
||
|
|
||
|
|
||
|
/*
|
||
|
* Dj?tDj5A
|
||
|
*/
|
||
|
|
||
|
#define BITMAP_WIDTH 32 /* #1%-%c%i%/%?$NI} (18:45:53/%;%k) */
|
||
|
#define BITMAP_HEIGHT 32 /* #1%-%c%i%/%?$N9b$5 (18:45:53/%;%k) */
|
||
|
|
||
|
#define WINDOW_WIDTH 320 /* %&%#%s8.1&$NI} (18:45:53/%;%k) */
|
||
|
#define WINDOW_HEIGHT 256 /* %&%#%s8.1&$N9b$5 (18:45:53/%;%k) */
|
||
|
|
||
|
#define DEFAULT_BORDER 2 /* %\!<%@!<%5%$%: */
|
||
|
|
||
|
#define DEFAULT_WIN_X 1 /* %&%#%s8.1&@8@.#X:BI8 */
|
||
|
#define DEFAULT_WIN_Y 1 /* %&%#%s8.1&@8@.#Y:BI8 */
|
||
|
|
||
|
#define AVAIL_KEYBUF 255
|
||
|
|
||
|
#define EVENT_MASK1 ( KeyPressMask | StructureNotifyMask )
|
||
|
|
||
|
#define EVENT_MASK2 ( KeyPressMask | \
|
||
|
ExposureMask | \
|
||
|
StructureNotifyMask )
|
||
|
|
||
|
#define MAX_TICK 9999 /* Odd Only! */
|
||
|
|
||
|
#define INTERVAL 125000L /* %$%s%?!</usr/src/games/xneko/SCCS/s.xneko.ck%?%$%` */
|
||
|
|
||
|
#define NEKO_SPEED 16
|
||
|
|
||
|
#define IDLE_SPACE 6
|
||
|
|
||
|
#define NORMAL_STATE 1
|
||
|
#define DEBUG_LIST 2
|
||
|
#define DEBUG_MOVE 3
|
||
|
|
||
|
/* G-$N>uBVDj?t */
|
||
|
|
||
|
#define NEKO_STOP 0 /* N)$A;_$^$C$? */
|
||
|
#define NEKO_JARE 1 /* 4i$r@v$C$F$$$k */
|
||
|
#define NEKO_KAKI 2 /* F,$rA_$$$F$$$k */
|
||
|
#define NEKO_AKUBI 3 /* $"$/$S$r$7$F$$$k */
|
||
|
#define NEKO_SLEEP 4 /* ?2$F$7$^$C$? */
|
||
|
#define NEKO_AWAKE 5 /* L\$,3P$a$? */
|
||
|
#define NEKO_U_MOVE 6 /* >e$K0\F0Cf */
|
||
|
#define NEKO_D_MOVE 7 /* 2<$K0\F0Cf */
|
||
|
#define NEKO_L_MOVE 8 /* :8$K0\F0Cf */
|
||
|
#define NEKO_R_MOVE 9 /* 1&$K0\F0Cf */
|
||
|
#define NEKO_UL_MOVE 10 /* :8>e$K0\F0Cf */
|
||
|
#define NEKO_UR_MOVE 11 /* 1&>e$K0\F0Cf */
|
||
|
#define NEKO_DL_MOVE 12 /* :82<$K0\F0Cf */
|
||
|
#define NEKO_DR_MOVE 13 /* 1&2<$K0\F0Cf */
|
||
|
#define NEKO_U_TOGI 14 /* >e$NJI$r0z$CA_$$$F$$$k */
|
||
|
#define NEKO_D_TOGI 15 /* 2<$NJI$r0z$CA_$$$F$$$k */
|
||
|
#define NEKO_L_TOGI 16 /* :8$NJI$r0z$CA_$$$F$$$k */
|
||
|
#define NEKO_R_TOGI 17 /* 1&$NJI$r0z$CA_$$$F$$$k */
|
||
|
|
||
|
/* G-$N%"%K%a!<%7%g%s7+$jJV$72s?t */
|
||
|
|
||
|
#define NEKO_STOP_TIME 4
|
||
|
#define NEKO_JARE_TIME 10
|
||
|
#define NEKO_KAKI_TIME 4
|
||
|
#define NEKO_AKUBI_TIME 3
|
||
|
#define NEKO_AWAKE_TIME 3
|
||
|
#define NEKO_TOGI_TIME 10
|
||
|
|
||
|
#define PI_PER8 ((double)3.1415926535/(double)8)
|
||
|
|
||
|
#define DIRNAMELEN 255
|
||
|
|
||
|
|
||
|
/*
|
||
|
* %0%m!</usr/src/games/xneko/SCCS/s.xneko.ckJQ?t
|
||
|
*/
|
||
|
|
||
|
static char *ProgramName; /* %3%^%s%IL>>N */
|
||
|
|
||
|
Display *theDisplay;
|
||
|
int theScreen;
|
||
|
unsigned int theDepth;
|
||
|
unsigned long theBlackPixel;
|
||
|
unsigned long theWhitePixel;
|
||
|
Window theWindow;
|
||
|
Cursor theCursor;
|
||
|
|
||
|
static unsigned int WindowWidth;
|
||
|
static unsigned int WindowHeight;
|
||
|
|
||
|
static int WindowPointX;
|
||
|
static int WindowPointY;
|
||
|
|
||
|
static unsigned int BorderWidth = DEFAULT_BORDER;
|
||
|
|
||
|
long IntervalTime = INTERVAL;
|
||
|
|
||
|
int EventState; /* %$s%H=hM}MQ >uBVJQ?t */
|
||
|
|
||
|
int NekoTickCount; /* G-F0:n%+%&%s%? */
|
||
|
int NekoStateCount; /* G-F10l>uBV%+%&%s%? */
|
||
|
int NekoState; /* G-$N>uBV */
|
||
|
|
||
|
int MouseX; /* %^%&%9#X:BI8 */
|
||
|
int MouseY; /* %^%&%9#Y:BI8 */
|
||
|
|
||
|
int PrevMouseX = 0; /* D>A0$N%^%&%9#X:BI8 */
|
||
|
int PrevMouseY = 0; /* D>A0$N%^%&%9#Y:BI8 */
|
||
|
|
||
|
int NekoX; /* G-#X:BI8 */
|
||
|
int NekoY; /* G-#Y:BI8 */
|
||
|
|
||
|
int NekoMoveDx; /* G-0\F05wN%#X */
|
||
|
int NekoMoveDy; /* G-0\F05wN%#Y */
|
||
|
|
||
|
int NekoLastX; /* G-:G=*IA2h#X:BI8 */
|
||
|
int NekoLastY; /* G-:G=*IA2h#Y:BI8 */
|
||
|
GC NekoLastGC; /* G-:G=*IA2h GC */
|
||
|
|
||
|
double NekoSpeed = (double)NEKO_SPEED;
|
||
|
|
||
|
double SinPiPer8Times3; /* sin( #3&P!?#8 ) */
|
||
|
double SinPiPer8; /* sin( &P!?#8 ) */
|
||
|
|
||
|
Pixmap SpaceXbm;
|
||
|
|
||
|
Pixmap Mati2Xbm;
|
||
|
Pixmap Jare2Xbm;
|
||
|
Pixmap Kaki1Xbm;
|
||
|
Pixmap Kaki2Xbm;
|
||
|
Pixmap Mati3Xbm;
|
||
|
Pixmap Sleep1Xbm;
|
||
|
Pixmap Sleep2Xbm;
|
||
|
|
||
|
Pixmap AwakeXbm;
|
||
|
|
||
|
Pixmap Up1Xbm;
|
||
|
Pixmap Up2Xbm;
|
||
|
Pixmap Down1Xbm;
|
||
|
Pixmap Down2Xbm;
|
||
|
Pixmap Left1Xbm;
|
||
|
Pixmap Left2Xbm;
|
||
|
Pixmap Right1Xbm;
|
||
|
Pixmap Right2Xbm;
|
||
|
Pixmap UpLeft1Xbm;
|
||
|
Pixmap UpLeft2Xbm;
|
||
|
Pixmap UpRight1Xbm;
|
||
|
Pixmap UpRight2Xbm;
|
||
|
Pixmap DownLeft1Xbm;
|
||
|
Pixmap DownLeft2Xbm;
|
||
|
Pixmap DownRight1Xbm;
|
||
|
Pixmap DownRight2Xbm;
|
||
|
|
||
|
Pixmap UpTogi1Xbm;
|
||
|
Pixmap UpTogi2Xbm;
|
||
|
Pixmap DownTogi1Xbm;
|
||
|
Pixmap DownTogi2Xbm;
|
||
|
Pixmap LeftTogi1Xbm;
|
||
|
Pixmap LeftTogi2Xbm;
|
||
|
Pixmap RightTogi1Xbm;
|
||
|
Pixmap RightTogi2Xbm;
|
||
|
|
||
|
GC SpaceGC;
|
||
|
|
||
|
GC Mati2GC;
|
||
|
GC Jare2GC;
|
||
|
GC Kaki1GC;
|
||
|
GC Kaki2GC;
|
||
|
GC Mati3GC;
|
||
|
GC Sleep1GC;
|
||
|
GC Sleep2GC;
|
||
|
|
||
|
GC AwakeGC;
|
||
|
|
||
|
GC Up1GC;
|
||
|
GC Up2GC;
|
||
|
GC Down1GC;
|
||
|
GC Down2GC;
|
||
|
GC Left1GC;
|
||
|
GC Left2GC;
|
||
|
GC Right1GC;
|
||
|
GC Right2GC;
|
||
|
GC UpLeft1GC;
|
||
|
GC UpLeft2GC;
|
||
|
GC UpRight1GC;
|
||
|
GC UpRight2GC;
|
||
|
GC DownLeft1GC;
|
||
|
GC DownLeft2GC;
|
||
|
GC DownRight1GC;
|
||
|
GC DownRight2GC;
|
||
|
|
||
|
GC UpTogi1GC;
|
||
|
GC UpTogi2GC;
|
||
|
GC DownTogi1GC;
|
||
|
GC DownTogi2GC;
|
||
|
GC LeftTogi1GC;
|
||
|
GC LeftTogi2GC;
|
||
|
GC RightTogi1GC;
|
||
|
GC RightTogi2GC;
|
||
|
|
||
|
typedef struct {
|
||
|
GC *GCCreatePtr;
|
||
|
Pixmap *BitmapCreatePtr;
|
||
|
char *PixelPattern;
|
||
|
unsigned int PixelWidth;
|
||
|
unsigned int PixelHeight;
|
||
|
} BitmapGCData;
|
||
|
|
||
|
BitmapGCData BitmapGCDataTable[] =
|
||
|
{
|
||
|
{ &SpaceGC, &SpaceXbm, space_bits, space_width, space_height },
|
||
|
{ &Mati2GC, &Mati2Xbm, mati2_bits, mati2_width, mati2_height },
|
||
|
{ &Jare2GC, &Jare2Xbm, jare2_bits, jare2_width, jare2_height },
|
||
|
{ &Kaki1GC, &Kaki1Xbm, kaki1_bits, kaki1_width, kaki1_height },
|
||
|
{ &Kaki2GC, &Kaki2Xbm, kaki2_bits, kaki2_width, kaki2_height },
|
||
|
{ &Mati3GC, &Mati3Xbm, mati3_bits, mati3_width, mati3_height },
|
||
|
{ &Sleep1GC, &Sleep1Xbm, sleep1_bits, sleep1_width, sleep1_height },
|
||
|
{ &Sleep2GC, &Sleep2Xbm, sleep2_bits, sleep2_width, sleep2_height },
|
||
|
{ &AwakeGC, &AwakeXbm, awake_bits, awake_width, awake_height },
|
||
|
{ &Up1GC, &Up1Xbm, up1_bits, up1_width, up1_height },
|
||
|
{ &Up2GC, &Up2Xbm, up2_bits, up2_width, up2_height },
|
||
|
{ &Down1GC, &Down1Xbm, down1_bits, down1_width, down1_height },
|
||
|
{ &Down2GC, &Down2Xbm, down2_bits, down2_width, down2_height },
|
||
|
{ &Left1GC, &Left1Xbm, left1_bits, left1_width, left1_height },
|
||
|
{ &Left2GC, &Left2Xbm, left2_bits, left2_width, left2_height },
|
||
|
{ &Right1GC, &Right1Xbm, right1_bits, right1_width, right1_height },
|
||
|
{ &Right2GC, &Right2Xbm, right2_bits, right2_width, right2_height },
|
||
|
{ &UpLeft1GC, &UpLeft1Xbm, upleft1_bits, upleft1_width, upleft1_height },
|
||
|
{ &UpLeft2GC, &UpLeft2Xbm, upleft2_bits, upleft2_width, upleft2_height },
|
||
|
{ &UpRight1GC,
|
||
|
&UpRight1Xbm, upright1_bits, upright1_width, upright1_height },
|
||
|
{ &UpRight2GC,
|
||
|
&UpRight2Xbm, upright2_bits, upright2_width, upright2_height },
|
||
|
{ &DownLeft1GC,
|
||
|
&DownLeft1Xbm, dwleft1_bits, dwleft1_width, dwleft1_height },
|
||
|
{ &DownLeft2GC,
|
||
|
&DownLeft2Xbm, dwleft2_bits, dwleft2_width, dwleft2_height },
|
||
|
{ &DownRight1GC,
|
||
|
&DownRight1Xbm, dwright1_bits, dwright1_width, dwright1_height },
|
||
|
{ &DownRight2GC,
|
||
|
&DownRight2Xbm, dwright2_bits, dwright2_width, dwright2_height },
|
||
|
{ &UpTogi1GC, &UpTogi1Xbm, utogi1_bits, utogi1_width, utogi1_height },
|
||
|
{ &UpTogi2GC, &UpTogi2Xbm, utogi2_bits, utogi2_width, utogi2_height },
|
||
|
{ &DownTogi1GC, &DownTogi1Xbm, dtogi1_bits, dtogi1_width, dtogi1_height },
|
||
|
{ &DownTogi2GC, &DownTogi2Xbm, dtogi2_bits, dtogi2_width, dtogi2_height },
|
||
|
{ &LeftTogi1GC, &LeftTogi1Xbm, ltogi1_bits, ltogi1_width, ltogi1_height },
|
||
|
{ &LeftTogi2GC, &LeftTogi2Xbm, ltogi2_bits, ltogi2_width, ltogi2_height },
|
||
|
{ &RightTogi1GC,
|
||
|
&RightTogi1Xbm, rtogi1_bits, rtogi1_width, rtogi1_height },
|
||
|
{ &RightTogi2GC,
|
||
|
&RightTogi2Xbm, rtogi2_bits, rtogi2_width, rtogi2_height },
|
||
|
{ NULL, NULL, NULL, NULL, NULL }
|
||
|
};
|
||
|
|
||
|
typedef struct {
|
||
|
GC *TickEvenGCPtr;
|
||
|
GC *TickOddGCPtr;
|
||
|
} Animation;
|
||
|
|
||
|
Animation AnimationPattern[] =
|
||
|
{
|
||
|
{ &Mati2GC, &Mati2GC }, /* NekoState == NEKO_STOP */
|
||
|
{ &Jare2GC, &Mati2GC }, /* NekoState == NEKO_JARE */
|
||
|
{ &Kaki1GC, &Kaki2GC }, /* NekoState == NEKO_KAKI */
|
||
|
{ &Mati3GC, &Mati3GC }, /* NekoState == NEKO_AKUBI */
|
||
|
{ &Sleep1GC, &Sleep2GC }, /* NekoState == NEKO_SLEEP */
|
||
|
{ &AwakeGC, &AwakeGC }, /* NekoState == NEKO_AWAKE */
|
||
|
{ &Up1GC, &Up2GC } , /* NekoState == NEKO_U_MOVE */
|
||
|
{ &Down1GC, &Down2GC }, /* NekoState == NEKO_D_MOVE */
|
||
|
{ &Left1GC, &Left2GC }, /* NekoState == NEKO_L_MOVE */
|
||
|
{ &Right1GC, &Right2GC }, /* NekoState == NEKO_R_MOVE */
|
||
|
{ &UpLeft1GC, &UpLeft2GC }, /* NekoState == NEKO_UL_MOVE */
|
||
|
{ &UpRight1GC, &UpRight2GC }, /* NekoState == NEKO_UR_MOVE */
|
||
|
{ &DownLeft1GC, &DownLeft2GC }, /* NekoState == NEKO_DL_MOVE */
|
||
|
{ &DownRight1GC, &DownRight2GC }, /* NekoState == NEKO_DR_MOVE */
|
||
|
{ &UpTogi1GC, &UpTogi2GC }, /* NekoState == NEKO_U_TOGI */
|
||
|
{ &DownTogi1GC, &DownTogi2GC }, /* NekoState == NEKO_D_TOGI */
|
||
|
{ &LeftTogi1GC, &LeftTogi2GC }, /* NekoState == NEKO_L_TOGI */
|
||
|
{ &RightTogi1GC, &RightTogi2GC }, /* NekoState == NEKO_R_TOGI */
|
||
|
};
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* 0C5/31/93^504W%G!<%?!&GC =i4|2=
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
InitBitmapAndGCs()
|
||
|
{
|
||
|
BitmapGCData *BitmapGCDataTablePtr;
|
||
|
XGCValues theGCValues;
|
||
|
|
||
|
theGCValues.function = GXcopy;
|
||
|
theGCValues.foreground = BlackPixel( theDisplay, theScreen );
|
||
|
theGCValues.background = WhitePixel( theDisplay, theScreen );
|
||
|
theGCValues.fill_style = FillTiled;
|
||
|
|
||
|
for ( BitmapGCDataTablePtr = BitmapGCDataTable;
|
||
|
BitmapGCDataTablePtr->GCCreatePtr != NULL;
|
||
|
BitmapGCDataTablePtr++ ) {
|
||
|
|
||
|
*(BitmapGCDataTablePtr->BitmapCreatePtr)
|
||
|
= XCreatePixmapFromBitmapData(
|
||
|
theDisplay,
|
||
|
RootWindow( theDisplay, theScreen ),
|
||
|
BitmapGCDataTablePtr->PixelPattern,
|
||
|
BitmapGCDataTablePtr->PixelWidth,
|
||
|
BitmapGCDataTablePtr->PixelHeight,
|
||
|
BlackPixel( theDisplay, theScreen ),
|
||
|
WhitePixel( theDisplay, theScreen ),
|
||
|
DefaultDepth( theDisplay, theScreen ) );
|
||
|
|
||
|
theGCValues.tile = *(BitmapGCDataTablePtr->BitmapCreatePtr);
|
||
|
|
||
|
*(BitmapGCDataTablePtr->GCCreatePtr)
|
||
|
= XCreateGC( theDisplay, theWindow,
|
||
|
GCFunction | GCForeground | GCBackground |
|
||
|
GCTile | GCFillStyle,
|
||
|
&theGCValues );
|
||
|
}
|
||
|
|
||
|
XFlush( theDisplay );
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* %9%/%j!<%s4D6-=i4|2=
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
InitScreen( DisplayName, theGeometry, TitleName, iconicState )
|
||
|
char *DisplayName;
|
||
|
char *theGeometry;
|
||
|
char *TitleName;
|
||
|
Bool iconicState;
|
||
|
{
|
||
|
int GeometryStatus;
|
||
|
XSetWindowAttributes theWindowAttributes;
|
||
|
XSizeHints theSizeHints;
|
||
|
unsigned long theWindowMask;
|
||
|
Pixmap theIconPixmap;
|
||
|
Pixmap theCursorSource;
|
||
|
Pixmap theCursorMask;
|
||
|
XWMHints theWMHints;
|
||
|
Window theRoot;
|
||
|
Colormap theColormap;
|
||
|
XColor theWhiteColor, theBlackColor, theExactColor;
|
||
|
|
||
|
if ( ( theDisplay = XOpenDisplay( DisplayName ) ) == NULL ) {
|
||
|
fprintf( stderr, "%s: Can't open display", ProgramName );
|
||
|
if ( DisplayName != NULL ) {
|
||
|
fprintf( stderr, " %s.\n", DisplayName );
|
||
|
} else {
|
||
|
fprintf( stderr, ".\n" );
|
||
|
}
|
||
|
exit( 1 );
|
||
|
}
|
||
|
|
||
|
theScreen = DefaultScreen( theDisplay );
|
||
|
theDepth = DefaultDepth( theDisplay, theScreen );
|
||
|
|
||
|
theBlackPixel = BlackPixel( theDisplay, theScreen );
|
||
|
theWhitePixel = WhitePixel( theDisplay, theScreen );
|
||
|
|
||
|
GeometryStatus = XParseGeometry( theGeometry,
|
||
|
&WindowPointX, &WindowPointY,
|
||
|
&WindowWidth, &WindowHeight );
|
||
|
|
||
|
if ( !( GeometryStatus & XValue ) ) {
|
||
|
WindowPointX = DEFAULT_WIN_X;
|
||
|
}
|
||
|
if ( !( GeometryStatus & YValue ) ) {
|
||
|
WindowPointY = DEFAULT_WIN_Y;
|
||
|
}
|
||
|
if ( !( GeometryStatus & WidthValue ) ) {
|
||
|
WindowWidth = WINDOW_WIDTH;
|
||
|
}
|
||
|
if ( !( GeometryStatus & HeightValue ) ) {
|
||
|
WindowHeight = WINDOW_HEIGHT;
|
||
|
}
|
||
|
|
||
|
theCursorSource
|
||
|
= XCreateBitmapFromData( theDisplay,
|
||
|
RootWindow( theDisplay, theScreen ),
|
||
|
cursor_bits,
|
||
|
cursor_width,
|
||
|
cursor_height );
|
||
|
|
||
|
theCursorMask
|
||
|
= XCreateBitmapFromData( theDisplay,
|
||
|
RootWindow( theDisplay, theScreen ),
|
||
|
cursor_mask_bits,
|
||
|
cursor_mask_width,
|
||
|
cursor_mask_height );
|
||
|
|
||
|
theColormap = DefaultColormap( theDisplay, theScreen );
|
||
|
|
||
|
if ( !XAllocNamedColor( theDisplay, theColormap,
|
||
|
"white", &theWhiteColor, &theExactColor ) ) {
|
||
|
fprintf( stderr,
|
||
|
"%s: Can't XAllocNamedColor( \"white\" ).\n", ProgramName );
|
||
|
exit( 1 );
|
||
|
}
|
||
|
|
||
|
if ( !XAllocNamedColor( theDisplay, theColormap,
|
||
|
"black", &theBlackColor, &theExactColor ) ) {
|
||
|
fprintf( stderr,
|
||
|
"%s: Can't XAllocNamedColor( \"black\" ).\n", ProgramName );
|
||
|
exit( 1 );
|
||
|
}
|
||
|
|
||
|
theCursor = XCreatePixmapCursor( theDisplay,
|
||
|
theCursorSource, theCursorMask,
|
||
|
&theBlackColor, &theWhiteColor,
|
||
|
cursor_x_hot, cursor_y_hot );
|
||
|
|
||
|
theWindowAttributes.border_pixel = theBlackPixel;
|
||
|
theWindowAttributes.background_pixel = theWhitePixel;
|
||
|
theWindowAttributes.cursor = theCursor;
|
||
|
theWindowAttributes.override_redirect = False;
|
||
|
|
||
|
theWindowMask = CWBackPixel |
|
||
|
CWBorderPixel |
|
||
|
CWCursor |
|
||
|
CWOverrideRedirect;
|
||
|
|
||
|
theWindow = XCreateWindow( theDisplay,
|
||
|
RootWindow( theDisplay, theScreen ),
|
||
|
WindowPointX, WindowPointY,
|
||
|
WindowWidth, WindowHeight,
|
||
|
BorderWidth,
|
||
|
theDepth,
|
||
|
InputOutput,
|
||
|
CopyFromParent,
|
||
|
theWindowMask,
|
||
|
&theWindowAttributes );
|
||
|
|
||
|
theIconPixmap = XCreateBitmapFromData( theDisplay, theWindow,
|
||
|
icon_bits,
|
||
|
icon_width,
|
||
|
icon_height );
|
||
|
|
||
|
theWMHints.icon_pixmap = theIconPixmap;
|
||
|
if ( iconicState ) {
|
||
|
theWMHints.initial_state = IconicState;
|
||
|
} else {
|
||
|
theWMHints.initial_state = NormalState;
|
||
|
}
|
||
|
theWMHints.flags = IconPixmapHint | StateHint;
|
||
|
|
||
|
XSetWMHints( theDisplay, theWindow, &theWMHints );
|
||
|
|
||
|
theSizeHints.flags = PPosition | PSize;
|
||
|
theSizeHints.x = WindowPointX;
|
||
|
theSizeHints.y = WindowPointY;
|
||
|
theSizeHints.width = WindowWidth;
|
||
|
theSizeHints.height = WindowHeight;
|
||
|
|
||
|
XSetNormalHints( theDisplay, theWindow, &theSizeHints );
|
||
|
|
||
|
if ( strlen( TitleName ) >= 1 ) {
|
||
|
XStoreName( theDisplay, theWindow, TitleName );
|
||
|
XSetIconName( theDisplay, theWindow, TitleName );
|
||
|
} else {
|
||
|
XStoreName( theDisplay, theWindow, ProgramName );
|
||
|
XSetIconName( theDisplay, theWindow, ProgramName );
|
||
|
}
|
||
|
|
||
|
XMapWindow( theDisplay, theWindow );
|
||
|
|
||
|
XFlush( theDisplay );
|
||
|
|
||
|
XGetGeometry( theDisplay, theWindow,
|
||
|
&theRoot,
|
||
|
&WindowPointX, &WindowPointY,
|
||
|
&WindowWidth, &WindowHeight,
|
||
|
&BorderWidth, &theDepth );
|
||
|
|
||
|
InitBitmapAndGCs();
|
||
|
|
||
|
XSelectInput( theDisplay, theWindow, EVENT_MASK1 );
|
||
|
|
||
|
XFlush( theDisplay );
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* %$%s%?!</usr/src/games/xneko/SCCS/s.xneko.ck
|
||
|
*
|
||
|
* !!$3$N4X?t$r8F$V$H!"$"$k0lDj$N;~4VJV$C$F$3$J$/$J$k!#G-
|
||
|
* $NF0:n%?%$%_%s%0D4@0$KMxMQ$9$k$3$H!#
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
Interval()
|
||
|
{
|
||
|
pause();
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* SCCS/s.xneko.c#728/%+%&%s%H=hM}
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
TickCount()
|
||
|
{
|
||
|
if ( ++NekoTickCount >= MAX_TICK ) {
|
||
|
NekoTickCount = 0;
|
||
|
}
|
||
|
|
||
|
if ( NekoTickCount % 2 == 0 ) {
|
||
|
if ( NekoStateCount < MAX_TICK ) {
|
||
|
NekoStateCount++;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G->uBV@_Dj
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
SetNekoState( SetValue )
|
||
|
int SetValue;
|
||
|
{
|
||
|
NekoTickCount = 0;
|
||
|
NekoStateCount = 0;
|
||
|
|
||
|
NekoState = SetValue;
|
||
|
|
||
|
#ifdef DEBUG
|
||
|
switch ( NekoState ) {
|
||
|
case NEKO_STOP:
|
||
|
case NEKO_JARE:
|
||
|
case NEKO_KAKI:
|
||
|
case NEKO_AKUBI:
|
||
|
case NEKO_SLEEP:
|
||
|
case NEKO_U_TOGI:
|
||
|
case NEKO_D_TOGI:
|
||
|
case NEKO_L_TOGI:
|
||
|
case NEKO_R_TOGI:
|
||
|
NekoMoveDx = NekoMoveDy = 0;
|
||
|
break;
|
||
|
default:
|
||
|
break;
|
||
|
}
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G-IA2h=hM}
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
DrawNeko( x, y, DrawGC )
|
||
|
int x;
|
||
|
int y;
|
||
|
GC DrawGC;
|
||
|
{
|
||
|
if ( ( x != NekoLastX || y != NekoLastY )
|
||
|
&& ( EventState != DEBUG_LIST ) ) {
|
||
|
XFillRectangle( theDisplay, theWindow, SpaceGC,
|
||
|
NekoLastX, NekoLastY,
|
||
|
BITMAP_WIDTH, BITMAP_HEIGHT );
|
||
|
}
|
||
|
|
||
|
XSetTSOrigin( theDisplay, DrawGC, x, y );
|
||
|
|
||
|
XFillRectangle( theDisplay, theWindow, DrawGC,
|
||
|
x, y, BITMAP_WIDTH, BITMAP_HEIGHT );
|
||
|
|
||
|
XFlush( theDisplay );
|
||
|
|
||
|
NekoLastX = x;
|
||
|
NekoLastY = y;
|
||
|
|
||
|
NekoLastGC = DrawGC;
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G-:FIA2h=hM}
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
RedrawNeko()
|
||
|
{
|
||
|
XFillRectangle( theDisplay, theWindow, NekoLastGC,
|
||
|
NekoLastX, NekoLastY,
|
||
|
BITMAP_WIDTH, BITMAP_HEIGHT );
|
||
|
|
||
|
XFlush( theDisplay );
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G-0\F0J}K!7hDj
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
NekoDirection()
|
||
|
{
|
||
|
int NewState;
|
||
|
double LargeX, LargeY;
|
||
|
double Length;
|
||
|
double SinTheta;
|
||
|
|
||
|
if ( NekoMoveDx == 0 && NekoMoveDy == 0 ) {
|
||
|
NewState = NEKO_STOP;
|
||
|
} else {
|
||
|
LargeX = (double)NekoMoveDx;
|
||
|
LargeY = (double)(-NekoMoveDy);
|
||
|
Length = sqrt( LargeX * LargeX + LargeY * LargeY );
|
||
|
SinTheta = LargeY / Length;
|
||
|
|
||
|
if ( NekoMoveDx > 0 ) {
|
||
|
if ( SinTheta > SinPiPer8Times3 ) {
|
||
|
NewState = NEKO_U_MOVE;
|
||
|
} else if ( ( SinTheta <= SinPiPer8Times3 )
|
||
|
&& ( SinTheta > SinPiPer8 ) ) {
|
||
|
NewState = NEKO_UR_MOVE;
|
||
|
} else if ( ( SinTheta <= SinPiPer8 )
|
||
|
&& ( SinTheta > -( SinPiPer8 ) ) ) {
|
||
|
NewState = NEKO_R_MOVE;
|
||
|
} else if ( ( SinTheta <= -( SinPiPer8 ) )
|
||
|
&& ( SinTheta > -( SinPiPer8Times3 ) ) ) {
|
||
|
NewState = NEKO_DR_MOVE;
|
||
|
} else {
|
||
|
NewState = NEKO_D_MOVE;
|
||
|
}
|
||
|
} else {
|
||
|
if ( SinTheta > SinPiPer8Times3 ) {
|
||
|
NewState = NEKO_U_MOVE;
|
||
|
} else if ( ( SinTheta <= SinPiPer8Times3 )
|
||
|
&& ( SinTheta > SinPiPer8 ) ) {
|
||
|
NewState = NEKO_UL_MOVE;
|
||
|
} else if ( ( SinTheta <= SinPiPer8 )
|
||
|
&& ( SinTheta > -( SinPiPer8 ) ) ) {
|
||
|
NewState = NEKO_L_MOVE;
|
||
|
} else if ( ( SinTheta <= -( SinPiPer8 ) )
|
||
|
&& ( SinTheta > -( SinPiPer8Times3 ) ) ) {
|
||
|
NewState = NEKO_DL_MOVE;
|
||
|
} else {
|
||
|
NewState = NEKO_D_MOVE;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if ( NekoState != NewState ) {
|
||
|
SetNekoState( NewState );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G-JI$V$D$+$jH=Dj
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
Bool
|
||
|
IsWindowOver()
|
||
|
{
|
||
|
Bool ReturnValue = False;
|
||
|
|
||
|
if ( NekoY <= 0 ) {
|
||
|
NekoY = 0;
|
||
|
ReturnValue = True;
|
||
|
} else if ( NekoY >= WindowHeight - BITMAP_HEIGHT ) {
|
||
|
NekoY = WindowHeight - BITMAP_HEIGHT;
|
||
|
ReturnValue = True;
|
||
|
}
|
||
|
if ( NekoX <= 0 ) {
|
||
|
NekoX = 0;
|
||
|
ReturnValue = True;
|
||
|
} else if ( NekoX >= WindowWidth - BITMAP_WIDTH ) {
|
||
|
NekoX = WindowWidth - BITMAP_WIDTH;
|
||
|
ReturnValue = True;
|
||
|
}
|
||
|
|
||
|
return( ReturnValue );
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G-0\F0>u67H=Dj
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
Bool
|
||
|
IsNekoDontMove()
|
||
|
{
|
||
|
if ( NekoX == NekoLastX && NekoY == NekoLastY ) {
|
||
|
return( True );
|
||
|
} else {
|
||
|
return( False );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G-0\F03+;OH=Dj
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
Bool
|
||
|
IsNekoMoveStart()
|
||
|
{
|
||
|
#ifndef DEBUG
|
||
|
if ( ( PrevMouseX >= MouseX - IDLE_SPACE
|
||
|
&& PrevMouseX <= MouseX + IDLE_SPACE ) &&
|
||
|
( PrevMouseY >= MouseY - IDLE_SPACE
|
||
|
&& PrevMouseY <= MouseY + IDLE_SPACE ) ) {
|
||
|
return( False );
|
||
|
} else {
|
||
|
return( True );
|
||
|
}
|
||
|
#else
|
||
|
if ( NekoMoveDx == 0 && NekoMoveDy == 0 ) {
|
||
|
return( False );
|
||
|
} else {
|
||
|
return( True );
|
||
|
}
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G-0\F0 dx, dy 7W;;
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
CalcDxDy()
|
||
|
{
|
||
|
Window QueryRoot, QueryChild;
|
||
|
int AbsoluteX, AbsoluteY;
|
||
|
int RelativeX, RelativeY;
|
||
|
unsigned int ModKeyMask;
|
||
|
double LargeX, LargeY;
|
||
|
double DoubleLength, Length;
|
||
|
|
||
|
XQueryPointer( theDisplay, theWindow,
|
||
|
&QueryRoot, &QueryChild,
|
||
|
&AbsoluteX, &AbsoluteY,
|
||
|
&RelativeX, &RelativeY,
|
||
|
&ModKeyMask );
|
||
|
|
||
|
PrevMouseX = MouseX;
|
||
|
PrevMouseY = MouseY;
|
||
|
|
||
|
MouseX = RelativeX;
|
||
|
MouseY = RelativeY;
|
||
|
|
||
|
LargeX = (double)( MouseX - NekoX - BITMAP_WIDTH / 2 );
|
||
|
LargeY = (double)( MouseY - NekoY - BITMAP_HEIGHT );
|
||
|
|
||
|
DoubleLength = LargeX * LargeX + LargeY * LargeY;
|
||
|
|
||
|
if ( DoubleLength != (double)0 ) {
|
||
|
Length = sqrt( DoubleLength );
|
||
|
if ( Length <= NekoSpeed ) {
|
||
|
NekoMoveDx = (int)LargeX;
|
||
|
NekoMoveDy = (int)LargeY;
|
||
|
} else {
|
||
|
NekoMoveDx = (int)( ( NekoSpeed * LargeX ) / Length );
|
||
|
NekoMoveDy = (int)( ( NekoSpeed * LargeY ) / Length );
|
||
|
}
|
||
|
} else {
|
||
|
NekoMoveDx = NekoMoveDy = 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* F0:n2r@OG-IA2h=hM}
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
NekoThinkDraw()
|
||
|
{
|
||
|
#ifndef DEBUG
|
||
|
CalcDxDy();
|
||
|
#endif
|
||
|
|
||
|
if ( NekoState != NEKO_SLEEP ) {
|
||
|
DrawNeko( NekoX, NekoY,
|
||
|
NekoTickCount % 2 == 0 ?
|
||
|
*(AnimationPattern[ NekoState ].TickEvenGCPtr) :
|
||
|
*(AnimationPattern[ NekoState ].TickOddGCPtr) );
|
||
|
} else {
|
||
|
DrawNeko( NekoX, NekoY,
|
||
|
NekoTickCount % 8 <= 3 ?
|
||
|
*(AnimationPattern[ NekoState ].TickEvenGCPtr) :
|
||
|
*(AnimationPattern[ NekoState ].TickOddGCPtr) );
|
||
|
}
|
||
|
|
||
|
TickCount();
|
||
|
|
||
|
switch ( NekoState ) {
|
||
|
case NEKO_STOP:
|
||
|
if ( IsNekoMoveStart() ) {
|
||
|
SetNekoState( NEKO_AWAKE );
|
||
|
break;
|
||
|
}
|
||
|
if ( NekoStateCount < NEKO_STOP_TIME ) {
|
||
|
break;
|
||
|
}
|
||
|
if ( NekoMoveDx < 0 && NekoX <= 0 ) {
|
||
|
SetNekoState( NEKO_L_TOGI );
|
||
|
} else if ( NekoMoveDx > 0 && NekoX >= WindowWidth - BITMAP_WIDTH ) {
|
||
|
SetNekoState( NEKO_R_TOGI );
|
||
|
} else if ( NekoMoveDy < 0 && NekoY <= 0 ) {
|
||
|
SetNekoState( NEKO_U_TOGI );
|
||
|
} else if ( NekoMoveDy > 0 && NekoY >= WindowHeight - BITMAP_HEIGHT ) {
|
||
|
SetNekoState( NEKO_D_TOGI );
|
||
|
} else {
|
||
|
SetNekoState( NEKO_JARE );
|
||
|
}
|
||
|
break;
|
||
|
case NEKO_JARE:
|
||
|
if ( IsNekoMoveStart() ) {
|
||
|
SetNekoState( NEKO_AWAKE );
|
||
|
break;
|
||
|
}
|
||
|
if ( NekoStateCount < NEKO_JARE_TIME ) {
|
||
|
break;
|
||
|
}
|
||
|
SetNekoState( NEKO_KAKI );
|
||
|
break;
|
||
|
case NEKO_KAKI:
|
||
|
if ( IsNekoMoveStart() ) {
|
||
|
SetNekoState( NEKO_AWAKE );
|
||
|
break;
|
||
|
}
|
||
|
if ( NekoStateCount < NEKO_KAKI_TIME ) {
|
||
|
break;
|
||
|
}
|
||
|
SetNekoState( NEKO_AKUBI );
|
||
|
break;
|
||
|
case NEKO_AKUBI:
|
||
|
if ( IsNekoMoveStart() ) {
|
||
|
SetNekoState( NEKO_AWAKE );
|
||
|
break;
|
||
|
}
|
||
|
if ( NekoStateCount < NEKO_AKUBI_TIME ) {
|
||
|
break;
|
||
|
}
|
||
|
SetNekoState( NEKO_SLEEP );
|
||
|
break;
|
||
|
case NEKO_SLEEP:
|
||
|
if ( IsNekoMoveStart() ) {
|
||
|
SetNekoState( NEKO_AWAKE );
|
||
|
break;
|
||
|
}
|
||
|
break;
|
||
|
case NEKO_AWAKE:
|
||
|
if ( NekoStateCount < NEKO_AWAKE_TIME ) {
|
||
|
break;
|
||
|
}
|
||
|
NekoDirection(); /* G-$,F0$/8~$-$r5a$a$k */
|
||
|
break;
|
||
|
case NEKO_U_MOVE:
|
||
|
case NEKO_D_MOVE:
|
||
|
case NEKO_L_MOVE:
|
||
|
case NEKO_R_MOVE:
|
||
|
case NEKO_UL_MOVE:
|
||
|
case NEKO_UR_MOVE:
|
||
|
case NEKO_DL_MOVE:
|
||
|
case NEKO_DR_MOVE:
|
||
|
NekoX += NekoMoveDx;
|
||
|
NekoY += NekoMoveDy;
|
||
|
NekoDirection();
|
||
|
if ( IsWindowOver() ) {
|
||
|
if ( IsNekoDontMove() ) {
|
||
|
SetNekoState( NEKO_STOP );
|
||
|
}
|
||
|
}
|
||
|
break;
|
||
|
case NEKO_U_TOGI:
|
||
|
case NEKO_D_TOGI:
|
||
|
case NEKO_L_TOGI:
|
||
|
case NEKO_R_TOGI:
|
||
|
if ( IsNekoMoveStart() ) {
|
||
|
SetNekoState( NEKO_AWAKE );
|
||
|
break;
|
||
|
}
|
||
|
if ( NekoStateCount < NEKO_TOGI_TIME ) {
|
||
|
break;
|
||
|
}
|
||
|
SetNekoState( NEKO_KAKI );
|
||
|
break;
|
||
|
default:
|
||
|
/* Internal Error */
|
||
|
SetNekoState( NEKO_STOP );
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
Interval();
|
||
|
}
|
||
|
|
||
|
|
||
|
#ifdef DEBUG
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* %-%c%i%/%?!<0lMwI=<(!J5/31/93P11500MQ!K
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
DisplayCharacters()
|
||
|
{
|
||
|
int Index;
|
||
|
int x, y;
|
||
|
|
||
|
for ( Index = 0, x = 0, y = 0;
|
||
|
BitmapGCDataTable[ Index ].GCCreatePtr != NULL; Index++ ) {
|
||
|
|
||
|
DrawNeko( x, y, *(BitmapGCDataTable[ Index ].GCCreatePtr) );
|
||
|
XFlush( theDisplay );
|
||
|
|
||
|
x += BITMAP_WIDTH;
|
||
|
|
||
|
if ( x > WindowWidth - BITMAP_WIDTH ) {
|
||
|
x = 0;
|
||
|
y += BITMAP_HEIGHT;
|
||
|
if ( y > WindowHeight - BITMAP_HEIGHT) {
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#endif /* DEBUG */
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* %-!<%$s%H=hM}
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
Bool
|
||
|
ProcessKeyPress( theKeyEvent )
|
||
|
XKeyEvent *theKeyEvent;
|
||
|
{
|
||
|
int Length;
|
||
|
int theKeyBufferMaxLen = AVAIL_KEYBUF;
|
||
|
char theKeyBuffer[ AVAIL_KEYBUF + 1 ];
|
||
|
KeySym theKeySym;
|
||
|
XComposeStatus theComposeStatus;
|
||
|
Bool ReturnState;
|
||
|
|
||
|
ReturnState = True;
|
||
|
|
||
|
Length = XLookupString( theKeyEvent,
|
||
|
theKeyBuffer, theKeyBufferMaxLen,
|
||
|
&theKeySym, &theComposeStatus );
|
||
|
|
||
|
if ( Length > 0 ) {
|
||
|
switch ( theKeyBuffer[ 0 ] ) {
|
||
|
case 'q':
|
||
|
case 'Q':
|
||
|
if ( theKeyEvent->state & Mod1Mask ) { /* META (Alt) %-!< */
|
||
|
ReturnState = False;
|
||
|
}
|
||
|
break;
|
||
|
default:
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#ifdef DEBUG
|
||
|
if ( EventState == DEBUG_MOVE ) {
|
||
|
switch ( theKeySym ) {
|
||
|
case XK_KP_1:
|
||
|
NekoMoveDx = -(int)( NekoSpeed / sqrt( (double)2 ) );
|
||
|
NekoMoveDy = -NekoMoveDx;
|
||
|
break;
|
||
|
case XK_KP_2:
|
||
|
NekoMoveDx = 0;
|
||
|
NekoMoveDy = (int)NekoSpeed;
|
||
|
break;
|
||
|
case XK_KP_3:
|
||
|
NekoMoveDx = (int)( NekoSpeed / sqrt( (double)2 ) );
|
||
|
NekoMoveDy = NekoMoveDx;
|
||
|
break;
|
||
|
case XK_KP_4:
|
||
|
NekoMoveDx = -(int)NekoSpeed;
|
||
|
NekoMoveDy = 0;
|
||
|
break;
|
||
|
case XK_KP_5:
|
||
|
NekoMoveDx = 0;
|
||
|
NekoMoveDy = 0;
|
||
|
break;
|
||
|
case XK_KP_6:
|
||
|
NekoMoveDx = (int)NekoSpeed;
|
||
|
NekoMoveDy = 0;
|
||
|
break;
|
||
|
case XK_KP_7:
|
||
|
NekoMoveDx = -(int)( NekoSpeed / sqrt( (double)2 ) );
|
||
|
NekoMoveDy = NekoMoveDx;
|
||
|
break;
|
||
|
case XK_KP_8:
|
||
|
NekoMoveDx = 0;
|
||
|
NekoMoveDy = -(int)NekoSpeed;
|
||
|
break;
|
||
|
case XK_KP_9:
|
||
|
NekoMoveDx = (int)( NekoSpeed / sqrt( (double)2 ) );
|
||
|
NekoMoveDy = -NekoMoveDx;
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
return( ReturnState );
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G-0LCVD4@0
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
NekoAdjust()
|
||
|
{
|
||
|
if ( NekoX < 0 ) {
|
||
|
NekoX = 0;
|
||
|
} else if ( NekoX > WindowWidth - BITMAP_WIDTH ) {
|
||
|
NekoX = WindowWidth - BITMAP_WIDTH;
|
||
|
}
|
||
|
|
||
|
if ( NekoY < 0 ) {
|
||
|
NekoY = 0;
|
||
|
} else if ( NekoY > WindowHeight - BITMAP_HEIGHT ) {
|
||
|
NekoY = WindowHeight - BITMAP_HEIGHT;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* %$s%H=hM}
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
Bool
|
||
|
ProcessEvent()
|
||
|
{
|
||
|
XEvent theEvent;
|
||
|
Bool ContinueState = True;
|
||
|
|
||
|
switch ( EventState ) {
|
||
|
case NORMAL_STATE:
|
||
|
while ( XCheckMaskEvent( theDisplay, EVENT_MASK1, &theEvent ) ) {
|
||
|
switch ( theEvent.type ) {
|
||
|
case ConfigureNotify:
|
||
|
WindowWidth = theEvent.xconfigure.width;
|
||
|
WindowHeight = theEvent.xconfigure.height;
|
||
|
WindowPointX = theEvent.xconfigure.x;
|
||
|
WindowPointY = theEvent.xconfigure.y;
|
||
|
BorderWidth = theEvent.xconfigure.border_width;
|
||
|
NekoAdjust();
|
||
|
break;
|
||
|
case Expose:
|
||
|
if ( theEvent.xexpose.count == 0 ) {
|
||
|
RedrawNeko();
|
||
|
}
|
||
|
break;
|
||
|
case MapNotify:
|
||
|
RedrawNeko();
|
||
|
break;
|
||
|
case KeyPress:
|
||
|
ContinueState = ProcessKeyPress( &theEvent.xkey );
|
||
|
if ( !ContinueState ) {
|
||
|
return( ContinueState );
|
||
|
}
|
||
|
break;
|
||
|
default:
|
||
|
/* Unknown Event */
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
break;
|
||
|
#ifdef DEBUG
|
||
|
case DEBUG_LIST:
|
||
|
XNextEvent( theDisplay, &theEvent );
|
||
|
switch ( theEvent.type ) {
|
||
|
case ConfigureNotify:
|
||
|
WindowWidth = theEvent.xconfigure.width;
|
||
|
WindowHeight = theEvent.xconfigure.height;
|
||
|
WindowPointX = theEvent.xconfigure.x;
|
||
|
WindowPointY = theEvent.xconfigure.y;
|
||
|
BorderWidth = theEvent.xconfigure.border_width;
|
||
|
break;
|
||
|
case Expose:
|
||
|
if ( theEvent.xexpose.count == 0 ) {
|
||
|
DisplayCharacters();
|
||
|
}
|
||
|
break;
|
||
|
case MapNotify:
|
||
|
DisplayCharacters();
|
||
|
break;
|
||
|
case KeyPress:
|
||
|
ContinueState = ProcessKeyPress( &theEvent );
|
||
|
break;
|
||
|
default:
|
||
|
/* Unknown Event */
|
||
|
break;
|
||
|
}
|
||
|
break;
|
||
|
case DEBUG_MOVE:
|
||
|
while ( XCheckMaskEvent( theDisplay, EVENT_MASK1, &theEvent ) ) {
|
||
|
switch ( theEvent.type ) {
|
||
|
case ConfigureNotify:
|
||
|
WindowWidth = theEvent.xconfigure.width;
|
||
|
WindowHeight = theEvent.xconfigure.height;
|
||
|
WindowPointX = theEvent.xconfigure.x;
|
||
|
WindowPointY = theEvent.xconfigure.y;
|
||
|
BorderWidth = theEvent.xconfigure.border_width;
|
||
|
NekoAdjust();
|
||
|
break;
|
||
|
case Expose:
|
||
|
if ( theEvent.xexpose.count == 0 ) {
|
||
|
RedrawNeko();
|
||
|
}
|
||
|
break;
|
||
|
case MapNotify:
|
||
|
RedrawNeko();
|
||
|
break;
|
||
|
case KeyPress:
|
||
|
ContinueState = ProcessKeyPress( &theEvent );
|
||
|
if ( !ContinueState ) {
|
||
|
return( ContinueState );
|
||
|
}
|
||
|
break;
|
||
|
default:
|
||
|
/* Unknown Event */
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
break;
|
||
|
#endif
|
||
|
default:
|
||
|
/* Internal Error */
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
return( ContinueState );
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G-=hM}
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
ProcessNeko()
|
||
|
{
|
||
|
struct itimerval Value;
|
||
|
|
||
|
/* 4D6-$N=i4|2= */
|
||
|
|
||
|
EventState = NORMAL_STATE;
|
||
|
|
||
|
/* G-$N=i4|2= */
|
||
|
|
||
|
NekoX = ( WindowWidth - BITMAP_WIDTH / 2 ) / 2;
|
||
|
NekoY = ( WindowHeight - BITMAP_HEIGHT / 2 ) / 2;
|
||
|
|
||
|
NekoLastX = NekoX;
|
||
|
NekoLastY = NekoY;
|
||
|
|
||
|
SetNekoState( NEKO_STOP );
|
||
|
|
||
|
/* %?%$%^!<@_Dj */
|
||
|
|
||
|
timerclear( &Value.it_interval );
|
||
|
timerclear( &Value.it_value );
|
||
|
|
||
|
Value.it_interval.tv_usec = IntervalTime;
|
||
|
Value.it_value.tv_usec = IntervalTime;
|
||
|
|
||
|
setitimer( ITIMER_REAL, &Value, 0 );
|
||
|
|
||
|
/* %a%$%s=hM} */
|
||
|
|
||
|
do {
|
||
|
NekoThinkDraw();
|
||
|
} while ( ProcessEvent() );
|
||
|
}
|
||
|
|
||
|
|
||
|
#ifdef DEBUG
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G-0lMw!J5/31/93P14460MQ!K
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
NekoList()
|
||
|
{
|
||
|
EventState = DEBUG_LIST;
|
||
|
|
||
|
fprintf( stderr, "\n" );
|
||
|
fprintf( stderr, "G-0lMw$rI=<($7$^$9!#(Quit !D Alt-Q)\n" );
|
||
|
fprintf( stderr, "\n" );
|
||
|
|
||
|
XSelectInput( theDisplay, theWindow, EVENT_MASK2 );
|
||
|
|
||
|
while ( ProcessEvent() );
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* G-0\F0SCCS/s.xneko.c9%H!J5/31/93P14670MQ!K
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
NekoMoveTest()
|
||
|
{
|
||
|
struct itimerval Value;
|
||
|
|
||
|
/* 4D6-$N=i4|2= */
|
||
|
|
||
|
EventState = DEBUG_MOVE;
|
||
|
|
||
|
/* G-$N=i4|2= */
|
||
|
|
||
|
NekoX = ( WindowWidth - BITMAP_WIDTH / 2 ) / 2;
|
||
|
NekoY = ( WindowHeight - BITMAP_HEIGHT / 2 ) / 2;
|
||
|
|
||
|
NekoLastX = NekoX;
|
||
|
NekoLastY = NekoY;
|
||
|
|
||
|
SetNekoState( NEKO_STOP );
|
||
|
|
||
|
/* %?%$%^!<@_Dj */
|
||
|
|
||
|
timerclear( &Value.it_interval );
|
||
|
timerclear( &Value.it_value );
|
||
|
|
||
|
Value.it_interval.tv_usec = IntervalTime;
|
||
|
Value.it_value.tv_usec = IntervalTime;
|
||
|
|
||
|
setitimer( ITIMER_REAL, &Value, 0 );
|
||
|
|
||
|
/* %a%$%s=hM} */
|
||
|
|
||
|
fprintf( stderr, "\n" );
|
||
|
fprintf( stderr, "G-$N0\F0SCCS/s.xneko.c9%H$r9T$$$^$9!#(Quit !D Alt-Q)\n" );
|
||
|
fprintf( stderr, "\n" );
|
||
|
fprintf( stderr, "\t%-!<May 31, 1993C%I>e$NSCCS/s.xneko.cs%-!<$GG-$r0\F0$5$;$F2<$5$$!#\n" );
|
||
|
fprintf( stderr, "\t(M-8z$J%-!<$O#1!A#9$G$9!#)\n" );
|
||
|
fprintf( stderr, "\n" );
|
||
|
|
||
|
do {
|
||
|
NekoThinkDraw();
|
||
|
} while ( ProcessEvent() );
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* %a%K%e!<=hM}!J5/31/93P15170MQ!K
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
ProcessDebugMenu()
|
||
|
{
|
||
|
int UserSelectNo = 0;
|
||
|
char UserAnswer[ BUFSIZ ];
|
||
|
|
||
|
fprintf( stderr, "\n" );
|
||
|
fprintf( stderr, "!Zxneko 5/31/93P15280%a%K%e!<![\n" );
|
||
|
|
||
|
while ( !( UserSelectNo >= 1 && UserSelectNo <= 2 ) ) {
|
||
|
fprintf( stderr, "\n" );
|
||
|
fprintf( stderr, "\t1)!!G-%-%c%i%/%?!<0lMwI=<(\n" );
|
||
|
fprintf( stderr, "\t2)!!G-0\F0SCCS/s.xneko.c9%H\n" );
|
||
|
fprintf( stderr, "\n" );
|
||
|
fprintf( stderr, "Select: " );
|
||
|
|
||
|
fgets( UserAnswer, sizeof( UserAnswer ), stdin );
|
||
|
|
||
|
UserSelectNo = atoi( UserAnswer );
|
||
|
|
||
|
if ( !( UserSelectNo >= 1 && UserSelectNo <= 2 ) ) {
|
||
|
fprintf( stderr, "\n" );
|
||
|
fprintf( stderr, "@5$7$$HV9f$rA*Br$7$F2<$5$$!#\n" );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
switch ( UserSelectNo ) {
|
||
|
case 1:
|
||
|
/* G-%-%c%i%/%?!<0lMwI=<( */
|
||
|
NekoList();
|
||
|
break;
|
||
|
case 2:
|
||
|
/* G-0\F0SCCS/s.xneko.c9%H */
|
||
|
NekoMoveTest();
|
||
|
break;
|
||
|
default:
|
||
|
/* Internal Error */
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
fprintf( stderr, "SCCS/s.xneko.c9%H=*N;!#\n" );
|
||
|
fprintf( stderr, "\n" );
|
||
|
}
|
||
|
|
||
|
#endif /* DEBUG */
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* SIGALRM %7%0%J%k=hM}
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
NullFunction()
|
||
|
{
|
||
|
/* No Operation */
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* Usage
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
void
|
||
|
Usage()
|
||
|
{
|
||
|
fprintf( stderr,
|
||
|
"Usage: %s [-display <display>] [-geometry <geometry>] \\\n",
|
||
|
ProgramName );
|
||
|
fprintf( stderr, " [-title <title>] [-name <title>] [-iconic] \\\n" );
|
||
|
fprintf( stderr, " [-speed <speed>] [-time <time>] [-help]\n" );
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* #XMay 31, 1993i%a!<%?I>2A
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
Bool
|
||
|
GetArguments( argc, argv, theDisplayName, theGeometry, theTitle,
|
||
|
NekoSpeed, IntervalTime )
|
||
|
int argc;
|
||
|
char *argv[];
|
||
|
char *theDisplayName;
|
||
|
char *theGeometry;
|
||
|
char *theTitle;
|
||
|
double *NekoSpeed;
|
||
|
long *IntervalTime;
|
||
|
{
|
||
|
int ArgCounter;
|
||
|
Bool iconicState;
|
||
|
|
||
|
theDisplayName[ 0 ] = '\0';
|
||
|
theGeometry[ 0 ] = '\0';
|
||
|
theTitle[ 0 ] = '\0';
|
||
|
|
||
|
iconicState = False;
|
||
|
|
||
|
for ( ArgCounter = 0; ArgCounter < argc; ArgCounter++ ) {
|
||
|
|
||
|
if ( strncmp( argv[ ArgCounter ], "-h", 2 ) == 0 ) {
|
||
|
Usage();
|
||
|
exit( 0 );
|
||
|
} else if ( strcmp( argv[ ArgCounter ], "-display" ) == 0 ) {
|
||
|
ArgCounter++;
|
||
|
if ( ArgCounter < argc ) {
|
||
|
strcpy( theDisplayName, argv[ ArgCounter ] );
|
||
|
} else {
|
||
|
fprintf( stderr, "%s: -display option error.\n", ProgramName );
|
||
|
exit( 1 );
|
||
|
}
|
||
|
} else if ( strncmp( argv[ ArgCounter ], "-geom", 5 ) == 0 ) {
|
||
|
ArgCounter++;
|
||
|
if ( ArgCounter < argc ) {
|
||
|
strcpy( theGeometry, argv[ ArgCounter ] );
|
||
|
} else {
|
||
|
fprintf( stderr,
|
||
|
"%s: -geometry option error.\n", ProgramName );
|
||
|
exit( 1 );
|
||
|
}
|
||
|
} else if ( ( strcmp( argv[ ArgCounter ], "-title" ) == 0 )
|
||
|
|| ( strcmp( argv[ ArgCounter ], "-name" ) == 0 ) ) {
|
||
|
ArgCounter++;
|
||
|
if ( ArgCounter < argc ) {
|
||
|
strcpy( theTitle, argv[ ArgCounter ] );
|
||
|
} else {
|
||
|
fprintf( stderr, "%s: -title option error.\n", ProgramName );
|
||
|
exit( 1 );
|
||
|
}
|
||
|
} else if ( strcmp( argv[ ArgCounter ], "-iconic" ) == 0 ) {
|
||
|
iconicState = True;
|
||
|
} else if ( strcmp( argv[ ArgCounter ], "-speed" ) == 0 ) {
|
||
|
ArgCounter++;
|
||
|
if ( ArgCounter < argc ) {
|
||
|
*NekoSpeed = atof( argv[ ArgCounter ] );
|
||
|
} else {
|
||
|
fprintf( stderr, "%s: -speed option error.\n", ProgramName );
|
||
|
exit( 1 );
|
||
|
}
|
||
|
} else if ( strcmp( argv[ ArgCounter ], "-time" ) == 0 ) {
|
||
|
ArgCounter++;
|
||
|
if ( ArgCounter < argc ) {
|
||
|
*IntervalTime = atol( argv[ ArgCounter ] );
|
||
|
} else {
|
||
|
fprintf( stderr, "%s: -time option error.\n", ProgramName );
|
||
|
exit( 1 );
|
||
|
}
|
||
|
} else {
|
||
|
fprintf( stderr,
|
||
|
"%s: Unknown option \"%s\".\n", ProgramName,
|
||
|
argv[ ArgCounter ] );
|
||
|
Usage();
|
||
|
exit( 1 );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if ( strlen( theDisplayName ) < 1 ) {
|
||
|
theDisplayName = NULL;
|
||
|
}
|
||
|
|
||
|
if ( strlen( theGeometry ) < 1 ) {
|
||
|
theGeometry = NULL;
|
||
|
}
|
||
|
|
||
|
return( iconicState );
|
||
|
}
|
||
|
|
||
|
|
||
|
/*--------------------------------------------------------------
|
||
|
*
|
||
|
* %a%$%s4X?t
|
||
|
*
|
||
|
*--------------------------------------------------------------*/
|
||
|
|
||
|
int
|
||
|
main( argc, argv )
|
||
|
int argc;
|
||
|
char *argv[];
|
||
|
{
|
||
|
Bool iconicState;
|
||
|
char theDisplayName[ DIRNAMELEN ];
|
||
|
char theGeometry[ DIRNAMELEN ];
|
||
|
char theTitle[ DIRNAMELEN ];
|
||
|
|
||
|
ProgramName = argv[ 0 ];
|
||
|
|
||
|
argc--;
|
||
|
argv++;
|
||
|
|
||
|
iconicState = GetArguments( argc, argv,
|
||
|
theDisplayName,
|
||
|
theGeometry,
|
||
|
theTitle,
|
||
|
&NekoSpeed,
|
||
|
&IntervalTime );
|
||
|
|
||
|
InitScreen( theDisplayName, theGeometry, theTitle, iconicState );
|
||
|
|
||
|
signal( SIGALRM, NullFunction );
|
||
|
|
||
|
SinPiPer8Times3 = sin( PI_PER8 * (double)3 );
|
||
|
SinPiPer8 = sin( PI_PER8 );
|
||
|
|
||
|
#ifndef DEBUG
|
||
|
ProcessNeko();
|
||
|
#else
|
||
|
ProcessDebugMenu();
|
||
|
#endif
|
||
|
|
||
|
exit( 0 );
|
||
|
}
|