本文共 1318 字,大约阅读时间需要 4 分钟。
#include "highgui.h"#include "cv.h"#include#include using namespace std;int main(void){ int a=1; float b=2.; double c[]={4.5,6.7,8.9}; CvMat *mat=cvCreateMat(3,3,CV_32SC1); cvSetIdentity(mat);//初始化这个矩阵 CvFileStorage *fs=cvOpenFileStorage("test.xml",0,CV_STORAGE_WRITE); cvWriteComment(fs,"my data",1); //开始写数据 cvStartWriteStruct(fs,"DATA",CV_NODE_MAP,0,cvAttrList(0,0)); //写入数据c数组 cvStartWriteStruct(fs,"c",CV_NODE_SEQ,0,cvAttrList(0,0)); cvWriteRawData(fs,c,3,"d"); cvEndWriteStruct(fs); //写入单位矩阵mat cvSave("mat.xml",mat); //写入整型数据a cvWriteInt(fs,"a",a); //写入浮点型数据b cvWriteReal(fs,"b",b); cvStartWriteStruct(fs,"c",CV_NODE_SEQ,0,cvAttrList(0,0)); cvWriteRawData(fs,c,3,"d"); cvEndWriteStruct(fs); cvEndWriteStruct(fs); cvReleaseFileStorage(&fs); cvReleaseMat(&mat);/**********读取XML***********/ int i,j; CvMat *readbyname,*readbynode; CvFileNode *mat_node;//文件结点 CvFileStorage *fs_read=NULL;//文件存储 fs_read=cvOpenFileStorage("mat.xml",0,CV_STORAGE_READ); readbyname = (CvMat *)cvReadByName(fs_read,NULL,"mat",NULL); mat_node = cvGetFileNodeByName(fs_read,NULL,"mat"); readbynode = (CvMat *)cvRead(fs_read,mat_node); for (i=0;i<3;i++) { for (j=0;j<3;j++) { cout<
转载地址:http://wbyyo.baihongyu.com/