home *** CD-ROM | disk | FTP | other *** search
/ PC Pro 1999 April / DPPCPRO0499.ISO / April / Notes / 50b2wic.exe / DATA1.CAB / NotesProgramFilesJavaSupport / rt.jar / java / awt / Polygon.class (.txt) < prev    next >
Encoding:
Java Class File  |  1998-04-23  |  2.5 KB  |  146 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.    private static final long serialVersionUID = -6460061437900069969L;
  11.  
  12.    public Polygon() {
  13.    }
  14.  
  15.    public Polygon(int[] var1, int[] var2, int var3) {
  16.       this.npoints = var3;
  17.       this.xpoints = new int[var3];
  18.       this.ypoints = new int[var3];
  19.       System.arraycopy(var1, 0, this.xpoints, 0, var3);
  20.       System.arraycopy(var2, 0, this.ypoints, 0, var3);
  21.    }
  22.  
  23.    public void translate(int var1, int var2) {
  24.       for(int var3 = 0; var3 < this.npoints; ++var3) {
  25.          int[] var10000 = this.xpoints;
  26.          var10000[var3] += var1;
  27.          var10000 = this.ypoints;
  28.          var10000[var3] += var2;
  29.       }
  30.  
  31.       if (this.bounds != null) {
  32.          this.bounds.translate(var1, var2);
  33.       }
  34.  
  35.    }
  36.  
  37.    void calculateBounds(int[] var1, int[] var2, int var3) {
  38.       int var4 = Integer.MAX_VALUE;
  39.       int var5 = Integer.MAX_VALUE;
  40.       int var6 = Integer.MIN_VALUE;
  41.       int var7 = Integer.MIN_VALUE;
  42.  
  43.       for(int var8 = 0; var8 < var3; ++var8) {
  44.          int var9 = var1[var8];
  45.          var4 = Math.min(var4, var9);
  46.          var6 = Math.max(var6, var9);
  47.          int var10 = var2[var8];
  48.          var5 = Math.min(var5, var10);
  49.          var7 = Math.max(var7, var10);
  50.       }
  51.  
  52.       this.bounds = new Rectangle(var4, var5, var6 - var4, var7 - var5);
  53.    }
  54.  
  55.    void updateBounds(int var1, int var2) {
  56.       this.bounds.x = Math.min(this.bounds.x, var1);
  57.       this.bounds.width = Math.max(this.bounds.width, var1 - this.bounds.x);
  58.       this.bounds.y = Math.min(this.bounds.y, var2);
  59.       this.bounds.height = Math.max(this.bounds.height, var2 - this.bounds.y);
  60.    }
  61.  
  62.    public void addPoint(int var1, int var2) {
  63.       if (this.npoints == this.xpoints.length) {
  64.          int[] var3 = new int[this.npoints * 2];
  65.          System.arraycopy(this.xpoints, 0, var3, 0, this.npoints);
  66.          this.xpoints = var3;
  67.          var3 = new int[this.npoints * 2];
  68.          System.arraycopy(this.ypoints, 0, var3, 0, this.npoints);
  69.          this.ypoints = var3;
  70.       }
  71.  
  72.       this.xpoints[this.npoints] = var1;
  73.       this.ypoints[this.npoints] = var2;
  74.       ++this.npoints;
  75.       if (this.bounds != null) {
  76.          this.updateBounds(var1, var2);
  77.       }
  78.  
  79.    }
  80.  
  81.    public Rectangle getBounds() {
  82.       return this.getBoundingBox();
  83.    }
  84.  
  85.    /** @deprecated */
  86.    public Rectangle getBoundingBox() {
  87.       if (this.bounds == null) {
  88.          this.calculateBounds(this.xpoints, this.ypoints, this.npoints);
  89.       }
  90.  
  91.       return this.bounds;
  92.    }
  93.  
  94.    public boolean contains(Point var1) {
  95.       return this.contains(var1.x, var1.y);
  96.    }
  97.  
  98.    public boolean contains(int var1, int var2) {
  99.       return this.inside(var1, var2);
  100.    }
  101.  
  102.    /** @deprecated */
  103.    public boolean inside(int var1, int var2) {
  104.       if (!this.getBoundingBox().inside(var1, var2)) {
  105.          return false;
  106.       } else {
  107.          int var3 = 0;
  108.          int var4 = 0;
  109.  
  110.          int var5;
  111.          for(var5 = 0; var5 < this.npoints && this.ypoints[var5] == var2; ++var5) {
  112.          }
  113.  
  114.          for(int var6 = 0; var6 < this.npoints; ++var6) {
  115.             int var7 = (var5 + 1) % this.npoints;
  116.             int var8 = this.xpoints[var7] - this.xpoints[var5];
  117.             int var9 = this.ypoints[var7] - this.ypoints[var5];
  118.             if (var9 != 0) {
  119.                int var10 = var1 - this.xpoints[var5];
  120.                int var11 = var2 - this.ypoints[var5];
  121.                if (this.ypoints[var7] == var2 && this.xpoints[var7] >= var1) {
  122.                   var4 = this.ypoints[var5];
  123.                }
  124.  
  125.                if (this.ypoints[var5] == var2 && this.xpoints[var5] >= var1 && var4 > var2 != this.ypoints[var7] > var2) {
  126.                   --var3;
  127.                }
  128.  
  129.                float var12 = (float)var11 / (float)var9;
  130.                if ((double)var12 >= (double)0.0F && (double)var12 <= (double)1.0F && var12 * (float)var8 >= (float)var10) {
  131.                   ++var3;
  132.                }
  133.             }
  134.  
  135.             var5 = var7;
  136.          }
  137.  
  138.          if (var3 % 2 == 0) {
  139.             return false;
  140.          } else {
  141.             return true;
  142.          }
  143.       }
  144.    }
  145. }
  146.