+++ /dev/null
-/*******************************************************************************\r
- * Copyright (c) 2007- VTT Technical Research Centre of Finland.\r
- * All rights reserved. This program and the accompanying materials\r
- * are made available under the terms of the Eclipse Public License v1.0\r
- * which accompanies this distribution, and is available at\r
- * http://www.eclipse.org/legal/epl-v10.html\r
- *\r
- * Contributors:\r
- * VTT Technical Research Centre of Finland - initial API and implementation\r
- *******************************************************************************/\r
-package org.simantics.proconf.g3d.gizmo;\r
-\r
-import javax.vecmath.Color4f;\r
-import javax.vecmath.Point3f;\r
-\r
-import com.jme.bounding.BoundingBox;\r
-import com.jme.renderer.Renderer;\r
-import com.jme.scene.TriMesh;\r
-import com.jme.scene.state.AlphaState;\r
-import com.jme.scene.state.MaterialState;\r
-import com.jme.scene.state.ZBufferState;\r
-import com.jme.util.geom.BufferUtils;\r
-\r
-\r
-\r
-public class RotateGizmo extends MultiSelectionGizmo {\r
-\r
- \r
- public static String PICK_NAME = "rotate";\r
- public static String X_NAME = "rx";\r
- public static String Y_NAME = "ry";\r
- public static String Z_NAME = "rz";\r
- public static String XYZ_NAME = "ra";\r
- \r
- public static final int X = 0;\r
- public static final int Y = 1;\r
- public static final int Z = 2;\r
- public static final int XYZ = 3;\r
- \r
-\r
- \r
- \r
- /* (non-Javadoc)\r
- * @see fi.vtt.proconf.shapeeditor.common.Gizmo#getPickPrefix()\r
- */\r
- public String getPickPrefix() {\r
- return PICK_NAME;\r
- }\r
- \r
- public int getIndexForName(String name) {\r
- if (!name.startsWith(PICK_NAME)) {\r
- return -1;\r
- }\r
- name = name.substring(PICK_NAME.length());\r
- if (name.startsWith(X_NAME))\r
- return X;\r
- if (name.startsWith(Y_NAME))\r
- return Y;\r
- if (name.startsWith(Z_NAME))\r
- return Z;\r
- if (name.startsWith(XYZ_NAME))\r
- return XYZ;\r
- return -1;\r
- }\r
- \r
-\r
- @Override\r
- public int getCount() {\r
- return 4;\r
- }\r
-\r
- public RotateGizmo(Renderer renderer) {\r
- super();\r
- float radius = 2.f;\r
- float radius2 = 1.8f;\r
- int div = 9;\r
- \r
- float x[] = new float[div+1];\r
- float y[] = new float[div+1];\r
- float x2[] = new float[div+1];\r
- float y2[] = new float[div+1];\r
- x[0] = radius;\r
- y[0] = 0.f;\r
- x[div] = 0.f;\r
- y[div] = radius;\r
- x2[0] = radius2;\r
- y2[0] = 0.f;\r
- x2[div] = 0.f;\r
- y2[div] = radius2;\r
- \r
- for (int i = 1; i < div; i++) {\r
- float angle = (float)i/(float)div;\r
- angle *= Math.PI * 0.5f;\r
- float c = (float)Math.cos(angle);\r
- float s = (float)Math.sin(angle);\r
- x[i] = radius * c;\r
- y[i] = radius * s;\r
- x2[i] = radius2 * c;\r
- y2[i] = radius2 * s;\r
-\r
- }\r
- \r
- Color4f colorx = new Color4f(0.5f,0.f,0.f,0.5f);\r
- Color4f colory = new Color4f(0.f,0.5f,0.f,0.5f);\r
- Color4f colorz = new Color4f(0.f,0.f,0.5f,0.5f);\r
- Color4f scolorx = new Color4f(1.f,0.f,0.f,0.7f);\r
- Color4f scolory = new Color4f(0.f,1.f,0.f,0.7f);\r
- Color4f scolorz = new Color4f(0.f,0.f,1.f,0.7f);\r
-\r
- \r
- Color4f colorxyz = new Color4f();\r
- colorxyz.x = colorx.x + colory.x + colorz.x;\r
- colorxyz.y = colorx.y + colory.y + colorz.y;\r
- colorxyz.z = colorx.z +colory.z + colorz.z;\r
- colorxyz.w = 0.5f;\r
- \r
- Color4f scolorxyz = new Color4f();\r
- scolorxyz.x = scolorx.x + scolory.x + scolorz.x;\r
- scolorxyz.y = scolorx.y + scolory.y + scolorz.y;\r
- scolorxyz.z = scolorx.z + scolory.z + scolorz.z;\r
- scolorxyz.w = 0.5f;\r
- \r
- int numVertices = div*2;\r
- float coordinates[] = new float[numVertices*3 + numVertices*3];\r
- float cols[] = new float[numVertices*4*2];\r
- int[] indices = new int[numVertices*3-6+numVertices*3 - 12];\r
- for (int i = 0; i < div; i++) {\r
- if (i == 0) {\r
- indices[0] = 0;\r
- indices[1] = 1;\r
- indices[2] = 2;\r
- continue;\r
- }\r
- int vIndex = i * 2 - 1;\r
- int index = i * 6 - 3;\r
- if (i == div - 1) {\r
- indices[index] = vIndex;\r
- indices[index+1] = vIndex+1;\r
- indices[index+2] = vIndex+2;\r
- \r
- } else {\r
- indices[index] = vIndex;\r
- indices[index+1] = vIndex+1;\r
- indices[index+2] = vIndex+2;\r
- indices[index+3] = vIndex+1;\r
- indices[index+4] = vIndex+3;\r
- indices[index+5] = vIndex+2;\r
- }\r
- }\r
- \r
- for (int i = div+1; i < div * 2 - 1; i++) {\r
- int vIndex = i * 2 - 1;\r
- int index = i * 6 - 12;\r
-\r
- indices[index] = vIndex;\r
- indices[index+1] = vIndex+1;\r
- indices[index+2] = vIndex+2;\r
- indices[index+3] = vIndex+1;\r
- indices[index+4] = vIndex+3;\r
- indices[index+5] = vIndex+2;\r
- }\r
- \r
- for (int i = 0; i < numVertices*2; i++)\r
- setColor(cols,i, colorx);\r
- \r
- setCoordinate(coordinates,0, new Point3f(0.f, x[0], 0.f));\r
- for (int i = 1; i < div; i++) {\r
- int index = i * 2 - 1;\r
- setCoordinate(coordinates,index,new Point3f(0.f,x[i],y[i]));\r
- setCoordinate(coordinates,index+1,new Point3f(y[1],x[i],y[i])); \r
- }\r
- setCoordinate(coordinates,numVertices - 1, new Point3f(0.f, 0.f, y[div]));\r
- \r
- setCoordinate(coordinates,numVertices, new Point3f(0.f, x2[0], 0.f));\r
- for (int i = 1; i < div; i++) {\r
- int index = (div+i) * 2 - 1;\r
- setCoordinate(coordinates,index,new Point3f(y[1],x[i],y[i]));\r
- setCoordinate(coordinates,index+1,new Point3f(y2[1],x2[i],y2[i])); \r
- }\r
- setCoordinate(coordinates,numVertices*2 - 1, new Point3f(0.f, 0.f, y2[div]));\r
- \r
- TriMesh linex = new TriMesh(PICK_NAME+X_NAME,BufferUtils.createFloatBuffer(coordinates),null,BufferUtils.createFloatBuffer(cols),null,BufferUtils.createIntBuffer(indices));\r
- \r
- \r
- for (int i = 0; i < numVertices*2; i++)\r
- setColor(cols,i, colory);\r
- \r
- setCoordinate(coordinates,0, new Point3f(x[0], 0.f, 0.f));\r
- for (int i = 1; i < div; i++) {\r
- int index = i * 2 - 1;\r
- setCoordinate(coordinates,index,new Point3f(x[i],0.f,y[i]));\r
- setCoordinate(coordinates,index+1,new Point3f(x[i],y[1],y[i])); \r
- }\r
- setCoordinate(coordinates,numVertices - 1, new Point3f(0.f, 0.f, y[div]));\r
- \r
- setCoordinate(coordinates,numVertices, new Point3f(x2[0], 0.f, 0.f));\r
- for (int i = 1; i < div; i++) {\r
- int index = (div+i) * 2 - 1;\r
- setCoordinate(coordinates,index,new Point3f(x[i],y[1],y[i]));\r
- setCoordinate(coordinates,index+1,new Point3f(x2[i],y2[1],y2[i])); \r
- }\r
- setCoordinate(coordinates,numVertices*2 - 1, new Point3f(0.f, 0.f, y2[div]));\r
-\r
- TriMesh liney = new TriMesh(PICK_NAME+Y_NAME,BufferUtils.createFloatBuffer(coordinates),null,BufferUtils.createFloatBuffer(cols),null,BufferUtils.createIntBuffer(indices));\r
- \r
- \r
- for (int i = 0; i < numVertices*2; i++)\r
- setColor(cols,i, colorz);\r
- \r
- setCoordinate(coordinates,0, new Point3f(0.f, x[0], 0.f));\r
- for (int i = 1; i < div; i++) {\r
- int index = i * 2 - 1;\r
- setCoordinate(coordinates,index,new Point3f(y[i],x[i],0.f));\r
- setCoordinate(coordinates,index+1,new Point3f(y[i],x[i],y[1])); \r
- }\r
- setCoordinate(coordinates,numVertices - 1, new Point3f(y[div],0.f, 0.f));\r
-\r
- setCoordinate(coordinates,numVertices, new Point3f(0.f, x2[0], 0.f));\r
- for (int i = 1; i < div; i++) {\r
- int index = (div+i) * 2 - 1;\r
- setCoordinate(coordinates,index,new Point3f(y[i],x[i],y[1]));\r
- setCoordinate(coordinates,index+1,new Point3f(y2[i],x2[i],y2[1])); \r
- }\r
- setCoordinate(coordinates,numVertices*2 - 1, new Point3f(y2[div],0.f, 0.f));\r
-\r
- TriMesh linez = new TriMesh(PICK_NAME+Z_NAME,BufferUtils.createFloatBuffer(coordinates),null,BufferUtils.createFloatBuffer(cols),null,BufferUtils.createIntBuffer(indices));\r
- \r
- \r
- numVertices = (div-2)*3+1;\r
- coordinates = new float[numVertices*3];\r
- cols = new float[numVertices*4];\r
- indices = new int[(div-2)*3*3];\r
- \r
- for (int i = 0; i < numVertices; i++)\r
- setColor(cols,i, colorxyz);\r
- float center = radius * 0.5f;//(float)Math.cos(Math.PI*0.25);\r
- setCoordinate(coordinates,0,new Point3f(center,center,center));\r
- for (int i = 1; i < div; i++) {\r
- int index = i;\r
- setCoordinate(coordinates,index,new Point3f(y2[1],x2[i],y2[i]));\r
- }\r
- for (int i = 1; i < div; i++) {\r
- int index = i + div-1 - 1;\r
- setCoordinate(coordinates,index,new Point3f(y2[i],y2[1],x2[i]));\r
- }\r
- for (int i = 1; i < div-1; i++) {\r
- int index = i + 2*(div-1) -2;\r
- setCoordinate(coordinates,index,new Point3f(x2[i],y2[i],y2[1]));\r
- }\r
- for (int i = 0; i < (div-2)*3; i++) {\r
- int index = i*3;\r
- int iindex = i+1;\r
- indices[index] = 0;\r
- indices[index+1] = iindex;\r
- indices[index+2] = iindex+1;\r
- if (iindex == (numVertices -1))\r
- indices[index+2] = 1;\r
- \r
- }\r
-\r
- TriMesh trianglexyz = new TriMesh(PICK_NAME+XYZ_NAME,BufferUtils.createFloatBuffer(coordinates),null,BufferUtils.createFloatBuffer(cols),null,BufferUtils.createIntBuffer(indices));\r
- \r
- \r
- getGizmoNode().attachChild(linex);\r
- getGizmoNode().attachChild(liney);\r
- getGizmoNode().attachChild(linez);\r
- getGizmoNode().attachChild(trianglexyz);\r
- getGizmoNode().setModelBound(new BoundingBox());\r
- getGizmoNode().updateModelBound();\r
- \r
- linex.getBatch(0).setCastsShadows(false);\r
- liney.getBatch(0).setCastsShadows(false);\r
- linez.getBatch(0).setCastsShadows(false);\r
- trianglexyz.getBatch(0).setCastsShadows(false);\r
- \r
- setGeometry(0,linex);\r
- setGeometry(1,liney);\r
- setGeometry(2,linez);\r
- setGeometry(3,trianglexyz);\r
- \r
- setColor(0,0,colorx);\r
- setColor(0,1,scolorx);\r
- setColor(1,0,colory);\r
- setColor(1,1,scolory);\r
- setColor(2,0,colorz);\r
- setColor(2,1,scolorz);\r
- setColor(3,0,colorxyz);\r
- setColor(3,1,scolorxyz);\r
- \r
- AlphaState as = renderer.createAlphaState();\r
- as.setBlendEnabled(true);\r
- as.setSrcFunction(AlphaState.DB_SRC_ALPHA);\r
- as.setDstFunction(AlphaState.DB_ONE_MINUS_SRC_ALPHA);\r
- as.setEnabled(true);\r
- getGizmoNode().setRenderState(as);\r
- MaterialState ms = renderer.createMaterialState();\r
- ms.setColorMaterial(MaterialState.CM_AMBIENT_AND_DIFFUSE);\r
- ms.setMaterialFace(MaterialState.MF_FRONT_AND_BACK);\r
- getGizmoNode().setRenderState(ms);\r
- ZBufferState zs = renderer.createZBufferState();\r
- zs.setFunction(ZBufferState.CF_ALWAYS);\r
- zs.setEnabled(true);\r
- getGizmoNode().setRenderState(zs);\r
- \r
- \r
- }\r
-\r
-}
\ No newline at end of file