Java-Gaming.org    
Featured games (78)
games approved by the League of Dukes
Games in Showcase (427)
Games in Android Showcase (89)
games submitted by our members
Games in WIP (466)
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 536 times)
0 Members and 1 Guest are viewing this topic.
Offline Best Username Ever

Junior Member





« Posted 2012-12-15 03: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  
 
 
You cannot reply to this message, because it is very, very old.

 

Add your game by posting it in the WIP section,
or publish it in Showcase.

The first screenshot will be displayed as a thumbnail.

xsi3rr4x (78 views)
2014-04-15 18:08:23

BurntPizza (70 views)
2014-04-15 03:46:01

UprightPath (81 views)
2014-04-14 17:39:50

UprightPath (66 views)
2014-04-14 17:35:47

Porlus (82 views)
2014-04-14 15:48:38

tom_mai78101 (106 views)
2014-04-10 04:04:31

BurntPizza (166 views)
2014-04-08 23:06:04

tom_mai78101 (262 views)
2014-04-05 13:34:39

trollwarrior1 (212 views)
2014-04-04 12:06:45

CJLetsGame (221 views)
2014-04-01 02:16:10
List of Learning Resources
by SHC
2014-04-18 03:17:39

List of Learning Resources
by Longarmx
2014-04-08 03:14:44

Good Examples
by matheus23
2014-04-05 13:51:37

Good Examples
by Grunnt
2014-04-03 15:48:46

Good Examples
by Grunnt
2014-04-03 15:48:37

Good Examples
by matheus23
2014-04-01 18:40:51

Good Examples
by matheus23
2014-04-01 18:40:34

Anonymous/Local/Inner class gotchas
by Roquen
2014-03-11 15:22:30
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!