package org.opencv.core; import java.util.Arrays; import java.util.List; public class MatOfPoint3 extends Mat { // 32SC3 private static final int _depth = CvType.CV_32S; private static final int _channels = 3; public MatOfPoint3() { super(); } protected MatOfPoint3(long addr) { super(addr); if( !empty() && checkVector(_channels, _depth) < 0 ) throw new IllegalArgumentException("Incompatible Mat"); //FIXME: do we need release() here? } public static MatOfPoint3 fromNativeAddr(long addr) { return new MatOfPoint3(addr); } public MatOfPoint3(Mat m) { super(m, Range.all()); if( !empty() && checkVector(_channels, _depth) < 0 ) throw new IllegalArgumentException("Incompatible Mat"); //FIXME: do we need release() here? } public MatOfPoint3(Point3...a) { super(); fromArray(a); } public void alloc(int elemNumber) { if(elemNumber>0) super.create(elemNumber, 1, CvType.makeType(_depth, _channels)); } public void fromArray(Point3...a) { if(a==null || a.length==0) return; int num = a.length; alloc(num); int buff[] = new int[num * _channels]; for(int i=0; i<num; i++) { Point3 p = a[i]; buff[_channels*i+0] = (int) p.x; buff[_channels*i+1] = (int) p.y; buff[_channels*i+2] = (int) p.z; } put(0, 0, buff); //TODO: check ret val! } public Point3[] toArray() { int num = (int) total(); Point3[] ap = new Point3[num]; if(num == 0) return ap; int buff[] = new int[num * _channels]; get(0, 0, buff); //TODO: check ret val! for(int i=0; i<num; i++) ap[i] = new Point3(buff[i*_channels], buff[i*_channels+1], buff[i*_channels+2]); return ap; } public void fromList(List<Point3> lp) { Point3 ap[] = lp.toArray(new Point3[0]); fromArray(ap); } public List<Point3> toList() { Point3[] ap = toArray(); return Arrays.asList(ap); } }