Mercurial > hg > jslab
annotate src/samer/j3d/MatrixPointArray.java @ 0:bf79fb79ee13
Initial Mercurial check in.
author | samer |
---|---|
date | Tue, 17 Jan 2012 17:50:20 +0000 |
parents | |
children |
rev | line source |
---|---|
samer@0 | 1 package samer.j3d; |
samer@0 | 2 |
samer@0 | 3 import samer.core.types.*; |
samer@0 | 4 import samer.maths.*; |
samer@0 | 5 import java.util.*; |
samer@0 | 6 import javax.media.j3d.*; |
samer@0 | 7 import javax.vecmath.*; |
samer@0 | 8 |
samer@0 | 9 |
samer@0 | 10 public class MatrixPointArray extends PointArray implements Observer |
samer@0 | 11 { |
samer@0 | 12 int N; // number of points |
samer@0 | 13 Matrix P; // 3d positions of points |
samer@0 | 14 VVector A; // scalar activations |
samer@0 | 15 VDouble K; // scaling factor for activations |
samer@0 | 16 |
samer@0 | 17 float carray[]; // array for holding colours |
samer@0 | 18 // Color3f carray[]; |
samer@0 | 19 |
samer@0 | 20 public MatrixPointArray(Matrix points, VVector activities) |
samer@0 | 21 { |
samer@0 | 22 super(points.getRowDimension(), COORDINATES | COLOR_3); |
samer@0 | 23 |
samer@0 | 24 N=points.getRowDimension(); |
samer@0 | 25 P=points; |
samer@0 | 26 A=activities; |
samer@0 | 27 K=new VDouble("scale",1); |
samer@0 | 28 |
samer@0 | 29 carray=new float[3*N]; |
samer@0 | 30 |
samer@0 | 31 // set capabilities for subsequent updates |
samer@0 | 32 setCapability(ALLOW_COORDINATE_WRITE); |
samer@0 | 33 setCapability(ALLOW_COLOR_WRITE); |
samer@0 | 34 |
samer@0 | 35 updatePoints(); |
samer@0 | 36 updateActivities(); |
samer@0 | 37 |
samer@0 | 38 A.addObserver(this); |
samer@0 | 39 P.addObserver(new Observer () { |
samer@0 | 40 public void update(Observable o, Object a) { |
samer@0 | 41 updatePoints(); |
samer@0 | 42 } |
samer@0 | 43 }); |
samer@0 | 44 } |
samer@0 | 45 |
samer@0 | 46 |
samer@0 | 47 public void update(Observable o, Object a) |
samer@0 | 48 { |
samer@0 | 49 updateActivities(); |
samer@0 | 50 } |
samer@0 | 51 |
samer@0 | 52 public void updatePoints() |
samer@0 | 53 { |
samer@0 | 54 // load points into point array |
samer@0 | 55 double [][] PA=P.getArray(); |
samer@0 | 56 double [] row; |
samer@0 | 57 for (int i=0; i<N; i++) { |
samer@0 | 58 row=PA[i]; |
samer@0 | 59 setCoordinate(i,row); |
samer@0 | 60 } |
samer@0 | 61 } |
samer@0 | 62 |
samer@0 | 63 public void updateActivities() |
samer@0 | 64 { |
samer@0 | 65 // load colours |
samer@0 | 66 double [] a=A.array(); |
samer@0 | 67 double k=K.value; |
samer@0 | 68 |
samer@0 | 69 for (int i=0, j=0; i<N; i++,j+=3) { |
samer@0 | 70 float ai=(float)(a[i]*k); |
samer@0 | 71 carray[j]=ai; |
samer@0 | 72 carray[j+1]=0.8f*ai; |
samer@0 | 73 carray[j+2]=0.4f*ai; |
samer@0 | 74 } |
samer@0 | 75 setColors(0,carray); |
samer@0 | 76 } |
samer@0 | 77 } |
samer@0 | 78 |