Boost de puissance
This commit is contained in:
parent
5ccf998834
commit
69577a9f6a
3 changed files with 83 additions and 29 deletions
|
@ -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
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -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();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Reference in a new issue