aboutsummaryrefslogtreecommitdiffstats
path: root/docs/dist/examples/spacewar/SpaceObject.java
blob: ee3afabccbadffd2d7ba964adfeb47303fd5aa81 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*

Copyright (c) Xerox Corporation 1998-2002.  All rights reserved.

Use and copying of this software and preparation of derivative works based
upon this software are permitted.  Any distribution of this software or
derivative works must comply with all applicable United States export control
laws.

This software is made available AS IS, and Xerox Corporation makes no warranty
about the software, its performance or its conformity to any specification.

|<---            this code is formatted to fit into 80 columns             --->|
|<---            this code is formatted to fit into 80 columns             --->|
|<---            this code is formatted to fit into 80 columns             --->|


SpaceObject.java
Part of the Spacewar system.

*/

package spacewar;


/**
 * SpaceObjects are objects that float around in space.  They support the
 * minimal SpaceObject protocol, having to do with position, velocity,
 * size and liveness.  They are constructed with game, position, velocity
 * and size.  When constructed, a spaceobject adds itself to the registry.
 *
 * When it dies, a spaceobject removes itself from the registry.  But note
 * that it doesn't decide when to die, subclasses do that.
 *
 * The display aspects actually draw the space object on the screen and say
 * how much space it takes up there.
 */
abstract class SpaceObject {

    private Game    game;
    private double  xPos, yPos, oldXPos, oldYPos, xVel, yVel;
    private boolean alive;

    SpaceObject (Game theGame, double xP, double yP, double xV, double yV) {
        game = theGame;
        xPos = xP;
        yPos = yP;
        oldXPos = xP;
        oldYPos = yP;
        xVel = xV;
        yVel = yV;

        alive = true;
        getGame().getRegistry().register(this);
    }

    Game getGame()      { return game; }

    double getXPos()    { return xPos; }
    double getYPos()    { return yPos; }

    double getOldXPos() { return oldXPos; }
    double getOldYPos() { return oldYPos; }

    double getXVel()    { return xVel; }
    double getYVel()    { return yVel; }

    void setXVel (double n) { xVel = n; }
    void setYVel (double n) { yVel = n; }

    boolean isAlive()          { return alive; }
    void setIsAlive(boolean n) { alive = n; }


    /**
     * Move 1 unit of time's worth of distance.  I.e. increment xPos by xVel
     * and yPos by yVel.  If we move off an edge of the screen move us back
     * in the opposite edge.
     */
    void clockTick() {
        oldXPos = xPos;
        oldYPos = yPos;
        xPos = (xPos + xVel) % getGame().getWidth();
        if(xPos < 0)
            xPos += getGame().getWidth();
        yPos = (yPos + yVel) % getGame().getHeight();
        if(yPos < 0)
            yPos += getGame().getHeight();
    }

    void accelerate(double dXVel, double dYVel) {
        xVel += dXVel;
        yVel += dYVel;
    }

    void die() {
        getGame().getRegistry().unregister(this);
    }

    abstract int getSize();

    /** resolve the effects of colliding with a space object.
     *  @param obj the space object that this object is colliding with.
     */
    abstract void handleCollision(SpaceObject obj);
}