亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? image.c

?? 這是圖象處理模式識別一書的源代碼
?? C
字號:
/*############################################################################# * 文件名:image.c * 功能:  實現了指紋圖像的基本操作 * modified by  PRTsinghua@hotmail.com#############################################################################*/#include <stdlib.h>#include <stdio.h>#include <string.h>#include "image.h"/* 指紋圖像結構。256級灰度圖 */typedef struct iFvsImage_t{    FvsByte_t       *pimg;         /* 8-bit圖像數組 */        FvsInt_t        w;             /* 寬度          */    FvsInt_t        h;             /* 高度          */    FvsInt_t        pitch;         /* 傾斜度        */    FvsImageFlag_t  flags;         /* 標記          */} iFvsImage_t;/******************************************************************************  * 功能:創建一個新的圖像對象  * 參數:無  * 返回:失敗返回空,否則返回新的圖像對象******************************************************************************/FvsImage_t ImageCreate(){    iFvsImage_t* p = NULL;    p = (FvsImage_t)malloc(sizeof(iFvsImage_t));    if (p!=NULL)    {        p->h        = 0;        p->w        = 0;        p->pitch    = 0;        p->pimg     = NULL;        p->flags    = FvsImageGray; /* 缺省的標記 */        }    return (FvsImage_t)p;}/******************************************************************************  * 功能:銷毀一個圖像對象  * 參數:image  指向圖像對象的指針  * 返回:無******************************************************************************/void ImageDestroy(FvsImage_t image){    iFvsImage_t* p = NULL;    if (image==NULL)        return;    (void)ImageSetSize(image, 0, 0);    p = image;    free(p);}/******************************************************************************  * 功能:設置圖像標記,該操作大部分由庫函數自動完成  * 參數:image  指向圖像對象的指針  *       flag   標記  * 返回:錯誤編號******************************************************************************/FvsError_t ImageSetFlag(FvsImage_t img, const FvsImageFlag_t flag){    iFvsImage_t* image = (iFvsImage_t*)img;    image->flags = flag;     return FvsOK;}/******************************************************************************  * 功能:獲得圖像標記  * 參數:image  指向圖像對象的指針  * 返回:圖像標記******************************************************************************/FvsImageFlag_t ImageGetFlag(const FvsImage_t img){    iFvsImage_t* image = (iFvsImage_t*)img;    return image->flags; }/******************************************************************************  * 功能:設置一個圖像對象的大小  * 參數:image   指向圖像對象的指針  *       width   圖像寬度  *       height  圖像高度  * 返回:錯誤編號******************************************************************************/FvsError_t ImageSetSize(FvsImage_t img, const FvsInt_t width, 						const FvsInt_t height){    iFvsImage_t* image = (iFvsImage_t*)img;    FvsError_t nRet = FvsOK;    FvsInt_t newsize = width*height;    /* size為0的情況 */    if (newsize==0)    {        if (image->pimg!=NULL)        {            free(image->pimg);            image->pimg = NULL;            image->w = 0;            image->h = 0;            image->pitch = 0;        }        return FvsOK;    }    if (image->h*image->w != newsize)    {        free(image->pimg);        image->w = 0;        image->h = 0;        image->pitch = 0;        /* 申請內存 */        image->pimg = (uint8_t*)malloc((size_t)newsize);    }    if (image->pimg == NULL)        nRet = FvsMemory;    else    {        image->h = height;        image->w = width;        image->pitch = width;    }    return nRet;}/******************************************************************************  * 功能:拷貝圖像  * 參數:destination  指向目標圖像對象的指針  *       source       指向源圖像對象的指針  * 返回:錯誤編號******************************************************************************/FvsError_t ImageCopy(FvsImage_t destination, const FvsImage_t source){    iFvsImage_t* dest = (iFvsImage_t*)destination;    iFvsImage_t* src  = (iFvsImage_t*)source;    FvsError_t nRet = FvsOK;    nRet = ImageSetSize(dest, src->w, src->h);        if (nRet==FvsOK)        memcpy(dest->pimg, src->pimg, (size_t)src->h*src->w);    /* 拷貝標記 */    dest->flags = src->flags;    return nRet;}/******************************************************************************  * 功能:清空圖像  * 參數:image  指向圖像對象的指針  * 返回:錯誤編號******************************************************************************/FvsError_t ImageClear(FvsImage_t img){    return ImageFlood(img, 0);}/******************************************************************************  * 功能:設置圖像中所有象素為特定值  * 參數:image  指向圖像對象的指針  *       value  要設定的值  * 返回:錯誤編號******************************************************************************/FvsError_t ImageFlood(FvsImage_t img, const FvsByte_t value){    FvsError_t nRet = FvsOK;    iFvsImage_t* image = (iFvsImage_t*)img;    if (image==NULL) return FvsMemory;    if (image->pimg!=NULL)        memset(image->pimg, (int)value, (size_t)(image->h*image->w));    return nRet;}/******************************************************************************  * 功能:設置圖像中某個象素的值  * 參數:image  指向圖像對象的指針  *       x      X軸坐標  *       y      Y軸坐標  *       val    要設定的值  * 返回:無******************************************************************************/void ImageSetPixel(FvsImage_t img, const FvsInt_t x, const FvsInt_t y, 						const FvsByte_t val){    iFvsImage_t* image = (iFvsImage_t*)img;    int address = y * image->w + x;    image->pimg[address] = val;}/******************************************************************************  * 功能:獲得圖像中某個象素的值  * 參數:image  指向圖像對象的指針  *       x      X軸坐標  *       y      Y軸坐標  * 返回:象素的值******************************************************************************/FvsByte_t ImageGetPixel(const FvsImage_t img, const FvsInt_t x, 						const FvsInt_t y){    iFvsImage_t* image = (iFvsImage_t*)img;    /* 數組中的位置 */    int address = y * image->pitch + x;    return image->pimg[address];}/******************************************************************************  * 功能:獲得圖像緩沖區指針  * 參數:image  指向圖像對象的指針  * 返回:指向圖像內存緩沖區的指針******************************************************************************/FvsByte_t* ImageGetBuffer(FvsImage_t img){    iFvsImage_t* image = (iFvsImage_t*)img;    if (image==NULL)     	return NULL;    return image->pimg;}/******************************************************************************  * 功能:獲得圖像寬度  * 參數:image  指向圖像對象的指針  * 返回:圖像寬度******************************************************************************/FvsInt_t ImageGetWidth(const FvsImage_t img){    iFvsImage_t* image = (iFvsImage_t*)img;    if (image==NULL)     	return -1;    return image->w;}/******************************************************************************  * 功能:獲得圖像高度  * 參數:image  指向圖像對象的指針  * 返回:圖像高度******************************************************************************/FvsInt_t ImageGetHeight(const FvsImage_t img){    iFvsImage_t* image = (iFvsImage_t*)img;    if (image==NULL)     	return -1;    return image->h;}/******************************************************************************  * 功能:獲得圖像緩沖區的大小  * 參數:image  指向圖像對象的指針  * 返回:緩沖區大小******************************************************************************/FvsInt_t ImageGetSize(const FvsImage_t img){    iFvsImage_t* image = (iFvsImage_t*)img;    if (image==NULL)     	return 0;    return image->h * image->w;}/******************************************************************************  * 功能:獲得圖像傾斜度  * 參數:image  指向圖像對象的指針  * 返回:傾斜度******************************************************************************/FvsInt_t ImageGetPitch(const FvsImage_t img){    iFvsImage_t* image = (iFvsImage_t*)img;    if (image==NULL)     	return -1;    return image->pitch;}/******************************************************************************  * 功能:比較兩個圖像大小  * 參數:image1  指向圖像對象1的指針  *       image2  指向圖像對象2的指針  * 返回:若兩個圖像大小相等,返回true;否則返回false******************************************************************************/FvsBool_t ImageCompareSize(const FvsImage_t image1, const FvsImage_t image2){    if (ImageGetWidth(image1)!=ImageGetWidth(image2))        return FvsFalse;    if (ImageGetHeight(image1)!=ImageGetHeight(image2))        return FvsFalse;    return FvsTrue;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品视频一二三| 欧美丰满高潮xxxx喷水动漫| 欧美极品aⅴ影院| 不卡一二三区首页| 最新欧美精品一区二区三区| 92精品国产成人观看免费| 亚洲精品中文在线影院| 在线精品视频一区二区三四| 亚洲福利一区二区三区| 在线播放日韩导航| 精品一区二区三区在线播放视频| 日韩精品在线一区| 国产91精品免费| 亚洲美女视频在线| 日韩一级免费观看| 国产jizzjizz一区二区| 亚洲综合视频在线观看| 日韩免费高清av| 成人综合激情网| 亚洲国产日韩一级| 精品国产免费人成在线观看| 成人99免费视频| 香蕉影视欧美成人| 国产丝袜欧美中文另类| 欧美午夜精品免费| 国产资源精品在线观看| 亚洲精品欧美激情| 精品国产乱码久久久久久图片 | 99久久精品国产导航| 亚洲一级二级三级| 欧美xfplay| 色婷婷一区二区三区四区| 精油按摩中文字幕久久| 亚洲色图色小说| 日韩精品中文字幕一区二区三区| 99在线精品免费| 另类专区欧美蜜桃臀第一页| 亚洲毛片av在线| 国产亚洲综合在线| 欧美日本在线观看| av中文字幕亚洲| 麻豆精品一二三| 亚洲精品乱码久久久久| 国产欧美一区二区三区鸳鸯浴| 精品国产一区a| 欧美性高清videossexo| 粉嫩av一区二区三区| 男人操女人的视频在线观看欧美| 亚洲人成在线播放网站岛国| 久久婷婷国产综合精品青草| 欧美日韩国产一区| av电影在线不卡| 国产一区久久久| 日韩精品成人一区二区三区| 亚洲特级片在线| 亚洲国产精品二十页| 日韩免费高清视频| 欧美精品99久久久**| 在线观看视频91| 成人综合激情网| 国产在线精品免费av| 男女视频一区二区| 亚洲国产综合人成综合网站| 综合色中文字幕| 国产精品久久久久久久久久久免费看| 日韩一区二区三区四区| 欧美日韩精品专区| 色视频一区二区| 91老师片黄在线观看| 成人国产精品免费观看| 国产99一区视频免费| 国产综合色产在线精品| 国产一区在线看| 狠狠色丁香九九婷婷综合五月| 日本视频在线一区| 乱中年女人伦av一区二区| 美女网站在线免费欧美精品| 日韩和欧美的一区| 人人精品人人爱| 久久精品国产久精国产| 免费黄网站欧美| 经典三级一区二区| 国产黄人亚洲片| 国产一区二区三区观看| 国产91精品久久久久久久网曝门| 国产a久久麻豆| 91在线免费看| 欧美日韩精品欧美日韩精品一| 欧美男同性恋视频网站| 日韩欧美一区二区在线视频| 久久综合久久综合久久综合| 久久久久久久久一| 国产精品久99| 亚洲精品国产a久久久久久| 一区二区理论电影在线观看| 亚洲午夜精品在线| 免费看欧美美女黄的网站| 国产酒店精品激情| 成人国产一区二区三区精品| 色婷婷激情久久| 欧美一区二区三区四区高清| 久久亚洲春色中文字幕久久久| 中文字幕精品一区二区三区精品| 亚洲男同性视频| 日日夜夜一区二区| 国产一区二区三区视频在线播放| 暴力调教一区二区三区| 欧美性大战xxxxx久久久| 国产精品毛片久久久久久| 中文字幕一区免费在线观看| 视频一区欧美精品| 国产成人高清在线| 欧美性感一区二区三区| 久久青草欧美一区二区三区| 亚洲三级电影全部在线观看高清| 午夜精品福利一区二区蜜股av| 久久国产免费看| 91在线porny国产在线看| 欧美日韩二区三区| 国产日韩三级在线| 日韩精品高清不卡| 99久久精品国产一区二区三区| 欧美日韩在线三区| 国产亚洲欧美日韩在线一区| 亚洲永久精品大片| 国产成人激情av| 在线播放日韩导航| 亚洲日本乱码在线观看| 狠狠色综合播放一区二区| 欧美伊人久久久久久午夜久久久久| 精品国产乱码久久久久久老虎 | 欧美性受极品xxxx喷水| 国产三级精品视频| 日本不卡在线视频| 91美女在线看| 久久久久久久久久久久电影 | 日韩毛片精品高清免费| 看电视剧不卡顿的网站| 欧美在线观看一区二区| 欧美国产1区2区| 毛片av一区二区| 欧美色图天堂网| 亚洲丝袜精品丝袜在线| 国产不卡高清在线观看视频| 欧美大片在线观看一区| 亚洲电影在线免费观看| 成人福利视频网站| 国产无一区二区| 国产又黄又大久久| 欧美一区日韩一区| 午夜久久久久久久久久一区二区| 91在线视频观看| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 国产精品毛片无遮挡高清| 国产一区二区电影| 久久综合色综合88| 九九精品视频在线看| 日韩欧美一级特黄在线播放| 日本成人在线不卡视频| 欧美高清性hdvideosex| 亚洲福利视频导航| 欧美丝袜第三区| 亚洲va天堂va国产va久| 欧美日韩一二区| 亚洲国产精品一区二区www| 欧美中文字幕亚洲一区二区va在线 | 国产成人a级片| 久久久久久久久免费| 国产真实乱子伦精品视频| 精品伦理精品一区| 国产在线播精品第三| 精品粉嫩超白一线天av| 国产在线精品一区在线观看麻豆| 日韩欧美一区二区视频| 国内不卡的二区三区中文字幕| 精品少妇一区二区三区在线播放| 黄页网站大全一区二区| 久久新电视剧免费观看| 国产91丝袜在线18| 亚洲三级电影全部在线观看高清| 色吊一区二区三区| 丝袜美腿一区二区三区| 日韩写真欧美这视频| 精品一区二区国语对白| 久久九九久精品国产免费直播| 成人小视频免费观看| 最新国产成人在线观看| 欧美综合久久久| 老司机免费视频一区二区| 久久久久久9999| 92精品国产成人观看免费 | 91精品国产手机| 国产精品一区久久久久| 国产精品免费视频一区| 在线国产电影不卡| 久久精品国产99国产| 亚洲国产电影在线观看| 精品视频一区二区不卡| 国产精品自产自拍| 亚洲欧洲制服丝袜|