Java-Gaming.org Hi !
Featured games (90)
games approved by the League of Dukes
Games in Showcase (773)
Games in Android Showcase (230)
games submitted by our members
Games in WIP (856)
games currently in development
News: Read the Java Gaming Resources, or peek at the official Java tutorials
 
    Home     Help   Search   Login   Register   
Pages: [1]
  ignore  |  Print  
  PointList  (Read 1420 times)
0 Members and 1 Guest are viewing this topic.
Offline Best Username Ever

Junior Devvie





« Posted 2012-12-15 02:46:18 »

A 2D point list holder object thing. Why? I want to post it on the wiki, as trivial as it is, with a bunch of other less trivial examples.
I also want to make sure it's bug free. I've used most of the code in my own projects. I marked the methods I added that others will expect but haven't tested myself.

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  
107  
108  
109  
110  
import java.util.Arrays;

public class PointList
{
  private int coords[];
  private int size;
 
  public PointList()
  {
    this(100);
  }

  public PointList(int capacity)
  {
    coords = new int[capacity * 2];
    size = 0;
  }

  public int getX(int i)
  {
    return coords[0 + 2 * i];
  }
 
  public int getY(int i)
  {
    return coords[1 + 2 * i];
  }
 
  public int getSize()
  {
    return size;
  }
 
  public int getCapacity()
  {
    return coords.length / 2;
  }

  public void add(int x, int y)
  {
    if(size * 2 == coords.length) { expand(); }
    coords[0 + 2 * size] = x;
    coords[1 + 2 * size] = y;
    size++;
  }

+ public void add(int index, int x, int y)
+ {
+   if(index < 0 || index > size + 2)
+   {
+     throw new IndexOutOfBoundsException();
+   }
+   if(size * 2 == coords.length) { expand(); }
+   System.arraycopy(coords, index * 2, coords, index * 2 + 2, 2 * (size - index));
+   coords[0 + 2 * index] = x;
+   coords[1 + 2 * index] = y;
+   size++;
+ }

  public void clear()
  {
    size = 0;
  }

  public void setCapacity(int c)
  {
    if(c < size) { c = size; }
    if(c < 1) { c = 1; }
    coords = Arrays.copyOf(coords, c * 2);
  }

  protected void expand()
  {
    coords = Arrays.copyOf(coords, coords.length + 100);
  }

+ public void ensureCapacity(int c)
+ {
+    if(coords.length * 2 < c)
+    {
+      setCapacity(c);
+    }
+ }

+ public void add(PointList other)
+ {
+   ensureCapacity(size + other.size);
+   System.arraycopy(other.coords, 0, coords, size * 2, other.size * 2);
+ }

+ public PointList copyRange(int start, int length)
+ {
+   PointList temp = new PointList(length);
+   System.arraycopy(coords, 0, temp.coords, 0, (length > size ? size : length) * 2);
+   return temp
+ }
 
+ public void remove(int index)
+ {
+   if(index < 0 || index > size)
+   {
+     throw new IndexOutOfBoundsException();
+   }
+   if(size > 1)
+   {
+     System.arraycopy(coords, index * 2 + 2, coords, index * 2, 2 * (size - index));
+   }
+   size--;
+ }
}


It's surprising how frequently I exclude a remove method. Smiley
Pages: [1]
  ignore  |  Print  
 
 

 
EgonOlsen (1850 views)
2018-06-10 19:43:48

EgonOlsen (1879 views)
2018-06-10 19:43:44

EgonOlsen (1245 views)
2018-06-10 19:43:20

DesertCoockie (1680 views)
2018-05-13 18:23:11

nelsongames (1345 views)
2018-04-24 18:15:36

nelsongames (1963 views)
2018-04-24 18:14:32

ivj94 (2736 views)
2018-03-24 14:47:39

ivj94 (1938 views)
2018-03-24 14:46:31

ivj94 (3029 views)
2018-03-24 14:43:53

Solater (1078 views)
2018-03-17 05:04:08
Deployment and Packaging
by mudlee
2018-08-22 18:09:50

Java Gaming Resources
by gouessej
2018-08-22 08:19:41

Deployment and Packaging
by gouessej
2018-08-22 08:04:08

Deployment and Packaging
by gouessej
2018-08-22 08:03:45

Deployment and Packaging
by philfrei
2018-08-20 02:33:38

Deployment and Packaging
by philfrei
2018-08-20 02:29:55

Deployment and Packaging
by philfrei
2018-08-19 23:56:20

Deployment and Packaging
by philfrei
2018-08-19 23:54:46
java-gaming.org is not responsible for the content posted by its members, including references to external websites, and other references that may or may not have a relation with our primarily gaming and game production oriented community. inquiries and complaints can be sent via email to the info‑account of the company managing the website of java‑gaming.org
Powered by MySQL Powered by PHP Powered by SMF 1.1.18 | SMF © 2013, Simple Machines | Managed by Enhanced Four Valid XHTML 1.0! Valid CSS!