《学习OpenCV》练习题第三章第八题b

#include <highgui.h>
#include <cv.h>
#include <stdio.h>

#pragma comment (lib,"opencv_calib3d231d.lib")
#pragma comment (lib,"opencv_contrib231d.lib")
#pragma comment (lib,"opencv_core231d.lib")
#pragma comment (lib,"opencv_features2d231d.lib")
#pragma comment (lib,"opencv_flann231d.lib")
#pragma comment (lib,"opencv_gpu231d.lib")
#pragma comment (lib,"opencv_haartraining_engined.lib")
#pragma comment (lib,"opencv_highgui231d.lib")
#pragma comment (lib,"opencv_imgproc231d.lib")
#pragma comment (lib,"opencv_legacy231d.lib")
#pragma comment (lib,"opencv_ml231d.lib")
#pragma comment (lib,"opencv_objdetect231d.lib")
#pragma comment (lib,"opencv_ts231d.lib")
#pragma comment (lib,"opencv_video231d.lib")

/*
 *《学习OpenCV》第三章第八题b
 * 完成时间:19:46 4/4 星期四 2013
 */

#define ARRAY_LENGTH 10    // 数组长度

typedef struct my_struct
{
	int i;
	CvPoint point;
	CvRect rect;
} MyStruct;

void write_my_struct(CvFileStorage * fs, const char* name, my_struct*  ms)
{
	//开始写数据
	cvStartWriteStruct(fs, name, 6);

	//写入一个 整数
	cvStartWriteStruct(fs,"integer",CV_NODE_SEQ);
	cvWriteInt(fs,NULL,ms->i);
	cvEndWriteStruct(fs);

	//写入cvpoint结构
	cvStartWriteStruct(fs,"CvPoint",CV_NODE_SEQ);
	cvWriteInt(fs,NULL,ms->point.x);
	cvWriteInt(fs,NULL,ms->point.y);
	cvEndWriteStruct(fs);
    
	//写入rect结构体
	cvStartWriteStruct(fs,"CvRect",CV_NODE_SEQ);
	cvWriteInt(fs,NULL,ms->rect.x);
	cvWriteInt(fs,NULL,ms->rect.y);
	cvWriteInt(fs,NULL,ms->rect.height);
	cvWriteInt(fs,NULL,ms->rect.width);
	cvEndWriteStruct(fs);
     
	//结束写数据
	cvEndWriteStruct(fs);
}

void read_my_struct(CvFileStorage* fs, CvFileNode* ms_node, my_struct* ms)
{
	// 读第一个整数
	// 注意:这里应使用node->data.i的value来读取Integer
	int i = cvGetFileNodeByName(fs, ms_node, "integer")->data.i;
	ms->i = i;

	// 读CvPoint结构
	CvSeq *s1 = cvGetFileNodeByName(fs, ms_node, "CvPoint")->data.seq;
	CvPoint point;
	point.x= cvReadInt((CvFileNode*)cvGetSeqElem(s1,0));
	point.y= cvReadInt((CvFileNode*)cvGetSeqElem(s1,1));
	ms->point = point;

	// 读取CvRect结构
	CvSeq *s2 = cvGetFileNodeByName(fs, ms_node, "CvRect")->data.seq;
	CvRect rect;
	rect.x=cvReadInt((CvFileNode*)cvGetSeqElem(s2, 0));
	rect.y=cvReadInt((CvFileNode*)cvGetSeqElem(s2, 1));
	rect.width=cvReadInt((CvFileNode*)cvGetSeqElem(s2, 3));
	rect.height=cvReadInt((CvFileNode*)cvGetSeqElem(s2, 2));
	ms->rect = rect;
}

// 将MyStruct的值显示出来
void ShowStructValue(MyStruct* pvalue)
{
	printf("integer:%d\n", pvalue->i);
	printf("CvPoint: (%d, %d)\n", pvalue->point.x, pvalue->point.y );
	printf("CvRect: h-->%d\tw-->%d\t(%d, %d)\n", pvalue->rect.height, 
		pvalue->rect.width, pvalue->rect.x, pvalue->rect.y);
}

// 检查两个MyStruct是否一致
bool check(MyStruct* msValue1, MyStruct* msValue2)
{
	if( (msValue1->i == msValue2->i) && 
		(msValue1->point.x == msValue2->point.x) &&
		(msValue1->point.y == msValue2->point.y) && 
		(msValue1->rect.height == msValue2->rect.height) && 
		(msValue1->rect.width == msValue2->rect.width) && 
		(msValue1->rect.x == msValue2->rect.x) && 
		(msValue1->rect.y == msValue2->rect.y) )
		return true;
	else 
		return false;
}

int main()
{
	/* 写数据部分 */
	MyStruct msArray[ARRAY_LENGTH];

	CvFileStorage* fs = cvOpenFileStorage("My_struct.xml", 0, CV_STORAGE_WRITE);
	char pchTag[12]; 
	// 随机生成数据
	for(int i = 0; i < ARRAY_LENGTH; i++)
	{
		CvRNG rng = cvRNG(cvGetTickCount());
		
		msArray[i].i = cvRandInt(&rng) % 256;
		msArray[i].point = cvPoint( cvRandInt(&rng) % 1000, cvRandInt(&rng) % 1000);
		msArray[i].rect = cvRect( cvRandInt(&rng) % 1000, cvRandInt(&rng) % 1000,
			cvRandInt(&rng) % 600, cvRandInt(&rng) % 600 );

		// 最后一个整数计数
		sprintf( pchTag, "my_struct_%d", i );
		write_my_struct(fs, pchTag, &msArray[i]);
	}

	cvReleaseFileStorage(&fs);

	/* 读数据部分 */
	fs = cvOpenFileStorage("My_struct.xml", NULL, CV_STORAGE_READ );
	MyStruct msArrayRead[ARRAY_LENGTH];
 	CvFileNode *pnode; 

	for(int i = 0; i < ARRAY_LENGTH; i++)
	{
		sprintf( pchTag, "my_struct_%d", i );
		pnode = cvGetFileNodeByName(fs, NULL, pchTag);
		read_my_struct( fs, pnode, &msArrayRead[i] );

		// 显示
		printf("---------------------- %d: Write -------------------------\n", i);
		ShowStructValue( &msArray[i]);
		printf("---------------------- %d: Read --------------------------\n", i);
		ShowStructValue( &msArrayRead[i]);
		// 检查读写是否一致
		if(check(&msArray[i], &msArrayRead[i] ))
		{
			printf("Consistent?:\tAnswer: True\n");
		}
		else
		{
			printf("Consistent?:\tAnswer: False\n");
		}
		getchar();
	}

	cvReleaseFileStorage(&fs); 

	return 0;
}

对应的XML文件:


运行结果:


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值