1
0
Fork 0

Boost de puissance

This commit is contained in:
MrDev023 2015-07-15 21:52:39 +02:00
parent 5ccf998834
commit 69577a9f6a
3 changed files with 83 additions and 29 deletions

View file

@ -16,6 +16,8 @@ public class Main {
private static final String TITLE = "Test VBO"; private static final String TITLE = "Test VBO";
private static final int width = 1280, height = 720; private static final int width = 1280, height = 720;
private static Thread[] threadArray;
private static Game game; private static Game game;
/** /**
@ -29,6 +31,7 @@ public class Main {
Display.setResizable(true); Display.setResizable(true);
Mouse.setGrabbed(true); Mouse.setGrabbed(true);
Display.create(); Display.create();
threadArray = new Thread[Runtime.getRuntime().availableProcessors()];
game = new Game(); game = new Game();
loop(); loop();
} catch (Exception e) { } catch (Exception e) {
@ -36,6 +39,19 @@ public class Main {
} }
} }
public static Thread addThread(Thread t){
for(Thread c : threadArray){
c = t;
try {
c.join();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
return t;
}
/** /**
* @Info Boucle principal avec Timer * @Info Boucle principal avec Timer
*/ */

View file

@ -6,12 +6,14 @@ import math.*;
public class Chunk { public class Chunk {
public final static int SIZE = 4; public final static int SIZE = 8;
private int x, y, z; private int x, y, z;
private VBO vbo; private VBO vbo;
private World world; private World world;
Block[][][] blocks; Block[][][] blocks;
private boolean IsLoad = false; private boolean IsLoad = false;
private boolean IsGenerated = false;
private boolean IsCurrentGenerate = false;
public Chunk(int x, int y, int z, World world) { public Chunk(int x, int y, int z, World world) {
this.x = x; this.x = x;
@ -32,21 +34,12 @@ public class Chunk {
public void createChunk(World world) { public void createChunk(World world) {
this.world = world; this.world = world;
for (int i = 0; i < SIZE; i++) {
for (int j = 0; j < 2; j++) { Main.addThread((new Thread(new Generate(this, world)))).start();
for (int k = 0; k < SIZE; k++) { IsCurrentGenerate = true;
blocks[i][j][k] = Block.GRASS;
}
}
}
for (int i = 0; i < SIZE; i++) {
for (int j = 0; j < 2; j++) {
for (int k = 0; k < SIZE; k++) {
loopChunk(i, j, k);
}
}
} }
public void loadBufferData() {
vbo.bufferData(); vbo.bufferData();
IsLoad = true; IsLoad = true;
} }
@ -256,6 +249,49 @@ public class Chunk {
return IsLoad; return IsLoad;
} }
public boolean isGenerated() {
return IsGenerated;
}
public void setGenerated(boolean g) {
IsGenerated = g;
}
public boolean isCurrentGenerate(){
return IsCurrentGenerate;
}
}
class Generate implements Runnable {
private Chunk chunk;
private World world;
public Generate(Chunk chunk, World world) {
this.chunk = chunk;
this.world = world;
}
public void run() {
for (int i = 0; i < chunk.SIZE; i++) {
for (int j = 0; j < 2; j++) {
for (int k = 0; k < chunk.SIZE; k++) {
chunk.blocks[i][j][k] = Block.GRASS;
}
}
}
synchronized (world.chunks) {
for (int i = 0; i < chunk.SIZE; i++) {
for (int j = 0; j < 2; j++) {
for (int k = 0; k < chunk.SIZE; k++) {
chunk.loopChunk(i, j, k);
}
}
}
}
chunk.setGenerated(true);
System.out.println(Thread.currentThread().getName());
Thread.currentThread().stop();
}
} }

View file

@ -11,7 +11,7 @@ public class World {
public long seed; public long seed;
public final int SIZE = 1,HEIGHT = 1; public final int SIZE = 1,HEIGHT = 1;
public static final float GRAVITY = 1; public static final float GRAVITY = 1;
public static final int VIEW_CHUNK = 2; public static final int VIEW_CHUNK = 4;
public ArrayList<Chunk> chunks = new ArrayList<Chunk>(); public ArrayList<Chunk> chunks = new ArrayList<Chunk>();
@ -34,16 +34,15 @@ public class World {
int za = (int)((Camera.getPosition().getZ()-((float)Chunk.SIZE/2.0f))/(float)Chunk.SIZE) - VIEW_CHUNK; int za = (int)((Camera.getPosition().getZ()-((float)Chunk.SIZE/2.0f))/(float)Chunk.SIZE) - VIEW_CHUNK;
int zb = (int)((Camera.getPosition().getZ()-((float)Chunk.SIZE/2.0f))/(float)Chunk.SIZE) + VIEW_CHUNK; int zb = (int)((Camera.getPosition().getZ()-((float)Chunk.SIZE/2.0f))/(float)Chunk.SIZE) + VIEW_CHUNK;
int delta_x = xb - xa; int delta_x = xb - xa;
int delta_z = zb - za; int delta_z = zb - za;
boolean isC = false;
for(int i = 0; i <= delta_x;i++){ for(int i = 0; i <= delta_x;i++){
for(int k = 0;k <= delta_z;k++){ for(int k = 0;k <= delta_z;k++){
for(int j = 0; j < HEIGHT; j++){ for(int j = 0; j < HEIGHT; j++){
if(getChunk((xa + i), 0, (za + k)) == null){ if(getChunk((xa + i), 0, (za + k)) == null){
Chunk ch = new Chunk((xa + i),j,(za + k),this); Chunk ch = new Chunk((xa + i),j,(za + k),this);
chunks.add(ch); chunks.add(ch);
isC = true;
} }
} }
} }
@ -57,7 +56,8 @@ public class World {
} }
} }
for(Chunk c : chunks){ for(Chunk c : chunks){
if(!c.isLoaded())c.createChunk(this); if(!c.isLoaded() && !c.isGenerated() && !c.isCurrentGenerate())c.createChunk(this);
if(!c.isLoaded() && c.isGenerated())c.loadBufferData();
c.update(); c.update();
} }
System.gc(); System.gc();
@ -72,7 +72,9 @@ public class World {
public Chunk getChunk(int xc, int yc, int zc) { public Chunk getChunk(int xc, int yc, int zc) {
Chunk c = null; Chunk c = null;
for(Chunk ch : chunks){ Object[] chunk = chunks.toArray();
for(int i = 0;i < chunk.length;i++){
Chunk ch = (Chunk)chunk[i];
if(ch.getX() == xc && ch.getY() == yc && ch.getZ() == zc){ if(ch.getX() == xc && ch.getY() == yc && ch.getZ() == zc){
c = ch; c = ch;
break; break;