* Fix inside view for Dome shape

git-svn-id: https://jmonkeyengine.googlecode.com/svn/trunk@8322 75d07b2b-3a1a-0410-a2c5-0572b91ccdca
3.0
sha..rd 13 years ago
parent adf65d648a
commit 5d5e0082a7
  1. 33
      engine/src/core/com/jme3/scene/shape/Dome.java

@ -282,21 +282,36 @@ public class Dome extends Mesh {
int bottomPlaneStart = ((plane - 1) * (radialSamples + 1)); int bottomPlaneStart = ((plane - 1) * (radialSamples + 1));
int topPlaneStart = (plane * (radialSamples + 1)); int topPlaneStart = (plane * (radialSamples + 1));
for (int sample = 0; sample < radialSamples; sample++, index += 6) { for (int sample = 0; sample < radialSamples; sample++, index += 6) {
ib.put((short) (bottomPlaneStart + sample)); if (insideView){
ib.put((short) (topPlaneStart + sample)); ib.put((short) (bottomPlaneStart + sample));
ib.put((short) (bottomPlaneStart + sample + 1)); ib.put((short) (bottomPlaneStart + sample + 1));
ib.put((short) (bottomPlaneStart + sample + 1)); ib.put((short) (topPlaneStart + sample));
ib.put((short) (topPlaneStart + sample)); ib.put((short) (bottomPlaneStart + sample + 1));
ib.put((short) (topPlaneStart + sample + 1)); ib.put((short) (topPlaneStart + sample + 1));
ib.put((short) (topPlaneStart + sample));
}else{
ib.put((short) (bottomPlaneStart + sample));
ib.put((short) (topPlaneStart + sample));
ib.put((short) (bottomPlaneStart + sample + 1));
ib.put((short) (bottomPlaneStart + sample + 1));
ib.put((short) (topPlaneStart + sample));
ib.put((short) (topPlaneStart + sample + 1));
}
} }
} }
// pole triangles // pole triangles
int bottomPlaneStart = (planes - 2) * (radialSamples + 1); int bottomPlaneStart = (planes - 2) * (radialSamples + 1);
for (int samples = 0; samples < radialSamples; samples++, index += 3) { for (int samples = 0; samples < radialSamples; samples++, index += 3) {
ib.put((short) (bottomPlaneStart + samples)); if (insideView){
ib.put((short) (vertCount - 1)); ib.put((short) (bottomPlaneStart + samples));
ib.put((short) (bottomPlaneStart + samples + 1)); ib.put((short) (bottomPlaneStart + samples + 1));
ib.put((short) (vertCount - 1));
}else{
ib.put((short) (bottomPlaneStart + samples));
ib.put((short) (vertCount - 1));
ib.put((short) (bottomPlaneStart + samples + 1));
}
} }
updateBound(); updateBound();

Loading…
Cancel
Save