由于OpenCV的java版本画图有太多错误,只能自己编写画图的代码,在一个函数中,编写出画圆和深度距离的代码,

代码如下:

public int CircleMyMat(Mat Show, Point3 Center, double Radius, Scalar COLOR ,int Width)
{
//请空画布为白色
Show = Mat.zeros(Show.size(), CvType.CV_8UC3);
//Core.bitwise_not(Show, Show);//反色! double[] C= Show.get(0, 0);
C[0]= 0;C[1]= 0;C[2]= 255;//C[0]= 0;C[1]= 0;C[2]= 0; //1.获取圈的值//画出圆!
int CenterX = (int) Center.x;
int CenterY = (int) Center.y;
int R = (int)Radius;
List<Point3 > CirclePoints = new LinkedList<Point3 >();
//得到圆上点的值!
int MaxX= CenterX + (int)R;
int MinX= CenterX - (int)R; int i =0; int X =0; int Y =0;
for(i = 0-R; i<R ;++i){
Point3 PointIn= new Point3();
PointIn.x = i + CenterX ;
PointIn.y = Math.sqrt( Math.abs(R*R - i*i) );//这个公式ZTMD关键!
PointIn.y = CenterY + PointIn.y ;
CirclePoints.add(PointIn);
}
//取下半部分!
for(i = 0-R; i<R ;++i){
Point3 PointIn= new Point3();
PointIn.x = i + CenterX ;
PointIn.y = Math.sqrt( Math.abs(R*R - i*i) );//这个公式ZTMD关键!
PointIn.y = CenterY - PointIn.y ;
PointIn.z = 1;
CirclePoints.add(PointIn);
} //2.获取Z值//画在右方如何?//固定缩放系数//保证不要跑出边界!
int CenterZ = (int) Center.z;
int Zl = CenterZ;//Zl直接作为长度被使用! //2.2 。画出一条线来!
Point ttt0 = new Point();
Point ttt1 = new Point();
ttt0.x = CenterX;
ttt0.y = CenterY;
ttt1.x = CenterX + Zl;//ttt1.x = CenterX + 20;//
ttt1.y = CenterY;
lineMyMat(Show, ttt0, ttt1, COLOR ,Width); //3.画出圈来!//在此调整粗细!
double[] P;
int Idx =0;
for( Idx=0; Idx< CirclePoints.size(); ++Idx)
{
P= C;
X= (int )CirclePoints.get(Idx).x;
Y= (int )CirclePoints.get(Idx).y;
Show.put(Y,X, P);//frameRf.put(Y, X, P);
++X;++Y;
Show.put( Y, X, C);
++X;++Y;
Show.put( Y, X, C);
} return 1;
}

出现了无法画图的问题,总是找不到原因。

最后,把

Show = Mat.zeros(Show.size(), CvType.CV_8UC3);

注销掉,程序可以运行了。

原因到底是什么,一时难以理解......................

关于OpenCV的Mat画图问题的更多相关文章

  1. OpenCV4Android——No implementation found for native Lorg/opencv/core/Mat;.n_Mat ()J

    ok 12-17 08:13:10.461: W/dalvikvm(540): No implementation found for native Lorg/opencv/core/Mat;.n_M ...

  2. opencv数据结构-MAT结构详解

    1.定义 OpenCV中的C结构体有 CvMat 和 CvMatND,但后续的应用中指出 CvMat 和 CvMatND 弃用了,在C++封装中用 Mat 代替,另外旧版还有一个 IplImage,同 ...

  3. OpenCV中Mat的列向量归一化

    OpenCV中Mat的列向量归一化 http://blog.csdn.net/shaoxiaohu1/article/details/8287528 OpenCV中Mat的列向量归一化 标签: Ope ...

  4. OpenCV中Mat总结

    一.数字图像存储概述 数字图像存储时,我们存储的是图像每个像素点的数值,对应的是一个数字矩阵. 二.Mat的存储 1.OpenCV1基于C接口定义的图像存储格式IplImage*,直接暴露内存,如果忘 ...

  5. OpenCV中Mat的使用

    一.数字图像存储概述 数字图像存储时,我们存储的是图像每个像素点的数值,对应的是一个数字矩阵. 二.Mat的存储 1.OpenCV1基于C接口定义的图像存储格式IplImage*,直接暴露内存,如果忘 ...

  6. java.lang.UnsatisfiedLinkError: No implementation found for long org.opencv.core.Mat.n_Mat()

    Android调试openCV4Android的时候出现以下错误 java.lang.UnsatisfiedLinkError: No implementation found for long or ...

  7. Opencv中Mat矩阵相乘——点乘、dot、mul运算详解

    Opencv中Mat矩阵相乘——点乘.dot.mul运算详解 2016年09月02日 00:00:36 -牧野- 阅读数:59593 标签: Opencv矩阵相乘点乘dotmul 更多 个人分类: O ...

  8. opencv中mat类介绍

    The class Mat represents an n-dimensional dense numerical single-channel or multi-channel array. It ...

  9. opencv之Mat数据类型

    data:Mat对象中的一个指针,指向内存中存放矩阵数据的一块内存 (uchar* data) dims:Mat所代表的矩阵的维度,如 3 * 4 的矩阵为 2 维, 3 * 4 * 5 的为3维 c ...

随机推荐

  1. 【codeforces 515A】Drazil and Date

    [题目链接]:http://codeforces.com/contest/515/problem/A [题意] 每次只能走到相邻的四个格子中的一个; 告诉你最后走到了(a,b)走了多少步->s ...

  2. 【LeetCode Weekly Contest 26 Q2】Longest Uncommon Subsequence II

    [题目链接]:https://leetcode.com/contest/leetcode-weekly-contest-26/problems/longest-uncommon-subsequence ...

  3. CodeForcesGym 100735B Retrospective Sequence

    Retrospective Sequence Time Limit: Unknown ms Memory Limit: 65536KB This problem will be judged on C ...

  4. 玲珑杯1147 - 最后你还是AK了

    1147 - 最后你还是AK了 Time Limit:5s Memory Limit:256MByte DESCRIPTION 今天HHHH遇到了一颗树,这个树有nn个点(nn为偶数),每条边都有一个 ...

  5. sicily 10330. Cutting Sausages

    #include<stdio.h> int main() {    int n,m,j,k;    while(scanf("%d%d",&n,&m)! ...

  6. P1331 海战 洛谷

    题目描述 在峰会期间,武装部队得处于高度戒备.警察将监视每一条大街,军队将保卫建筑物,领空将布满了F-2003飞机.此外,巡洋船只和舰队将被派去保护海岸线.不幸的是因为种种原因,国防海军部仅有很少的几 ...

  7. F1: A Distributed SQL Database That Scales GOOGLE F1 论文

    http://research.google.com/pubs/pub41344.html http://research.google.com/pubs/pub36726.html

  8. Two Heads Are Often Better Than One

    Two Heads Are Often Better Than One Adrian Wible PROGRAMMING REQUIRES DEEP THOUGHT, and deep thought ...

  9. springmvc 解析xml数据

    springmvc 解析xml数据 http://blog.csdn.net/zhi_jun/article/details/37925475

  10. 游戏人生(一),我的lua之旅:那些坑爹的CCBReaderLoad

    首先,我们说说这个CCBReaderLoad. 这个脚本是cocos2dx自带的一个lua+cocosbuilder 的工具,详细功能呐,往下看. 先来看下我遇到的一个问题: ----美工给了我一个. ...