《学习OpenCV》第八章轮廓课后题8.3
2017-12-06 20:20
477 查看
用CvSeq的函数创建圆和矩形,这两个图像用点序列来表示。
有关序列的读写方法可以自行学习,这里只给出一个示例
有关序列的读写方法可以自行学习,这里只给出一个示例
#include <iostream> #include <opencv2/opencv.hpp> #include <opencv2/highgui.hpp> using namespace std; using namespace cv; #define CVX_RED CV_RGB(0xff, 0x00, 0x00) #define CVX_GREEN CV_RGB(0x00, 0xff, 0x00) #define CVX_BLUE CV_RGB(0x00, 0x00, 0xff) void DrawBox(IplImage* img) { /*1、初始化相关变量*/ CvBox2D box ; CvPoint2D32f center; CvSize2D32f size; center.x = 50; center.y = 50; size.width = 30; size.height = 30; box.center = center; box.size = size; CvPoint2D32f point[4]; int i; for ( i=0; i<4; i++) { point[i].x = 0; point[i].y = 0; } /*2、计算CvBox2D结构表示矩形的4顶点*/ cvBoxPoints(box, point); //计算二维盒子顶点,把box的点赋值给point /*3、把float类型的点转化成int类型*/ CvPoint pt[4]; for ( i=0; i<4; i++) { pt[i].x = (int)point[i].x; pt[i].y = (int)point[i].y; } /*4、开辟一个内存管理器并创建一个序列*/ CvMemStorage* store = cvCreateMemStorage(0); CvSeq* seq = cvCreateSeq(CV_SEQ_ELTYPE_POINT | CV_SEQ_KIND_CURVE | CV_SEQ_FLAG_CLOSED,sizeof(CvContour),sizeof(CvPoint),store); /*5、数据的存储和提取*/ for (int j = 0; j < 4; j++) { cvSeqPush(seq,&pt[j]); } for (int j = 0; j < seq->total; j++) { CvPoint* p=(CvPoint*)cvGetSeqElem(seq,j); printf("p->x=%d,p->y=%d\n",p->x,p->y); } /*6、绘制图形*/ cvDrawContours(img,seq,CV_RGB(255,255,255),CV_RGB(255,255,255),1,3,8); cvShowImage("Box", img); cvReleaseMemStorage(&store); } void DrawCircle(IplImage* img) { /*1、开辟一个内存管理器并创建一个序列*/ CvMemStorage* store = cvCreateMemStorage(0); CvSeq* seq = cvCreateSeq(CV_SEQ_ELTYPE_POINT | CV_SEQ_KIND_CURVE |CV_SEQ_FLAG_CLOSED,sizeof(CvContour),sizeof(CvPoint),store); /*2、绘制圆*/ CvPoint pt; for(int x=25; x<25+50; x++) { float y = 50 + sqrt(25*25.0-(x-50)*(x-50)); pt.x = x; pt.y = y; cvSeqPush(seq,&pt); } for(int x=25+50; x>25; x--) { float y = 50 - sqrt(25*25.0-(x-50)*(x-50)); pt.x = x; pt.y = y; cvSeqPush(seq,&pt); } for (int j = 0; j < seq->total; j++) { CvPoint* p=(CvPoint*)cvGetSeqElem(seq,j); printf("p->x=%d,p->y=%d\n",p->x,p->y); } cvDrawContours(img,seq,CV_RGB(255,255,255),CV_RGB(255,255,255),1,3,8); cvShowImage("Circle", img); cvReleaseMemStorage(&store); } int main() { /*1、申请内存、创建一个图片、*/ CvMemStorage* storage = cvCreateMemStorage(); IplImage* img = cvCreateImage(cvSize(200,200),8,3); cvZero(img); cvShowImage("img", img); /*2、绘制矩形*/ DrawBox(img); cvSetZero(img); /*3、绘制圆*/ DrawCircle(img); cvWaitKey(100000); cvReleaseImage(&img); cvReleaseMemStorage(&storage); return 1; }
相关文章推荐
- 《学习OpenCV》第八章轮廓课后题
- 算法概论第八章课后题--8.3
- 算法概论第八章课后习题8.3
- 算法概论 第八章课后题8.3
- 《学习OpenCV》第三章课后题3
- 学习OpenCV课后题3.1
- 《学习OpenCV》第五章课后题2
- 《学习OpenCV》课后习题解答2
- 《学习OpenCV》课后习题解答6
- 15算法课程 课后习题8.3
- 【第八章】 对ORM的支持 之 8.3 集成iBATIS ——跟我学spring3
- 第八章 线性时间排序 8.3 基数排序
- C++primer第八章课后变成练习的小问题
- 【第八章】 对ORM的支持 之 8.3 集成iBATIS ——跟我学spring3
- 《学习OpenCV》第三章课后题5
- 《学习OpenCV》课后习题解答2
- Python课后习题-第八章 读写文件
- 【第八章】 对ORM的支持 之 8.3 集成iBATIS ——跟我学spring3
- 机器学习(周志华) 参考答案 第八章 集成学习 8.3
- Java语言程序设计基础篇 第八章 课后编程答案