• OpenCV用读取矩阵,访问图像数据


    View Code
     1 int _tmain(int argc,_TCHAR* argv[])
    2 {
    3 //用固定数据创建一个矩阵
    4 float vals[]={0.664,-0.500,0.500,0.866};
    5 CvMat rotmat;
    6 cvInitMatHeader(&rotmat,2,2,CV_32FC1,vals);
    7 int number = cvGetDims(&rotmat,0);
    8 CvMat* mat = cvCreateMat(5,5,CV_32FC1);
    9 //用简单方法对矩阵数据存取。
    10
    11 //方法一
    12 float element_3_2 = CV_MAT_ELEM(*mat,float,3,2);
    13
    14 //方法二
    15 float element_3_2_ptr = 7.7;
    16 *((float*)CV_MAT_ELEM_PTR(*mat,3,2))=element_3_2_ptr;
    17
    18 /************************************************************************/
    19 /* 以上方法利用宏进行存取数据。但是,宏在每次调用的时候都重新计算指针。
    20 这意味着要查找指向矩阵基本元素数据区的指针,计算目标数据在矩阵中的相对地址,然后将相对位置与基本位置相加。
    21 因此这不是一个很好的存取矩阵的方法。在计算顺序访问矩阵的所有元素时,这种方法的缺点尤为突出。
    22 并且方法一,方法二只适用于访问1维或者2维的数组。
    23 */
    24 /************************************************************************/
    25
    26
    27
    28 }
    29
    30
    31 //累加一个三通道矩阵中的所有元素
    32 float sum(const CvMat* mat)
    33 {
    34 float s=0.0f;
    35 for(int row=0;row<mat->rows;row++)
    36 {
    37 const float* prt=(const float*)(mat->data->ptr+row*mat->step);
    38 for (int col=0;col<mat->cols;col++)
    39 {
    40 s+=*prt++;
    41 }
    42 }
    43 return (s);
    44 }
    45
    46 //矩阵的元素data是一个联合体。所以对这个指针解引用时,必须指明结构体中的正确的元素以便得到正确的指针类型。
    47 //为了参数正确的偏移必须用矩阵的行数据长度step元素。
    48
    49
    50
    51 //仅最大化HSV图像“S”和“V”部分
    52 //指针ptr指向第y行的起始位置。接着从指针中析出饱和度和高度在x维的值。因为这是一个三通道图像,所以c通道在x列的位置为3*x+c。
    53 void saturate_sv(IplImage* img)
    54 {
    55 for(int y=0;y<img->height;y++)
    56 {
    57 uchar* ptr=(uchar*)(
    58 img->imageData+y*img->widthStep
    59 );
    60 for (int x=0;x<img->width;x++)
    61 {
    62 ptr[3*x+1]=255;
    63 ptr[3*x+2]=255;
    64 }
    65
    66 }
    67 }

  • 相关阅读:
    SQL 索引
    SQL 存储
    C#编程中的66个好习惯,你有多少个?
    Delphi中如何让窗口最小化至系统托盘
    浅谈 堆和堆栈
    C#编程中的66个好习惯
    用ADO连接oracle的步骤
    如何卸载ocx包
    数据库中,Decimal数据类型
    [转载]内存区划分、内存分配、常量存储区、堆、栈、自由存储区、全局区
  • 原文地址:https://www.cnblogs.com/slysky/p/2195850.html
Copyright © 2020-2023  润新知