题目:(P105)

创建一个结构,结构中包含一个整数,一个CvPoint和一个 CvRect;称结构体为“my_struct”。

a. 写两个函数:void Write_my_strct(CvFileStorage* fs, const char * name, my_struct* ms) 和 void read_my_struct(CvFileStorage* fs, CvFileNode* ms_node, my_struct* ms)

b. 创建一个元素为my_struct结构体且长度为10的数组,并将数组写入磁盘和从磁盘读入内存。

解答:

#include<cv.h>
#include<highgui.h> typedef struct my_struct {
int integer;
CvPoint ptr;
CvRect rect;
}my_struct; void write_my_struct(CvFileStorage* fs, const char* name, my_struct* ms) {
cvWriteInt(fs, "integer", ms[0].integer); cvStartWriteStruct(fs, "ptr", CV_NODE_SEQ);
cvWriteInt(fs, NULL, ms[0].ptr.x);
cvWriteInt(fs, NULL, ms[0].ptr.y);
cvEndWriteStruct(fs); cvStartWriteStruct(fs, "rect", CV_NODE_SEQ);
cvWriteInt(fs, NULL, ms[0].rect.x);
cvWriteInt(fs, NULL, ms[0].rect.y);
cvWriteInt(fs, NULL, ms[0].rect.width);
cvWriteInt(fs, NULL, ms[0].rect.height);
cvEndWriteStruct(fs);
} void read_my_struct(CvFileStorage* fs, CvFileNode* ms_node, my_struct* ms) {
int integer = cvReadIntByName(fs, NULL, "integer", 5);
CvSeq* seq = cvGetFileNodeByName(fs, NULL, "ptr")->data.seq;
int ptr_x = cvReadInt((CvFileNode*)cvGetSeqElem(seq, 0));
int ptr_y = cvReadInt((CvFileNode*)cvGetSeqElem(seq, 1));
seq = cvGetFileNodeByName(fs, NULL, "rect")->data.seq;
int rect_x = cvReadInt((CvFileNode*)cvGetSeqElem(seq, 0));
int rect_y = cvReadInt((CvFileNode*)cvGetSeqElem(seq, 1));
int rect_width = cvReadInt((CvFileNode*)cvGetSeqElem(seq, 2));
int rect_height = cvReadInt((CvFileNode*)cvGetSeqElem(seq, 3));
CvPoint ptr = cvPoint(ptr_x, ptr_y);
CvRect rect = cvRect(rect_x, rect_y, rect_width, rect_height);
ms->integer = integer;
ms->ptr.x = ptr_x;
ms->ptr.y = ptr_y;
ms->rect.x = rect_x;
ms->rect.y = rect_y;
ms->rect.width = rect_width;
ms->rect.height = rect_height;
} int main(int argc, char** argv) {
my_struct ms[10] = { { 10, cvPoint(5, 5), cvRect(5, 5, 10, 10) } };
CvFileStorage* sfs = cvOpenFileStorage("E:\\cfg.xml", NULL, CV_STORAGE_WRITE);
write_my_struct(sfs, "struct", ms);
cvReleaseFileStorage(&sfs); my_struct* ms2 = (my_struct*)malloc(sizeof(my_struct));
CvFileStorage* ofs = cvOpenFileStorage("E:\\cfg.xml", NULL, CV_STORAGE_READ);
read_my_struct(ofs, NULL, ms2);
cvReleaseFileStorage(&ofs); printf("integer: %d\n", ms2->integer);
printf("ptr: (%d, %d) \n", ms->ptr.x, ms->ptr.y);
printf("rect: (%d, %d, %d, %d) \n", ms->rect.x, ms->rect.y, ms->rect.width, ms->rect.height);
getchar();
return 0;
}

《学习OpenCV》课后习题解答7的更多相关文章

  1. 機器學習基石(Machine Learning Foundations) 机器学习基石 作业三 课后习题解答

    今天和大家分享coursera-NTU-機器學習基石(Machine Learning Foundations)-作业三的习题解答.笔者在做这些题目时遇到非常多困难,当我在网上寻找答案时却找不到,而林 ...

  2. 《学习OpenCV》课后习题解答8

    题目:(P126) 本章完整讲述了基本的输入/输出编程以及OpenCV的数据结构.下面的练习是基于前面的知识做一些应用,为后面大程序的实现提供帮助. a.创建一个程序实现以下功能:(1)从视频文件中读 ...

  3. 《学习OpenCV》课后习题解答6

    题目:(P104) 使用cvCmp()创建一个掩码.加载一个真实的图像.使用cvsplit()将图像分割成红,绿,蓝三个单通道图像. a.找到并显示绿图. b.克隆这个绿图两次(分别命名为clone1 ...

  4. 《学习OpenCV》课后习题解答5

    题目:(P104) 为一个图像创建多个图像头.读取一个大小至少为100*100的图像.另创建两个图像头并设置它们的origion,depth,nChannels和widthStep属性同之前读取的图像 ...

  5. 《学习OpenCV》课后习题解答4

    题目:(P104) 练习使用感兴趣区域(ROI).创建一个210*210的单通道图像并将其归0.在图像中使用ROI和cvSet()建立一个增长如金字塔状的数组.也就是:外部边界为0,下一个内部边界应该 ...

  6. 《学习OpenCV》课后习题解答3

    题目:(P104) 创建一个大小为100*100的三通道RGB图像.将它的元素全部置0.使用指针算法以(20,5)与(40,20)为项点绘制一个绿色平面. 解答: #include "cv. ...

  7. 《学习OpenCV》课后习题解答2

    题目:(P104) 创建一个拥有三个通道的二维字节类型矩阵,大小为100*100,并将所有值赋为0.通过函数cvPtr2D将指针指向中间的通道("绿色").以(20,5)与(40, ...

  8. 《学习OpenCV》课后习题解答9

    题目:(P126) 创建一个程序,使其读入并显示一幅图像.当用户鼠标点击图像时,获取图像对应像素的颜色值(BGR),并在图像上点击鼠标处用文本将颜色值显示出来. 解答: 本题关键是会用cvGet2D获 ...

  9. 《学习OpenCV》课后习题解答1

    题目:(P104) 下面这个练习是帮助掌握矩阵类型.创造一个三通道二维矩阵,字节类型,大小为100*100,并设置所有数值为0. a.在矩阵中使用cvCircle( CvArr* img, CvPoi ...

随机推荐

  1. export default 和 export的使用方式

    注意:1.export default 向外暴露的成员,可以使用任意的变量来接收 2.在一个模块中 ; export default 只允许向外暴露一次 3.在一个模块中 ; 可以同时使用 expor ...

  2. NPM 常见错误

    找不到兼容版本 你有一个过时的npm.请更新到最新稳定的npm. 权限错误 npm ERR! code EPERM npm ERR! code EACCES 修复缓存的权限sudo chown -R ...

  3. 构建高可靠hadoop集群之4-权限指引

    此文翻译自http://hadoop.apache.org/docs/r2.8.0/hadoop-project-dist/hadoop-hdfs/HdfsPermissionsGuide.html ...

  4. 通过命令在navicat中创建数据库及表结构

    方法/步骤     首先我们双击打开[navicat]这款软件,在菜单栏中选择[文件]-->[新建连接]-->[MySQL]: 步骤阅读   在打开的[新建连接]对话框中输入[连接名]和[ ...

  5. [异常笔记]required a bean of type 'org.quartz.JobExecutionContext' that could not be found

    *************************** APPLICATION FAILED TO START *************************** Description: Par ...

  6. ELK的简述安装

    一.ElasticSearch集群的安装及其配置 https://www.cnblogs.com/gentle-awen/p/10000801.html 可视化x-pack安装: https://ww ...

  7. Hadoop(11)-MapReduce概述和简单实操

    1.MapReduce的定义 2.MapReduce的优缺点 优点 缺点 3.MapReduce的核心思想 4.MapReduce进程 5.常用数据序列化类型 6.MapReduce的编程规范 用户编 ...

  8. Centos7 搭建 hadoop3.1.1 集群教程

    配置环境要求: Centos7 jdk 8 Vmware 14 pro hadoop 3.1.1 Hadoop下载 安装4台虚拟机,如图所示 克隆之后需要更改网卡选项,ip,mac地址,uuid 重启 ...

  9. Python3爬虫(二)网络爬虫的尺寸与约束

    Infi-chu: http://www.cnblogs.com/Infi-chu/ 一.网络爬虫的尺寸: 1.小规模,数据量小,爬取速度不敏感,Requests库,爬取网页 2.中规模,数据规模较大 ...

  10. R语言学习笔记(十一):零碎知识点(26-30)

    26--aggregate( ) 函数aggregate()对分组中的每一个变量调用tapply()函数. aggregate(a,list,f) 第二个参数必须是列表.也就是因子部分. 第三个参数即 ...