青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

使用wxWidget中遇到的圖片存儲問題一二

1. 實驗室中CCD的實際色階為14位,獲取的原始圖像數(shù)據(jù)的每個值都存儲在一個字中,即存儲色階16位,也就是說最高兩位的數(shù)據(jù)一直為0,同時獲取的圖片信息僅僅是16色階的灰度圖,而采用wxWidget沒有辦法直接將16位的數(shù)值串保存為圖片格式,如tiff格式,那么如何將16位的數(shù)值串以圖片的形式進(jìn)行保存呢?

    經(jīng)過這么幾天的折騰總算是找到了一條解決的途徑,就是將16位的數(shù)值串轉(zhuǎn)化為8為的數(shù)值串,也許你會很快的想到這么一個方法,nValue*max(uint8)/max(uint16);用來表示轉(zhuǎn)化后的數(shù)值,不夠還是得考慮一下CCD的實際色階,由于是14位,因此可以采用這樣的方式nValue*max(uint8)/max(uint14);不過由于我們對于圖片的處理是直接對圖片的原始數(shù)據(jù)進(jìn)行處理,而轉(zhuǎn)化只是圖片在顯示屏上顯示的前提步驟,采用上述的方式雖然能夠相對很準(zhǔn)確的進(jìn)行轉(zhuǎn)化,但是需要花費一定的計算量,而通過近似的轉(zhuǎn)化能夠更快的進(jìn)行這個轉(zhuǎn)化過程,同時獲取得到的圖片依然具有較好的清晰度,下面細(xì)說一下我采用的方法:

   1: unsigned short nPicData16 = new unsigned short[nBufSize];   // nBufSize is the size to store pic
   2:  
   3: // to get the nPicData16
   4: // ..................
   5: // get the nPicData16
   6:  
   7: char *pcPicData8 = new char[nBufSize];
   8: for (size_t i = 0; i < nBufSize; ++i) {
   9:   pcPicData8[i] = (char)(nPicData16>>6);
  10: }
  11:  
  12:  

由于2^6在2^14中所占的比例較小因此可以采用這樣的近似的方法。(這種方法具體有什么作用或是缺陷還沒有細(xì)究,請各位看官給點看法

2. 順利將14位數(shù)值串轉(zhuǎn)化成為8為數(shù)值串后,嘗試的使用下列方式進(jìn)行圖片保存,發(fā)現(xiàn)結(jié)果一片黑,數(shù)值都為0了:

   1: // 結(jié)果發(fā)現(xiàn)存儲得到的save.bmp圖是24b的
   2: wxBitmap bitmap(pcPicData8,1392,1040,8);
   3: bitmap.SaveFile(wxT("save.bmp"),wxBITMAP_TYPE_BMP);
   4:  

因此猜想wxWidget對直接獲取的數(shù)據(jù)串進(jìn)行保存時采用的rgb的模式進(jìn)行保存,可能只會保存為24字節(jié)格式的圖片,也就是想要將圖片顯示到屏幕上時,也應(yīng)該采用24b的圖片。不過wxWidget對于圖片數(shù)據(jù)卻能夠讀取8位的圖片,但是再次采用上述的方式進(jìn)行存儲時,變成了32字節(jié)的了,(各位大蝦知不知道有沒有方法能夠直接保存8位圖的呢)。

于是采用了將這個8位的數(shù)值串分別賦值給R,G,B,用這種方式實現(xiàn)灰度圖的創(chuàng)建,然后再進(jìn)行保存,最終解決了問題。

   1: unsigned char *rgbData = new unsigned char[1392*1040*3];
   2: unsigned char *ptr1 = (unsigned char*) pcPicData8;
   3: unsigned char *ptr2 = rgbData;
   4: for (int i = 0; i < 1392*1040; ++i) {
   5:     *ptr2++ = *ptr1;   
   6:     *ptr2++ = *ptr1;
   7:     *ptr2++ = *ptr1++;
   8: }
   9: wxImage myImage(1392,1040,rgbData);
  10: myImage.SaveFile(wxT("save.bmp"),wxBITMAP_TYPE_BMP);

posted on 2012-06-26 17:51 鐘謝偉 閱讀(1970) 評論(12)  編輯 收藏 引用

評論

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 20:48 泡菜

貌似,wxWidget默認(rèn)保存tiff為24位圖(色階8位)的

wxWidget底層調(diào)用的,子庫為LibTIFF---一個開源C庫;需要復(fù)雜實用,直接調(diào)用C API...不過這樣很麻煩的.一般24位圖足夠?qū)嵱昧税?

文中提到的"實驗室中CCD的單個像素的分辨率為14位",有點沒理解?指色階14位,既32位圖么??看著有點暈  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 20:53 泡菜

上面回復(fù)有點錯誤,特別糾正下,應(yīng)該這樣說:

文中提到的"實驗室中CCD的單個像素的分辨率為14位",有點沒理解?指色階14位,既42位圖么??看著有點暈

顯卡一般實際輸出為32位圖(24位圖上加了個透明通道,色階還是8位的),個別支持48位圖(色階16位),例如DP口,可這是通過抖動/差值實現(xiàn)的,沒啥實際意義  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 21:03 鐘謝偉

@泡菜
那個專有的名詞是dynamic range A/D——14bit,指的是模數(shù)轉(zhuǎn)換范圍,我理解可能表示實際色階(文中說成單個像素的分辨率了,用詞不夠?qū)I(yè),不好意思),而數(shù)據(jù)存儲中是以16位色階存儲,也就是說16位中最高的兩位一直是0,而這個ccd只能夠獲取灰度圖,也就是沒有RGB信息,而wxWidget中沒有簡單的直接保存8位灰度圖的方式,于是采用了文中說的方式。  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 21:29 泡菜

@鐘謝偉
把代碼變?yōu)橄旅孢@個看看,保存下來的圖是否還是黑色的南??

1: // 結(jié)果發(fā)現(xiàn)存儲得到的save.bmp圖是24b的
2: wxBitmap bitmap(pcPicData8,1392,1040);
3: bitmap.SaveFile(wxT("save.bmp"),wxBITMAP_TYPE_BMP);  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 21:34 鐘謝偉

@泡菜
是的,還是黑色的,嘗試過了的  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 21:58 泡菜

static char pcPicData8[]= { 255 ,255 ,255 ,255 ,31,
255,255,255,31,255,255,255,31,255,255,255,
31,255,255,255,31,255,255,255,31,255,255,
255,31,255,255,255,31,255,255,255,25,243,
255,255,19,249,255,255,7,252,255,255,15,254,
255,255,31,255,255,255,191,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255 };

wxBitmap bitmap(pcPicData8,32,32);
bitmap.SaveFile(wxT("save.bmp"),wxBITMAP_TYPE_BMP);

很久沒碰編程了,上面的代碼在wxWidget下是能正常生成,并保存的.說明你的pcPicData8轉(zhuǎn)化有問題,問題出在pcPicData8上.  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 22:24 泡菜

實驗室硬件CCD咋樣不清楚,整體代碼也沒看到,但感覺你對圖像色階的理解有點小問題;如果CCD是14位的(A/D),直接獲得的數(shù)據(jù)得通過轉(zhuǎn)換(抖動/插值)才能生成16位色階的圖片(48位圖).....大多軟件也不支持48位圖的.

tiff不太清楚,但bmp、JPG最高支持24位圖(8位色階),也是wxWidget默認(rèn)支持的;PNG好像本身格式支持48位圖,可wxWidget默認(rèn)也24位圖,實際上目前,在PC上還沒看到有完全支持48位圖形的程序.
  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-27 11:32 鐘謝偉

@泡菜
它是灰度圖,所以沒有48位之說。
你給出的例子是教程中的例子,能夠正常生成,不過pcPicData8的長度是128,而32*32=1024,對于它是怎么實現(xiàn)的感到困惑。也許采用的是補零??
另外我轉(zhuǎn)化存儲的數(shù)據(jù)上傳了  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-27 11:46 鐘謝偉

@泡菜
暈啊,不知道怎么上傳文件  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-27 13:09 泡菜

這是百度上,灰度圖像解釋:(針對RGB色彩空間來說)

完整的圖像,是由紅色綠色藍(lán)色三個通道組成的。紅色、綠色、藍(lán)色三個通道的縮覽圖都是以灰度顯示的。用不同的灰度色階來表示“ 紅,綠,藍(lán)”在圖像中的比重。通道中的純白,代表了該色光在此處為最高亮度,亮度級別是255。

俺在加點...8位色階數(shù)碼圖,實際上就是24位圖片(另一種表述方法),RGB三坐標(biāo),每個坐標(biāo)軸,分為256個刻度.例如(255,0,255)表示品紅,(0,0,255)表示藍(lán)色.圖片上的每個像素點,就是這樣描述出來的.

RGB色彩空間,是以RGB三個坐標(biāo)建立起的"立方體","灰度級"指"立方體"的對角線.灰度圖簡單點理解,可以簡單理解為,采用RGB色彩空間建立起來的圖形.
所以灰度圖,有48位圖(16位色階)的概念,只不過這個立方體相對8位色階,更大而已,每個坐標(biāo)的刻度從256級別,變大為65536級(2的16次方),可以表現(xiàn)65536*65536*65536種顏色;相對于8位色階(24位圖),256*256*256種顏色多得多爾

給你個連接自己看,雖然講的不太詳細(xì)
http://baike.baidu.com/view/1184366.htm

你對某些概念的確沒搞清楚,不過只要想學(xué)就好辦...

最后一貼,最終問題還是要靠自己解決....:)
  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-27 22:03 泡菜

本來說不回帖了,可感覺還是有些東西有點不知所以然,就把wxWidget的英文文檔調(diào)出來看,發(fā)現(xiàn)俺上面的例子也有點理解錯誤

wxBitmap的其中一個構(gòu)造函數(shù)為wxBitmap (const char bits[], int width, int height, int depth=1);英文說明
Creates a bitmap from the given array bits.
You should only use this function for monochrome bitmaps (depth 1) in portable programs: in this case the bits parameter should contain an XBM image.
For other bit depths, the behaviour is platform dependent: under Windows, the data is passed without any changes to the underlying CreateBitmap() API. Under other platforms, only monochrome bitmaps may be created using this constructor and wxImage should be used for creating colour bitmaps from static data.

其bits[]是XBM image,種基于ASCII編碼的圖像格式,不同于真彩色圖,沒采用RGB色彩空間,自然不能套用三原色的東西.
之前俺的例子是從一篇中文,文檔里提取的,他沒做詳細(xì)描述,俺想當(dāng)然的引用了,有點誤導(dǎo)....俺承認(rèn) :(

特別提一下,wxImage,他的其中一個構(gòu)造函數(shù),wxImage (int width, int height, unsigned char *data, unsigned char *alpha, bool static_data=false);英文文檔描述
Creates an image from data in memory.
If static_data is false then the wxImage will take ownership of the data and free it afterwards. For this, it has to be allocated with malloc.
Parameters:
width Specifies the width of the image.
height Specifies the height of the image.
data A pointer to RGB data ------------注意是RGB
alpha A pointer to alpha-channel data
static_data Indicates if the data should be free'd after use

注意到他與上面wxBitmap構(gòu)造函數(shù)聲明的不同了沒? 在wxImage這個上面用,自然沒問題

看樣遇見問題還是老老實實,求助英文文檔來的實際 :(

另,經(jīng)過查文檔,確認(rèn),wxWidget默認(rèn)生成圖像,的確是8位色階,24位真彩的哦  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-28 09:32 鐘謝偉

@泡菜
額,一直看的是英文文檔,卻沒有深究,想當(dāng)然了,汗顏。
  回復(fù)  更多評論   


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2012年6月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567

導(dǎo)航

統(tǒng)計

常用鏈接

留言簿(1)

隨筆檔案

IT網(wǎng)站

My Friends

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美午夜片在线观看| 亚洲少妇在线| 久久精品亚洲乱码伦伦中文| 欧美aⅴ一区二区三区视频| 欧美在线免费观看| 香蕉av777xxx色综合一区| 一区二区高清视频| 亚洲视频一区二区| 亚洲男女毛片无遮挡| 亚洲夜晚福利在线观看| 午夜久久久久久久久久一区二区| 一级成人国产| 久久aⅴ国产紧身牛仔裤| 久久精品一级爱片| 欧美华人在线视频| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 亚洲午夜高清视频| 在线综合亚洲| 久久精品国产综合精品| 嫩草成人www欧美| 夜夜嗨av一区二区三区中文字幕| 99精品久久久| 久久天天狠狠| 国产精品青草久久| 性欧美1819性猛交| 欧美岛国激情| 国产精品夜色7777狼人| 91久久在线播放| 蜜臀99久久精品久久久久久软件| 亚洲伦理一区| 欧美激情综合色| 在线成人性视频| 久久久久久久国产| 午夜精品久久久久久久99水蜜桃 | 亚洲大片一区二区三区| 欧美成人一品| 久久综合九色九九| 韩国欧美一区| 久久躁狠狠躁夜夜爽| 亚洲午夜av电影| 国产精品一区二区视频| 亚洲欧美清纯在线制服| 中文国产亚洲喷潮| 国产日韩欧美亚洲一区| 欧美亚洲综合网| 久久精品2019中文字幕| 黄色亚洲免费| 亚洲激情不卡| 国产精品视频不卡| 久久天天狠狠| 欧美成人蜜桃| 在线亚洲一区观看| 欧美一级在线视频| 亚洲人成网站精品片在线观看| 亚洲国产另类久久久精品极度| 欧美日本中文| 美女在线一区二区| 欧美日韩一区三区| 欧美人妖另类| 久久精视频免费在线久久完整在线看| 亚洲欧美日韩一区在线观看| 尤物在线观看一区| 亚洲一区二区视频| 99综合精品| 免费人成精品欧美精品| 久久久精品一品道一区| 欧美日韩 国产精品| 免费日韩av片| 在线观看精品一区| 欧美在线视频免费播放| 午夜亚洲精品| 国产精品日韩精品| 一区二区免费在线观看| 日韩视频久久| 欧美成人一品| 亚洲精品久久久久久久久久久| 国产欧美日韩免费看aⅴ视频| 日韩视频一区二区三区| 亚洲人成欧美中文字幕| 欧美激情五月| 中文国产成人精品| 欧美一区二区视频网站| 国产精品久久久久7777婷婷| 一区二区三区**美女毛片 | 欧美日韩一区三区四区| 亚洲国内精品| 亚洲欧美日韩国产中文在线| 欧美日韩国产综合一区二区| 亚洲免费精彩视频| 欧美一区二区三区在线观看视频| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲视频日本| 蜜桃视频一区| 亚洲自拍都市欧美小说| 久久一日本道色综合久久| 国产精品视频一二三| 久久都是精品| 一区二区日本视频| 免费成人美女女| 一区二区三区日韩欧美精品| 国产乱码精品一区二区三区五月婷| 午夜精品一区二区三区在线播放| 免费短视频成人日韩| 亚洲一区二区网站| 亚洲欧美日韩网| 亚洲精品美女在线观看| 久久婷婷成人综合色| 欧美在线观看www| 国产一区二区三区在线观看视频| 久久精品国产亚洲一区二区三区| 欧美日韩另类在线| aa国产精品| 久久夜色撩人精品| 久久国产精品99久久久久久老狼| 久久人人97超碰精品888| 午夜精品久久久久久久蜜桃app | 美女国产一区| 久久永久免费| 午夜在线一区| 午夜精品久久| 久久九九99| 美日韩免费视频| 欧美+日本+国产+在线a∨观看| 欧美在线亚洲| 久久一综合视频| 欧美国产精品专区| 国产精品国产三级国产aⅴ浪潮| 欧美日韩国内| 久久亚洲图片| 欧美大片在线观看| 欧美国产精品v| 牛牛精品成人免费视频| 美日韩免费视频| 国产精品腿扒开做爽爽爽挤奶网站| 国产毛片一区| 亚洲三级网站| 久久久久国内| 一本大道久久精品懂色aⅴ| 亚洲一区二区三区精品在线| 久久久精彩视频| 国产精品青草久久久久福利99| 影音先锋成人资源站| 亚洲欧美一区二区三区久久| 久久久久久电影| 亚洲免费网址| 国产精品美女久久久免费| 日韩视频久久| 亚洲精品久久久久久久久| 麻豆精品一区二区av白丝在线| 国产精品热久久久久夜色精品三区 | 国产精品成人aaaaa网站| 伊人久久久大香线蕉综合直播| 亚洲视屏一区| 一区二区动漫| 欧美日韩成人综合| 亚洲人成艺术| 亚洲黄色在线视频| 欧美日韩亚洲成人| 亚洲免费在线观看| 亚洲在线电影| 国产一区高清视频| 猫咪成人在线观看| 农村妇女精品| 一本色道久久综合| 制服丝袜激情欧洲亚洲| 国产精品嫩草久久久久| 久久精品国产清自在天天线| 欧美在线不卡视频| 亚洲美女在线看| 亚洲一区不卡| 亚洲激情影院| 午夜在线视频观看日韩17c| 久久精品国产99国产精品澳门 | 午夜精品久久久久久99热| 国产主播一区二区三区四区| 欧美xart系列在线观看| 欧美日韩一区在线| 久久综合中文| 国产精品每日更新| 亚洲高清在线精品| 国内精品美女av在线播放| 亚洲人精品午夜| 1204国产成人精品视频| 亚洲天堂偷拍| 亚洲午夜在线观看视频在线| 久久久久国产精品麻豆ai换脸| 一区二区三区欧美亚洲| 久久视频一区| 欧美大片在线看免费观看| 国产偷久久久精品专区| 夜夜嗨av一区二区三区网页 | 欧美日韩精品国产| 久久一区激情| 一区二区三区在线观看欧美| 亚洲欧美日韩综合| 久久人人爽人人| 亚洲大胆视频| 欧美激情一区二区三区成人| 欧美www视频在线观看| 亚洲高清视频在线观看|