1 #include <highgui.h> 2 #include <cv.h> 3 #include <stdio.h> 4 5 #pragma comment (lib,"opencv_calib3d231d.lib") 6 #pragma comment (lib,"opencv_contrib231d.lib") 7 #pragma comment (lib,"opencv_core231d.lib") 8 #pragma comment (lib,"opencv_features2d231d.lib") 9 #pragma comment (lib,"opencv_flann231d.lib") 10 #pragma comment (lib,"opencv_gpu231d.lib") 11 #pragma comment (lib,"opencv_haartraining_engined.lib") 12 #pragma comment (lib,"opencv_highgui231d.lib") 13 #pragma comment (lib,"opencv_imgproc231d.lib") 14 #pragma comment (lib,"opencv_legacy231d.lib") 15 #pragma comment (lib,"opencv_ml231d.lib") 16 #pragma comment (lib,"opencv_objdetect231d.lib") 17 #pragma comment (lib,"opencv_ts231d.lib") 18 #pragma comment (lib,"opencv_video231d.lib") 19 20 /* 21 *《学习OpenCV》第三章第八题b 22 * 完成时间:19:46 4/4 星期四 2013 23 */ 24 25 #define ARRAY_LENGTH 10 // 数组长度 26 27 typedef struct my_struct 28 { 29 int i; 30 CvPoint point; 31 CvRect rect; 32 } MyStruct; 33 34 void write_my_struct(CvFileStorage * fs, const char* name, my_struct* ms) 35 { 36 //开始写数据 37 cvStartWriteStruct(fs, name, 6); 38 39 //写入一个 整数 40 cvStartWriteStruct(fs,"integer",CV_NODE_SEQ); 41 cvWriteInt(fs,NULL,ms->i); 42 cvEndWriteStruct(fs); 43 44 //写入cvpoint结构 45 cvStartWriteStruct(fs,"CvPoint",CV_NODE_SEQ); 46 cvWriteInt(fs,NULL,ms->point.x); 47 cvWriteInt(fs,NULL,ms->point.y); 48 cvEndWriteStruct(fs); 49 50 //写入rect结构体 51 cvStartWriteStruct(fs,"CvRect",CV_NODE_SEQ); 52 cvWriteInt(fs,NULL,ms->rect.x); 53 cvWriteInt(fs,NULL,ms->rect.y); 54 cvWriteInt(fs,NULL,ms->rect.height); 55 cvWriteInt(fs,NULL,ms->rect.width); 56 cvEndWriteStruct(fs); 57 58 //结束写数据 59 cvEndWriteStruct(fs); 60 } 61 62 void read_my_struct(CvFileStorage* fs, CvFileNode* ms_node, my_struct* ms) 63 { 64 // 读第一个整数 65 // 注意:这里应使用node->data.i的value来读取Integer 66 int i = cvGetFileNodeByName(fs, ms_node, "integer")->data.i; 67 ms->i = i; 68 69 // 读CvPoint结构 70 CvSeq *s1 = cvGetFileNodeByName(fs, ms_node, "CvPoint")->data.seq; 71 CvPoint point; 72 point.x= cvReadInt((CvFileNode*)cvGetSeqElem(s1,0)); 73 point.y= cvReadInt((CvFileNode*)cvGetSeqElem(s1,1)); 74 ms->point = point; 75 76 // 读取CvRect结构 77 CvSeq *s2 = cvGetFileNodeByName(fs, ms_node, "CvRect")->data.seq; 78 CvRect rect; 79 rect.x=cvReadInt((CvFileNode*)cvGetSeqElem(s2, 0)); 80 rect.y=cvReadInt((CvFileNode*)cvGetSeqElem(s2, 1)); 81 rect.width=cvReadInt((CvFileNode*)cvGetSeqElem(s2, 3)); 82 rect.height=cvReadInt((CvFileNode*)cvGetSeqElem(s2, 2)); 83 ms->rect = rect; 84 } 85 86 // 将MyStruct的值显示出来 87 void ShowStructValue(MyStruct* pvalue) 88 { 89 printf("integer:%d\n", pvalue->i); 90 printf("CvPoint: (%d, %d)\n", pvalue->point.x, pvalue->point.y ); 91 printf("CvRect: h-->%d\tw-->%d\t(%d, %d)\n", pvalue->rect.height, 92 pvalue->rect.width, pvalue->rect.x, pvalue->rect.y); 93 } 94 95 // 检查两个MyStruct是否一致 96 bool check(MyStruct* msValue1, MyStruct* msValue2) 97 { 98 if( (msValue1->i == msValue2->i) && 99 (msValue1->point.x == msValue2->point.x) && 100 (msValue1->point.y == msValue2->point.y) && 101 (msValue1->rect.height == msValue2->rect.height) && 102 (msValue1->rect.width == msValue2->rect.width) && 103 (msValue1->rect.x == msValue2->rect.x) && 104 (msValue1->rect.y == msValue2->rect.y) ) 105 return true; 106 else 107 return false; 108 } 109 110 int main() 111 { 112 /* 写数据部分 */ 113 MyStruct msArray[ARRAY_LENGTH]; 114 115 CvFileStorage* fs = cvOpenFileStorage("My_struct.xml", 0, CV_STORAGE_WRITE); 116 char pchTag[12]; 117 // 随机生成数据 118 for(int i = 0; i < ARRAY_LENGTH; i++) 119 { 120 CvRNG rng = cvRNG(cvGetTickCount()); 121 122 msArray[i].i = cvRandInt(&rng) % 256; 123 msArray[i].point = cvPoint( cvRandInt(&rng) % 1000, cvRandInt(&rng) % 1000); 124 msArray[i].rect = cvRect( cvRandInt(&rng) % 1000, cvRandInt(&rng) % 1000, 125 cvRandInt(&rng) % 600, cvRandInt(&rng) % 600 ); 126 127 // 最后一个整数计数 128 sprintf( pchTag, "my_struct_%d", i ); 129 write_my_struct(fs, pchTag, &msArray[i]); 130 } 131 132 cvReleaseFileStorage(&fs); 133 134 /* 读数据部分 */ 135 fs = cvOpenFileStorage("My_struct.xml", NULL, CV_STORAGE_READ ); 136 MyStruct msArrayRead[ARRAY_LENGTH]; 137 CvFileNode *pnode; 138 139 for(int i = 0; i < ARRAY_LENGTH; i++) 140 { 141 sprintf( pchTag, "my_struct_%d", i ); 142 pnode = cvGetFileNodeByName(fs, NULL, pchTag); 143 read_my_struct( fs, pnode, &msArrayRead[i] ); 144 145 // 显示 146 printf("---------------------- %d: Write -------------------------\n", i); 147 ShowStructValue( &msArray[i]); 148 printf("---------------------- %d: Read --------------------------\n", i); 149 ShowStructValue( &msArrayRead[i]); 150 // 检查读写是否一致 151 if(check(&msArray[i], &msArrayRead[i] )) 152 { 153 printf("Consistent?:\tAnswer: True\n"); 154 } 155 else 156 { 157 printf("Consistent?:\tAnswer: False\n"); 158 } 159 getchar(); 160 } 161 162 cvReleaseFileStorage(&fs); 163 164 return 0; 165 }
对应的XML文件:
运行结果: