home *** CD-ROM | disk | FTP | other *** search
/ Dynamic HTML Construction Kit / Dynamic HTML Construction Kit.iso / earthlink / nscomm / java40.jar / java / awt / Polygon.class (.txt) < prev    next >
Encoding:
Java Class File  |  1997-11-03  |  1.9 KB  |  143 lines

  1. package java.awt;
  2.  
  3. import java.io.Serializable;
  4.  
  5. public class Polygon implements Shape, Serializable {
  6.    public int npoints;
  7.    public int[] xpoints = new int[4];
  8.    public int[] ypoints = new int[4];
  9.    protected Rectangle bounds;
  10.  
  11.    public Polygon() {
  12.    }
  13.  
  14.    public Polygon(int[] var1, int[] var2, int var3) {
  15.       this.npoints = var3;
  16.       this.xpoints = new int[var3];
  17.       this.ypoints = new int[var3];
  18.       System.arraycopy(var1, 0, this.xpoints, 0, var3);
  19.       System.arraycopy(var2, 0, this.ypoints, 0, var3);
  20.    }
  21.  
  22.    public void translate(int var1, int var2) {
  23.       for(int var3 = 0; var3 < this.npoints; ++var3) {
  24.          int[] var10000 = this.xpoints;
  25.          var10000[var3] += var1;
  26.          var10000 = this.ypoints;
  27.          var10000[var3] += var2;
  28.       }
  29.  
  30.       if (this.bounds != null) {
  31.          this.bounds.translate(var1, var2);
  32.       }
  33.  
  34.    }
  35.  
  36.    void calculateBounds(int[] var1, int[] var2, int var3) {
  37.       int var4 = Integer.MAX_VALUE;
  38.       int var5 = Integer.MAX_VALUE;
  39.       int var6 = Integer.MIN_VALUE;
  40.       int var7 = Integer.MIN_VALUE;
  41.  
  42.       for(int var8 = 0; var8 < var3; ++var8) {
  43.          int var9 = var1[var8];
  44.          var4 = Math.min(var4, var9);
  45.          var6 = Math.max(var6, var9);
  46.          int var10 = var2[var8];
  47.          var5 = Math.min(var5, var10);
  48.          var7 = Math.max(var7, var10);
  49.       }
  50.  
  51.       this.bounds = new Rectangle(var4, var5, var6 - var4, var7 - var5);
  52.    }
  53.  
  54.    void updateBounds(int var1, int var2) {
  55.       this.bounds.x = Math.min(this.bounds.x, var1);
  56.       this.bounds.width = Math.max(this.bounds.width, var1 - this.bounds.x);
  57.       this.bounds.y = Math.min(this.bounds.y, var2);
  58.       this.bounds.height = Math.max(this.bounds.height, var2 - this.bounds.y);
  59.    }
  60.  
  61.    public void addPoint(int var1, int var2) {
  62.       if (this.npoints == this.xpoints.length) {
  63.          int[] var3 = new int[this.npoints * 2];
  64.          System.arraycopy(this.xpoints, 0, var3, 0, this.npoints);
  65.          this.xpoints = var3;
  66.          var3 = new int[this.npoints * 2];
  67.          System.arraycopy(this.ypoints, 0, var3, 0, this.npoints);
  68.          this.ypoints = var3;
  69.       }
  70.  
  71.       this.xpoints[this.npoints] = var1;
  72.       this.ypoints[this.npoints] = var2;
  73.       ++this.npoints;
  74.       if (this.bounds != null) {
  75.          this.updateBounds(var1, var2);
  76.       }
  77.  
  78.    }
  79.  
  80.    public Rectangle getBounds() {
  81.       return this.getBoundingBox();
  82.    }
  83.  
  84.    public Rectangle getBoundingBox() {
  85.       if (this.bounds == null) {
  86.          this.calculateBounds(this.xpoints, this.ypoints, this.npoints);
  87.       }
  88.  
  89.       return this.bounds;
  90.    }
  91.  
  92.    public boolean contains(Point var1) {
  93.       return this.contains(var1.x, var1.y);
  94.    }
  95.  
  96.    public boolean contains(int var1, int var2) {
  97.       return this.inside(var1, var2);
  98.    }
  99.  
  100.    public boolean inside(int var1, int var2) {
  101.       if (!this.getBoundingBox().inside(var1, var2)) {
  102.          return false;
  103.       } else {
  104.          int var3 = 0;
  105.          int var4 = 0;
  106.  
  107.          int var5;
  108.          for(var5 = 0; var5 < this.npoints && this.ypoints[var5] == var2; ++var5) {
  109.          }
  110.  
  111.          for(int var6 = 0; var6 < this.npoints; ++var6) {
  112.             int var7 = (var5 + 1) % this.npoints;
  113.             int var8 = this.xpoints[var7] - this.xpoints[var5];
  114.             int var9 = this.ypoints[var7] - this.ypoints[var5];
  115.             if (var9 != 0) {
  116.                int var10 = var1 - this.xpoints[var5];
  117.                int var11 = var2 - this.ypoints[var5];
  118.                if (this.ypoints[var7] == var2 && this.xpoints[var7] >= var1) {
  119.                   var4 = this.ypoints[var5];
  120.                }
  121.  
  122.                if (this.ypoints[var5] == var2 && this.xpoints[var5] >= var1 && var4 > var2 != this.ypoints[var7] > var2) {
  123.                   --var3;
  124.                }
  125.  
  126.                float var12 = (float)var11 / (float)var9;
  127.                if ((double)var12 >= (double)0.0F && (double)var12 <= (double)1.0F && var12 * (float)var8 >= (float)var10) {
  128.                   ++var3;
  129.                }
  130.             }
  131.  
  132.             var5 = var7;
  133.          }
  134.  
  135.          if (var3 % 2 == 0) {
  136.             return false;
  137.          } else {
  138.             return true;
  139.          }
  140.       }
  141.    }
  142. }
  143.