【開源程序(C++)】獲取bing圖片并自動設置為電腦桌面背景

眾所周知,bing搜索網站首頁每日會更新一張圖片,張張漂亮(額,也有一些不合我口味的),特別適合用來做電腦壁紙。

我們想要將bing網站背景圖片設置為電腦桌面背景的通常做法是:

  • 上網,搜索bing
  • 找到圖片的下載鏈接,并下載之
  • 將圖片設置為桌面背景(也有部分瀏覽器支持直接在網頁中右擊圖片設置為壁紙)
  • 可能你還會刪除下載下來的圖片

作為一枚coder,你不會覺得麻煩嘛?至少需要三個步驟呢!

So...我就用C++語言寫了一個小程序,用于獲取bing網站的圖片,并將其設置為桌面背景。整個過程只需要點擊.exe文件,一鍵完成!

當然,你也可以通過本程序,窺見Windows API的些許用法,活學活用C++知識!

當然網上也存在片片斷斷的程序,我的部分程序也借鑒了它們的思想,在此感謝互聯網和辛勤的貢獻者們。

以下是程序設計的技術要點:

--------------------------------------------------------------

技術要點:

    1、獲取網絡地址   直接使用網絡地址或下載 注意若下載下來后,要將\轉換為/,當然也可以用\\
       網絡地址可以從這里獲取:http://cn.bing.com/HPImageArchive.aspx?format=xml&idx=0&n=1
       在返回的xml頁面中(images->image->url)找到具體的圖片地址(xml解析),拼接到bing域名后面構成完整地址
       注:xml解析用了TinyXml2
 
    2、轉換圖片格式(jpg->bmp),本程序中的SystemParametersInfoA函數只支持bmp
       在程序中自動轉換(單單改后綴名是沒有用的),轉換用的程序是從網上下載的,用C語言編寫而成
       考慮到需要改后綴名,那就直接下載圖片好了,順便存儲之
 
    3、圖片保存路徑為C:/Users/Administrator/bingPicture/,格式為.jpg 方便以后瀏覽

注意:部分用戶電腦可能不存在路徑C:/Users/Administrator/,造成程序無法執行,可以直接在C盤根目錄下創建路徑,如C:/bingPicture/
       注意不保存轉換后的bmp格式圖片(設置背景后即刪除),因為體積較大
       判斷文件夾是否存在,若不存在,則自動創建文件夾


4、注意本程序獲取的圖片尺寸是1366x768,若你的屏幕分辨率為1920x1080,還需要對Xml解析出來的圖片Url地址進行字符串替換(將1366x768換成1920x1080即可)

前提:針對1920x1080尺寸的圖片地址存在


5、若此程序若在國際網絡下運行,獲取的就是國際版bing壁紙;若在國內網絡下運行,獲取的就是中國版bing壁紙。因此在同一天內,在不同網絡環境下獲取的圖片可能不同

 
*未實現的功能*:
    1、獲取每日壁紙的故事(利用bing故事接口) ,更新壁紙后顯示在執行框中
 
    2、開機自啟動,并隱藏到托盤中(為減少CPU占用并增加趣味性,設置為開機自動啟動,提示網絡連接,并輸入"go"才執行功能)
       電腦若未關機,則在24:00自動啟動,更換背景
 
    3、軟件自動更新版本功能

--------------------------------------------------------------

程序在文章后面提供,源碼已注釋很詳細,不再贅述。

注意,使用程序之前,務必看以下注意事項:

--------------------------------------------------------------

請注意:
?? ?1、本軟件使用Qt開發,您也可以將文件加入自己的工程,使用其他IDE開發
?? ????? 需要注意的一點是,本軟件需要加入URLMON.DLL(源碼包中有)

?? ?2、本軟件開源(源碼位于xiaoxi666的博客園以及github,不對其他地址給出的鏈接負責),僅用于學習交流,請勿用于商業用途

?? ?3、為防止軟件被加入惡意功能,不提供可執行文件,若需使用請重新編譯,編譯器需要支持c++11

?? ?4、本軟件程序中內含刪除臨時文件功能,請在更改前仔細確認,避免路徑錯誤而刪除其他重要文件

--------------------------------------------------------------

然而許多小伙伴要體驗效果,我就一并把可執行文件放出來吧(請勿隨意傳播.exe文件防止有人添加惡意功能。當然源碼開放可共享)

下載區:

  • 源碼
  • 可執行文件(可執行文件中圖片保存地址為C:/bingPicture/

但一定要注意核對文件校驗碼(以保證安全):

  • ?可執行文件壓縮包WallPaper校驗碼

    MD5: 48173BA7DCF2120F2822226A5D4A90CF
?????????? SHA1: CEB0ED570AF613EC3829AC8FDE4F8C50DDEF4101

  • ?可執行文件WallPaper_1366x768_Common校驗碼(此版本用于1366x768分辨率)

    MD5: ACDA8E5E4CF0B2916254B233D1243FD3
  ???? SHA1: 6041C813DC8E2AE29EA8675EF279CFC0E7921D53

  • 可執行文件WallPaper_1920x1080_Common校驗碼(此版本用于1920x1080分辨率)

    MD5: 474570808A56EFDC7B589F605D08C5B6
  ????? SHA1: B78921AD655B35F079076904A22F1A0E5122EB7F

?

為方便瀏覽,貼出主要源程序:

?main.cpp文件

  1 //main.cpp
  2 /******************windows桌面背景更換C++程序***********************************************************
  3 功能:獲取每日bing搜索主頁圖片,設置為當日桌面壁紙。并將其下載保存至本地文件夾方便以后瀏覽
  4 作者:xiaoxi666
  5 日期:2017/03/12
  6 
  7 技術要點:
  8     1、獲取網絡地址   直接使用網絡地址或下載 注意若下載下來后,要將\轉換為/,當然也可以用\\
  9        網絡地址可以從這里獲取:http://cn.bing.com/HPImageArchive.aspx?format=xml&idx=0&n=1
 10        在返回  的xml頁面中(images->image->url)找到具體的圖片地址(xml解析),拼接到bing域名后面,構成完整地址
 11        注:xml解析用了TinyXml2
 12 
 13     2、轉換圖片格式(jpg->bmp),本程序中的SystemParametersInfoA函數只支持bmp
 14        在程序中自動轉換(單單改后綴名是沒有用的),轉換用的程序是從網上下載的,用C語言編寫而成
 15        考慮到需要改后綴名,那就直接下載圖片好了,順便存儲之
 16 
 17     3、圖片保存路徑為C:\bingPicture\,格式為.jpg 方便以后瀏覽
 18        注意不保存轉換后的bmp格式圖片(設置背景后即刪除),因為體積較大
 19        判斷文件夾是否存在,若不存在,則自動創建文件夾
 20 
 21 *未實現的功能*:
 22     ***獲取每日壁紙的故事(利用bing故事接口) ,更新壁紙后顯示在執行框中
 23 
 24     ***開機自啟動,并隱藏到托盤中(為減少CPU占用并增加趣味性,設置為開機自動啟動,提示網絡連接,并輸入"go"才執行功能)
 25        電腦若未關機,則在24:00自動啟動,更換背景
 26 
 27     ***軟件自動更新版本功能
 28 
 29 ******************************************************************************************************/
 30 
 31 #include <iostream>    //輸入輸出
 32 #include <cstring>     //文件命名處理需要用字符串
 33 #include <windows.h>   //調用操作系統各種API
 34 #include <ctime>       //獲取時間,各種文件命名
 35 #include <UrlMon.h>    //包含提供下載服務的API
 36 #include "tinyxml2.h"  //解析XML
 37 #include <io.h>        //判斷文件夾是否存在
 38 #include <direct.h>    //創建文件夾
 39 extern "C"
 40 {
 41 #include "jpeg.h"    //轉換圖片格式jpg->bmp  轉換格式的程序使用C語言寫的
 42 }
 43 
 44 //創建本地bingPicture路徑和Tmp路徑
 45 void createDir()
 46 {
 47     //本地bingPicture路徑
 48     std::string LocalFolder="C:/bingPicture/";
 49 
 50     if(0!=access(LocalFolder.c_str(),0))    //判斷文件夾是否存在,若不存在則創建
 51         if(0!=mkdir(LocalFolder.c_str()))
 52             std::cout<<"創建文件夾bingPicture失敗!"<<std::endl;
 53         else
 54             std::cout<<"創建文件夾bingPicture成功!"<<std::endl;
 55     else
 56         std::cout<<"文件夾bingPicture已存在!"<<std::endl;
 57 
 58     //本地Tmp路徑
 59     std::string LocalXmlFolder="C:/bingPicture/Tmp/";
 60 
 61     if(0!=access(LocalXmlFolder.c_str(),0))    //判斷文件夾是否存在,若不存在則創建
 62         if(0!=mkdir(LocalXmlFolder.c_str()))
 63             std::cout<<"創建臨時文件夾Tmp失敗!"<<std::endl;
 64         else
 65             std::cout<<"創建臨時文件夾Tmp成功!"<<std::endl;
 66     else
 67         std::cout<<"臨時文件夾Tmp已存在!"<<std::endl;
 68 
 69 }
 70 
 71 /**************************************************************************************
 72 首先明白一個概念,即string替換所有字符串,將"12212"這個字符串的所有"12"都替換成"21",結果是什么?
 73 可以是22211,也可以是21221,有時候應用的場景不同,就會希望得到不同的結果,所以這兩種答案都做了實現。
 74 **************************************************************************************/
 75 //替換字符串方法1(完全輪詢,替換一次后接著再次掃描,因為替換一次后可能又出現了滿足替換條件的字符串)
 76 std::string & replace_all(std::string& str,const std::string& old_value,const std::string& new_value)
 77 {
 78     while(true)   {
 79         std::string::size_type pos(0);
 80         if((pos=str.find(old_value))!=std::string::npos)
 81             str.replace(pos,old_value.length(),new_value);
 82         else
 83             break;
 84     }
 85     return str;
 86 }
 87 
 88 //替換字符串方法2(只替換一次) 本項目中,只替換\為/用方法2即可
 89 std::string & replace_all_distinct(std::string& str,const std::string& old_value,const std::string& new_value)
 90 {
 91     for(std::string::size_type pos(0);  pos!=std::string::npos; pos+=new_value.length())
 92     {
 93         if((pos=str.find(old_value,pos))!=std::string::npos)
 94             str.replace(pos,old_value.length(),new_value);
 95         else   break;
 96     }
 97     return str;
 98 }
 99 
100 //獲取年月日(命名用)
101 std::string getYearMonthDay()
102 {
103     time_t timer;
104     time(&timer);
105     tm* t_tm = localtime(&timer);
106 
107     std::string Year=std::to_string(t_tm->tm_year+1900);
108     std::string Month=std::to_string(t_tm->tm_mon+1);
109     std::string Day=std::to_string(t_tm->tm_mday);
110     std::string PictureName=Year+"_"+Month+"_"+Day;
111 
112     return PictureName;
113 }
114 
115 //獲取圖片的Xml并解析圖片的url路徑
116 std::string getPicTureXmlAndUrl()
117 {
118     //網絡上的XML路徑
119     std::string WebXmlpath ="http://cn.bing.com/HPImageArchive.aspx?format=xml&idx=0&n=1";
120     //本地Xml路徑
121     std::string LocalXmlFolder="C:/bingPicture/Tmp/";
122     std::string LocalXmleach=getYearMonthDay();
123     std::string LocalXmlFullpath=LocalXmlFolder+LocalXmleach+".xml";
124 
125     if(URLDownloadToFileA(NULL,
126                          WebXmlpath.c_str(),
127                          LocalXmlFullpath.c_str(),
128                          0,
129                          NULL)
130             ==S_OK)
131     {
132         std::cout<<"Xml下載成功!即將解析今日壁紙Url!"<<std::endl;
133 
134         /***************下面開始解析xml中的url路徑*******************/
135         tinyxml2::XMLDocument doc;
136         if(tinyxml2::XML_SUCCESS != doc.LoadFile(LocalXmlFullpath.c_str()))
137             std::cout<<"讀取Xml文件異常!"<<std::endl;
138         tinyxml2::XMLElement *images=doc.RootElement();
139         tinyxml2::XMLElement *image =images->FirstChildElement("image");
140 
141         //圖片Url
142         std::string WebPicturedomain="http://cn.bing.com";
143         std::string WebPictureUrl="";
144 
145         if(image!=NULL)
146             WebPictureUrl=image->FirstChildElement("url")->GetText();
147 
148         std::string WebPictureFullpath1366x768 =WebPicturedomain+WebPictureUrl;
149         std::cout<<"今日壁紙Url解析成功!"<<std::endl;
150         /*********************************************************/
151         return WebPictureFullpath1366x768;
152 //        //將1366x768換成1920x1080
153 //        std::string WebPictureFullpath1920x1080 =replace_all_distinct(WebPictureFullpath1366x768,"1366x768","1920x1080");
154 
155 //        return WebPictureFullpath1920x1080;
156     }
157     else
158     {
159         std::cout<<"Xml下載失敗!無法獲取圖片Url!請檢查網絡連接是否正常!"<<std::endl;
160         return "error";
161     }
162 
163 }
164 
165 //從網絡上下載圖片并存儲到本地
166 std::string getPicture(std::string WebFullpath)
167 {
168     //本地存儲路徑
169     std::string LocalFolder="C:/bingPicture/";
170     std::string Localeach=getYearMonthDay();
171     std::string LocalFullpath=LocalFolder+Localeach+".jpg";
172 
173     if(URLDownloadToFileA(NULL,
174                          WebFullpath.c_str(),
175                          LocalFullpath.c_str(),
176                          0,
177                          NULL)
178             ==S_OK)
179     {
180         std::cout<<"今日壁紙下載成功!"<<std::endl;
181 
182         /***************下面轉換圖片格式jpg->bmp******************/
183         //臨時文件夾Tmp路徑
184         std::string TmpFolder="C:/bingPicture/Tmp/";
185         //.bmp圖片路徑
186         std::string bmpFolder=TmpFolder+getYearMonthDay()+".bmp";
187         LoadJpegFile(const_cast<char *>(LocalFullpath.c_str()),const_cast<char *>(bmpFolder.c_str()));
188         /*******************************************************/
189         return bmpFolder;
190     }
191     else
192     {
193         std::cout<<"壁紙下載失敗!請檢查網絡連接是否正常!"<<std::endl;
194         return "error";
195     }
196 }
197 
198 //改變桌面背景成功后,刪除bmp文件和xml文件(只保留jpg文件),此步驟需要小心,避免刪除錯誤路徑下的內容
199 void deleteBmpAndXml()
200 {
201     //臨時文件夾Tmp路徑
202     std::string TmpFolder="C:/bingPicture/Tmp/";
203     //.bmp圖片路徑
204     std::string bmpFolder=TmpFolder+getYearMonthDay()+".bmp";
205     //xml文件路徑
206     std::string xmlFolder=TmpFolder+getYearMonthDay()+".xml";
207 
208     if(0==access("C:/bingPicture/Tmp/",0))    //判斷文件夾是否存在,若存在則刪除
209     {
210         //刪除bmp圖片
211         if(0==access(bmpFolder.c_str(),0))
212         {
213             if(0==remove(bmpFolder.c_str()))
214                 std::cout<<"刪除臨時bmp格式圖片成功!"<<std::endl;
215             else
216                 std::cout<<"刪除臨時bmp格式圖片失敗!"<<std::endl;
217         }
218         else
219             std::cout<<"臨時bmp格式圖片不存在!"<<std::endl;
220 
221         //刪除xml文件
222         if(0==access(xmlFolder.c_str(),0))
223         {
224             if(0==remove(xmlFolder.c_str()))
225                 std::cout<<"刪除xml文件成功!"<<std::endl;
226             else
227                 std::cout<<"刪除xml文件失敗!"<<std::endl;
228         }
229         else
230             std::cout<<"xml文件不存在!"<<std::endl;
231 
232         //刪除Tmp文件夾(注意此函數只能刪除空文件夾,因此要先刪除文件夾中的文件)
233         if(0==rmdir(TmpFolder.c_str()))
234             std::cout<<"臨時文件夾Tmp已刪除!"<<std::endl;
235         else
236             std::cout<<"臨時文件夾Tmp刪除失敗!"<<std::endl;
237     }
238     else
239         std::cout<<"臨時文件夾Tmp不存在!"<<std::endl;
240 
241 }
242 
243 //改變桌面背景(PictureFullpath:圖片完整路徑)
244 void changePicture(std::string PictureFullpath)
245 {
246     bool result=false;
247     result=SystemParametersInfoA(SPI_SETDESKWALLPAPER,
248                           0,
249                           (PVOID)PictureFullpath.c_str(),
250                           0);
251     if(result==false)
252     {
253         std::cout<<"今日壁紙更新失敗!請聯系開發人員!"<<std::endl;
254     }
255 
256     else
257     {
258         SystemParametersInfoA(SPI_SETDESKWALLPAPER,
259                                   0,
260                                   (PVOID)PictureFullpath.c_str(),
261                                   SPIF_SENDCHANGE);
262         //deleteBmpAndXml();    //windows8及其以上會變成黑色,把這條語句放到main最后面就沒問題,具體原因未知
263         system("cls");
264         std::cout<<"version:1.0.0 (Author:xiaoxi666)"<<std::endl<<std::endl;
265         std::cout<<"今日壁紙更新成功!"<<std::endl<<std::endl;
266         std::cout<<"美好的一天開始啦!用心享受吧!"<<std::endl<<std::endl;
267     }
268 }
269 
270 int main()
271 {
272     std::string startOrder="";
273     std::cout<<"嗨!小伙伴!你的貼心壁紙小助手已啟動!將為你設置今日壁紙哦!"<<std::endl<<std::endl;
274     std::cout<<"請確保電腦網絡連接狀況良好,準備好后輸入go"<<std::endl<<std::endl;
275     std::cout<<"請輸入指令: ";
276     std::cin>>startOrder;
277     while("go"!=startOrder)
278     {
279         std::cout<<"哎呀輸錯了呢,重新輸入吧: ";
280         std::cin>>startOrder;
281     }
282     if("go"==startOrder)
283     {
284         createDir();
285         changePicture(getPicture(getPicTureXmlAndUrl()));
286     }
287 
288     /*******************************以下為個性化字幕輸出,與程序核心功能無關************************/
289     std::string umua0="          **     **   ********   *******   *******   ***  ***     ";
290     std::string umua1="          **     **   ********   *******   *******   ***  ***     ";
291     std::string umua2="          **     **   **    **   **   **   ***  **   ***  ***     ";
292     std::string umua3="          **     **   **    **   **   **   ***  **    **  **      ";
293     std::string umua4="          *********   ********   *******   *******     *  *       ";
294     std::string umua5="          *********   ********   *******   **           **        ";
295     std::string umua6="          **     **   **    **   **        **           **        ";
296     std::string umua7="          **     **   **    **   **        **           **        ";
297     std::string umua8="          **     **   **    **   **        **           **        ";
298     std::string umua9="          **     **   **    **   **        **           **        ";
299 
300     #define mua(n) std::cout<<umua##n<<std::endl;
301     std::cout<<std::endl<<std::endl;
302     mua(0);mua(1);mua(2);mua(3);mua(4);mua(5);mua(6);mua(7);mua(8);mua(9);
303     std::cout<<std::endl<<std::endl<<std::endl;
304     system("pause");
305     /******************************************************************************************/
306     deleteBmpAndXml();
307     return 0;
308 }
View Code

?

圖片格式轉換程序(這個是網上下載的C源碼,我改了一下接口,在此感謝)

jpeg.h

//頭文件jpeg.h,配合程序jpeg2bmp.c使用
//若用于c++程序中,請用extern "C"包含此頭文件
//功能:用于將圖片從jpg類型轉換為bmp類型,調用函數LoadJpegFile即可,參數1:jpg文件路徑;參數2:bmp文件路徑#define M_SOF0  0xc0
#define M_DHT   0xc4
#define M_EOI   0xd9
#define M_SOS   0xda
#define M_DQT   0xdb
#define M_DRI   0xdd
#define M_APP0  0xe0static int Zig_Zag[8][8]={{0,1,5,6,14,15,27,28},{2,4,7,13,16,26,29,42},{3,8,12,17,25,30,41,43},{9,11,18,24,37,40,44,53},{10,19,23,32,39,45,52,54},{20,22,33,38,46,51,55,60},{21,34,37,47,50,56,59,61},{35,36,48,49,57,58,62,63}};#define W1 2841 /* 2048*sqrt(2)*cos(1*pi/16) */
#define W2 2676 /* 2048*sqrt(2)*cos(2*pi/16) */
#define W3 2408 /* 2048*sqrt(2)*cos(3*pi/16) */
#define W5 1609 /* 2048*sqrt(2)*cos(5*pi/16) */
#define W6 1108 /* 2048*sqrt(2)*cos(6*pi/16) */
#define W7 565  /* 2048*sqrt(2)*cos(7*pi/16) */int LoadJpegFile (char *JpegFileName,char *bmpFileName);
View Code

jpeg2bmp.c

//jpeg.c
//本程序用C語言編寫,若用于c++程序中,請用extern "C"包含頭文件jpeg.h
//功能:用于將圖片從jpg類型轉換為bmp類型,調用函數LoadJpegFile即可,參數1:jpg文件路徑;參數2:bmp文件路徑

#include "jpeg.h"
#include "memory.h"
#include "math.h"
#include "stdio.h"
#include "windows.h"//macro definition
#define WIDTHBYTES(i)    ((i+31)/32*4)
#define PI 3.1415926535
//define return value of function
#define FUNC_OK 0
#define FUNC_MEMORY_ERROR 1
#define FUNC_FILE_ERROR 2
#define FUNC_FORMAT_ERROR 3
//
//Jpeg functions
//int LoadJpegFile (char *JpegFileName,char *bmpFileName);
void showerror(int funcret);
int  InitTag();
void InitTable();
int  Decode();
int  DecodeMCUBlock();
int  HufBlock(unsigned char dchufindex,unsigned char achufindex);
int  DecodeElement();
void IQtIZzMCUComponent(short flag);
void IQtIZzBlock(short  *s ,int * d,short flag);
void GetYUV(short flag);
void StoreBuffer();
BYTE ReadByte();
void Initialize_Fast_IDCT();
void Fast_IDCT(int * block);
void idctrow(int * blk);
void idctcol(int * blk);
//
//global variable declaration
BITMAPFILEHEADER   bf;
BITMAPINFOHEADER   bi;
HBITMAP            hBitmap=NULL;
HGLOBAL            hImgData=NULL;
DWORD              NumColors;
DWORD              LineBytes;
DWORD              ImgWidth=0 , ImgHeight=0;
unsigned int       PcxBytesPerLine;
LPSTR              lpPtr;
//
//variables used in jpeg function
short            SampRate_Y_H,SampRate_Y_V;
short            SampRate_U_H,SampRate_U_V;
short            SampRate_V_H,SampRate_V_V;
short            H_YtoU,V_YtoU,H_YtoV,V_YtoV;
short            Y_in_MCU,U_in_MCU,V_in_MCU;
unsigned char   *lpJpegBuf;
unsigned char   *lp;
short            qt_table[3][64];
short            comp_num;
BYTE            comp_index[3];
BYTE            YDcIndex,YAcIndex,UVDcIndex,UVAcIndex;
BYTE            HufTabIndex;
short            *YQtTable,*UQtTable,*VQtTable;
BYTE            And[9]={0,1,3,7,0xf,0x1f,0x3f,0x7f,0xff};
short            code_pos_table[4][16],code_len_table[4][16];
unsigned short    code_value_table[4][256];
unsigned short    huf_max_value[4][16],huf_min_value[4][16];
short            BitPos,CurByte;
short            rrun,vvalue;
short            MCUBuffer[10*64];
int                QtZzMCUBuffer[10*64];
short            BlockBuffer[64];
short            ycoef,ucoef,vcoef;
BOOL            IntervalFlag;
short            interval=0;
int                Y[4*64],U[4*64],V[4*64];
DWORD            sizei,sizej;
short             restart;
static  long    iclip[1024];
static  long    *iclp;////
int LoadJpegFile (char *JpegFileName,char *bmpFileName)
{HFILE               hfjpg;DWORD                ImgSize;DWORD              JpegBufSize;HFILE              hfbmp;HGLOBAL               hJpegBuf;int                   funcret;LPBITMAPINFOHEADER lpImgData;if((hfjpg=_lopen(JpegFileName,OF_READ))==HFILE_ERROR){showerror(FUNC_FILE_ERROR);return 0;}//get jpg file lengthJpegBufSize=_llseek(hfjpg,0L,SEEK_END);//rewind to the beginning of the file_llseek(hfjpg,0L,SEEK_SET);if((hJpegBuf=GlobalAlloc(GHND,JpegBufSize))==NULL){_lclose(hfjpg);showerror(FUNC_MEMORY_ERROR);return 0;}lpJpegBuf=(unsigned char  *)GlobalLock(hJpegBuf);_hread(hfjpg,(unsigned char  *)lpJpegBuf,JpegBufSize);_lclose(hfjpg);InitTable();if((funcret=InitTag())!=FUNC_OK){GlobalUnlock(hJpegBuf);GlobalFree(hJpegBuf);showerror(funcret);return 0;}//create new bitmapfileheader and bitmapinfoheadermemset((char *)&bf,0,sizeof(BITMAPFILEHEADER));    memset((char *)&bi,0,sizeof(BITMAPINFOHEADER));bi.biSize=(DWORD)sizeof(BITMAPINFOHEADER);bi.biWidth=(LONG)(ImgWidth);bi.biHeight=(LONG)(ImgHeight);bi.biPlanes=1;bi.biBitCount=24;bi.biClrUsed=0;bi.biClrImportant=0;bi.biCompression=BI_RGB;NumColors=0;LineBytes=(DWORD)WIDTHBYTES(bi.biWidth*bi.biBitCount);ImgSize=(DWORD)LineBytes*bi.biHeight;bf.bfType=0x4d42;bf.bfSize=sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER)+NumColors*sizeof(RGBQUAD)+ImgSize;bf.bfOffBits=(DWORD)(NumColors*sizeof(RGBQUAD)+sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER));if((hImgData=GlobalAlloc(GHND,ImgSize))==NULL){GlobalUnlock(hJpegBuf);GlobalFree(hJpegBuf);showerror(FUNC_MEMORY_ERROR);return FALSE;}lpImgData=(LPBITMAPINFOHEADER)GlobalLock(hImgData); lpPtr=(char *)lpImgData;if((SampRate_Y_H==0)||(SampRate_Y_V==0)){GlobalUnlock(hJpegBuf);GlobalFree(hJpegBuf);GlobalUnlock(hImgData);GlobalFree(hImgData);hImgData=NULL;showerror(FUNC_FORMAT_ERROR);return FALSE ;}funcret=Decode();if(funcret==FUNC_OK){hfbmp=_lcreat(bmpFileName,0);_lwrite(hfbmp,(LPSTR)&bf,sizeof(BITMAPFILEHEADER)); //寫BMP文件頭_lwrite(hfbmp,(LPSTR)&bi,sizeof(BITMAPINFOHEADER)); //寫BMP文件信息_lwrite(hfbmp,(LPSTR)lpImgData,ImgSize);            //寫BMP位圖數據
        _lclose(hfbmp);GlobalUnlock(hJpegBuf);GlobalFree(hJpegBuf);GlobalUnlock(hImgData);return TRUE;}else{GlobalUnlock(hJpegBuf);GlobalFree(hJpegBuf);GlobalUnlock(hImgData);GlobalFree(hImgData);hImgData=NULL;showerror(funcret);return FALSE;}
}
/
void showerror(int funcret)
{switch(funcret){case FUNC_MEMORY_ERROR:printf("Error alloc memory!\n");   exit(1);break;case FUNC_FILE_ERROR:printf("File not found!!\n");   exit(1);break;case FUNC_FORMAT_ERROR:printf("File format error!\n");   exit(1);break;}
}
////
int InitTag()
{BOOL finish=FALSE;BYTE id;short  llength;short  i,j,k;short  huftab1,huftab2;short  huftabindex;BYTE hf_table_index;BYTE qt_table_index;BYTE comnum;unsigned char  *lptemp;short  ccount;lp=lpJpegBuf+2;while (!finish){id=*(lp+1);lp+=2;switch (id){case M_APP0:llength=MAKEWORD(*(lp+1),*lp);lp+=llength;break;case M_DQT:llength=MAKEWORD(*(lp+1),*lp);qt_table_index=(*(lp+2))&0x0f;lptemp=lp+3;if(llength<80){for(i=0;i<64;i++)qt_table[qt_table_index][i]=(short)*(lptemp++);}else{for(i=0;i<64;i++)qt_table[qt_table_index][i]=(short)*(lptemp++);qt_table_index=(*(lptemp++))&0x0f;for(i=0;i<64;i++)qt_table[qt_table_index][i]=(short)*(lptemp++);}lp+=llength;        break;case M_SOF0:llength=MAKEWORD(*(lp+1),*lp);ImgHeight=MAKEWORD(*(lp+4),*(lp+3));ImgWidth=MAKEWORD(*(lp+6),*(lp+5));comp_num=*(lp+7);if((comp_num!=1)&&(comp_num!=3))return FUNC_FORMAT_ERROR;if(comp_num==3){comp_index[0]=*(lp+8);SampRate_Y_H=(*(lp+9))>>4;SampRate_Y_V=(*(lp+9))&0x0f;YQtTable=(short *)qt_table[*(lp+10)];comp_index[1]=*(lp+11);SampRate_U_H=(*(lp+12))>>4;SampRate_U_V=(*(lp+12))&0x0f;UQtTable=(short *)qt_table[*(lp+13)];comp_index[2]=*(lp+14);SampRate_V_H=(*(lp+15))>>4;SampRate_V_V=(*(lp+15))&0x0f;VQtTable=(short *)qt_table[*(lp+16)];}else{comp_index[0]=*(lp+8);SampRate_Y_H=(*(lp+9))>>4;SampRate_Y_V=(*(lp+9))&0x0f;YQtTable=(short *)qt_table[*(lp+10)];comp_index[1]=*(lp+8);SampRate_U_H=1;SampRate_U_V=1;UQtTable=(short *)qt_table[*(lp+10)];comp_index[2]=*(lp+8);SampRate_V_H=1;SampRate_V_V=1;VQtTable=(short *)qt_table[*(lp+10)];}lp+=llength;                            break;case M_DHT:             llength=MAKEWORD(*(lp+1),*lp);if (llength<0xd0){huftab1=(short)(*(lp+2))>>4;     //huftab1=0,1huftab2=(short)(*(lp+2))&0x0f;   //huftab2=0,1huftabindex=huftab1*2+huftab2;lptemp=lp+3;for (i=0; i<16; i++)code_len_table[huftabindex][i]=(short)(*(lptemp++));j=0;for (i=0; i<16; i++)if(code_len_table[huftabindex][i]!=0){k=0;while(k<code_len_table[huftabindex][i]){code_value_table[huftabindex][k+j]=(short)(*(lptemp++));k++;}j+=k;    }i=0;while (code_len_table[huftabindex][i]==0)i++;for (j=0;j<i;j++){huf_min_value[huftabindex][j]=0;huf_max_value[huftabindex][j]=0;}huf_min_value[huftabindex][i]=0;huf_max_value[huftabindex][i]=code_len_table[huftabindex][i]-1;for (j=i+1;j<16;j++){huf_min_value[huftabindex][j]=(huf_max_value[huftabindex][j-1]+1)<<1;huf_max_value[huftabindex][j]=huf_min_value[huftabindex][j]+code_len_table[huftabindex][j]-1;}code_pos_table[huftabindex][0]=0;for (j=1;j<16;j++)code_pos_table[huftabindex][j]=code_len_table[huftabindex][j-1]+code_pos_table[huftabindex][j-1];lp+=llength;}  //ifelse{hf_table_index=*(lp+2);lp+=2;while (hf_table_index!=0xff){huftab1=(short)hf_table_index>>4;     //huftab1=0,1huftab2=(short)hf_table_index&0x0f;   //huftab2=0,1huftabindex=huftab1*2+huftab2;lptemp=lp+1;ccount=0;for (i=0; i<16; i++){code_len_table[huftabindex][i]=(short)(*(lptemp++));ccount+=code_len_table[huftabindex][i];}ccount+=17;    j=0;for (i=0; i<16; i++)if(code_len_table[huftabindex][i]!=0){k=0;while(k<code_len_table[huftabindex][i]){code_value_table[huftabindex][k+j]=(short)(*(lptemp++));k++;}j+=k;}i=0;while (code_len_table[huftabindex][i]==0)i++;for (j=0;j<i;j++){huf_min_value[huftabindex][j]=0;huf_max_value[huftabindex][j]=0;}huf_min_value[huftabindex][i]=0;huf_max_value[huftabindex][i]=code_len_table[huftabindex][i]-1;for (j=i+1;j<16;j++){huf_min_value[huftabindex][j]=(huf_max_value[huftabindex][j-1]+1)<<1;huf_max_value[huftabindex][j]=huf_min_value[huftabindex][j]+code_len_table[huftabindex][j]-1;}code_pos_table[huftabindex][0]=0;for (j=1;j<16;j++)code_pos_table[huftabindex][j]=code_len_table[huftabindex][j-1]+code_pos_table[huftabindex][j-1];lp+=ccount;hf_table_index=*lp;}  //while}  //elsebreak;case M_DRI:llength=MAKEWORD(*(lp+1),*lp);restart=MAKEWORD(*(lp+3),*(lp+2));lp+=llength;break;case M_SOS:llength=MAKEWORD(*(lp+1),*lp);comnum=*(lp+2);if(comnum!=comp_num)return FUNC_FORMAT_ERROR;lptemp=lp+3;for (i=0;i<comp_num;i++){if(*lptemp==comp_index[0]){YDcIndex=(*(lptemp+1))>>4;   //YYAcIndex=((*(lptemp+1))&0x0f)+2;}else{UVDcIndex=(*(lptemp+1))>>4;   //U,VUVAcIndex=((*(lptemp+1))&0x0f)+2;}lptemp+=2;}lp+=llength;finish=TRUE;break;case M_EOI:    return FUNC_FORMAT_ERROR;break;default:if ((id&0xf0)!=0xd0){llength=MAKEWORD(*(lp+1),*lp);lp+=llength;}else lp+=2;break;}  //switch} //whilereturn FUNC_OK;
}
/////
void InitTable()
{short i,j;sizei=sizej=0;ImgWidth=ImgHeight=0;rrun=vvalue=0;BitPos=0;CurByte=0;IntervalFlag=FALSE;restart=0;for(i=0;i<3;i++)for(j=0;j<64;j++)qt_table[i][j]=0;comp_num=0;HufTabIndex=0;for(i=0;i<3;i++)comp_index[i]=0;for(i=0;i<4;i++)for(j=0;j<16;j++){code_len_table[i][j]=0;code_pos_table[i][j]=0;huf_max_value[i][j]=0;huf_min_value[i][j]=0;}for(i=0;i<4;i++)for(j=0;j<256;j++)code_value_table[i][j]=0;for(i=0;i<10*64;i++){MCUBuffer[i]=0;QtZzMCUBuffer[i]=0;}for(i=0;i<4*64;i++){Y[i]=0;U[i]=0;V[i]=0;        }for(i=0;i<64;i++)BlockBuffer[i]=0;ycoef=ucoef=vcoef=0;
}
/
int Decode()
{int funcret;Y_in_MCU=SampRate_Y_H*SampRate_Y_V;U_in_MCU=SampRate_U_H*SampRate_U_V;V_in_MCU=SampRate_V_H*SampRate_V_V;H_YtoU=SampRate_Y_H/SampRate_U_H;V_YtoU=SampRate_Y_V/SampRate_U_V;H_YtoV=SampRate_Y_H/SampRate_V_H;V_YtoV=SampRate_Y_V/SampRate_V_V;Initialize_Fast_IDCT();while((funcret=DecodeMCUBlock())==FUNC_OK){interval++;if((restart)&&(interval % restart==0))IntervalFlag=TRUE;elseIntervalFlag=FALSE;IQtIZzMCUComponent(0);IQtIZzMCUComponent(1);IQtIZzMCUComponent(2);GetYUV(0);GetYUV(1);GetYUV(2);StoreBuffer();sizej+=SampRate_Y_H*8;if(sizej>=ImgWidth){sizej=0;sizei+=SampRate_Y_V*8;}if ((sizej==0)&&(sizei>=ImgHeight))break;}return funcret;
}
/////
void  GetYUV(short flag)
{short    H,VV;short    i,j,k,h;int        *buf;int        *pQtZzMCU;switch(flag){case 0:H=SampRate_Y_H;VV=SampRate_Y_V;buf=Y;pQtZzMCU=QtZzMCUBuffer;break;case 1:H=SampRate_U_H;VV=SampRate_U_V;buf=U;pQtZzMCU=QtZzMCUBuffer+Y_in_MCU*64;break;case 2:H=SampRate_V_H;VV=SampRate_V_V;buf=V;pQtZzMCU=QtZzMCUBuffer+(Y_in_MCU+U_in_MCU)*64;break;}for (i=0;i<VV;i++)for(j=0;j<H;j++)for(k=0;k<8;k++)for(h=0;h<8;h++)buf[(i*8+k)*SampRate_Y_H*8+j*8+h]=*pQtZzMCU++;
}
///
void StoreBuffer()
{short i,j;unsigned char  *lpbmp;unsigned char R,G,B;int y,u,v,rr,gg,bb;for(i=0;i<SampRate_Y_V*8;i++){if((sizei+i)<ImgHeight){lpbmp=((unsigned char *)lpPtr+(DWORD)(ImgHeight-sizei-i-1)*LineBytes+sizej*3);for(j=0;j<SampRate_Y_H*8;j++){if((sizej+j)<ImgWidth){y=Y[i*8*SampRate_Y_H+j];u=U[(i/V_YtoU)*8*SampRate_Y_H+j/H_YtoU];v=V[(i/V_YtoV)*8*SampRate_Y_H+j/H_YtoV];rr=((y<<8)+18*u+367*v)>>8;gg=((y<<8)-159*u-220*v)>>8;bb=((y<<8)+411*u-29*v)>>8;R=(unsigned char)rr;G=(unsigned char)gg;B=(unsigned char)bb;if (rr&0xffffff00) if (rr>255) R=255; else if (rr<0) R=0;if (gg&0xffffff00) if (gg>255) G=255; else if (gg<0) G=0;if (bb&0xffffff00) if (bb>255) B=255; else if (bb<0) B=0;*lpbmp++=B;*lpbmp++=G;*lpbmp++=R;}else  break;}}else break;}
}
///
int DecodeMCUBlock()
{short *lpMCUBuffer;short i,j;int funcret;if (IntervalFlag){lp+=2;ycoef=ucoef=vcoef=0;BitPos=0;CurByte=0;}switch(comp_num){case 3:lpMCUBuffer=MCUBuffer;for (i=0;i<SampRate_Y_H*SampRate_Y_V;i++)  //Y
        {funcret=HufBlock(YDcIndex,YAcIndex);if (funcret!=FUNC_OK)return funcret;BlockBuffer[0]=BlockBuffer[0]+ycoef;ycoef=BlockBuffer[0];for (j=0;j<64;j++)*lpMCUBuffer++=BlockBuffer[j];}for (i=0;i<SampRate_U_H*SampRate_U_V;i++)  //U
        {funcret=HufBlock(UVDcIndex,UVAcIndex);if (funcret!=FUNC_OK)return funcret;BlockBuffer[0]=BlockBuffer[0]+ucoef;ucoef=BlockBuffer[0];for (j=0;j<64;j++)*lpMCUBuffer++=BlockBuffer[j];}for (i=0;i<SampRate_V_H*SampRate_V_V;i++)  //V
        {funcret=HufBlock(UVDcIndex,UVAcIndex);if (funcret!=FUNC_OK)return funcret;BlockBuffer[0]=BlockBuffer[0]+vcoef;vcoef=BlockBuffer[0];for (j=0;j<64;j++)*lpMCUBuffer++=BlockBuffer[j];}break;case 1:lpMCUBuffer=MCUBuffer;funcret=HufBlock(YDcIndex,YAcIndex);if (funcret!=FUNC_OK)return funcret;BlockBuffer[0]=BlockBuffer[0]+ycoef;ycoef=BlockBuffer[0];for (j=0;j<64;j++)*lpMCUBuffer++=BlockBuffer[j];for (i=0;i<128;i++)*lpMCUBuffer++=0;break;default:return FUNC_FORMAT_ERROR;}return FUNC_OK;
}
//
int HufBlock(BYTE dchufindex,BYTE achufindex)
{short count=0;short i;int funcret;//dcHufTabIndex=dchufindex;funcret=DecodeElement();if(funcret!=FUNC_OK)return funcret;BlockBuffer[count++]=vvalue;//acHufTabIndex=achufindex;while (count<64){funcret=DecodeElement();if(funcret!=FUNC_OK)return funcret;if ((rrun==0)&&(vvalue==0)){for (i=count;i<64;i++)BlockBuffer[i]=0;count=64;}else{for (i=0;i<rrun;i++)BlockBuffer[count++]=0;BlockBuffer[count++]=vvalue;}}return FUNC_OK;
}
//
int DecodeElement()
{int thiscode,tempcode;unsigned short temp,valueex;short codelen;BYTE hufexbyte,runsize,tempsize,sign;BYTE newbyte,lastbyte;if(BitPos>=1){BitPos--;thiscode=(BYTE)CurByte>>BitPos;CurByte=CurByte&And[BitPos];}else{lastbyte=ReadByte();BitPos--;newbyte=CurByte&And[BitPos];thiscode=lastbyte>>7;CurByte=newbyte;}codelen=1;while ((thiscode<huf_min_value[HufTabIndex][codelen-1])||(code_len_table[HufTabIndex][codelen-1]==0)||(thiscode>huf_max_value[HufTabIndex][codelen-1])){if(BitPos>=1){BitPos--;tempcode=(BYTE)CurByte>>BitPos;CurByte=CurByte&And[BitPos];}else{lastbyte=ReadByte();BitPos--;newbyte=CurByte&And[BitPos];tempcode=(BYTE)lastbyte>>7;CurByte=newbyte;}thiscode=(thiscode<<1)+tempcode;codelen++;if(codelen>16)return FUNC_FORMAT_ERROR;}  //whiletemp=thiscode-huf_min_value[HufTabIndex][codelen-1]+code_pos_table[HufTabIndex][codelen-1];hufexbyte=(BYTE)code_value_table[HufTabIndex][temp];rrun=(short)(hufexbyte>>4);runsize=hufexbyte&0x0f;if(runsize==0){vvalue=0;return FUNC_OK;}tempsize=runsize;if(BitPos>=runsize){BitPos-=runsize;valueex=(BYTE)CurByte>>BitPos;CurByte=CurByte&And[BitPos];}else{valueex=CurByte;tempsize-=BitPos;while(tempsize>8){lastbyte=ReadByte();valueex=(valueex<<8)+(BYTE)lastbyte;tempsize-=8;}  //whilelastbyte=ReadByte();BitPos-=tempsize;valueex=(valueex<<tempsize)+(lastbyte>>BitPos);CurByte=lastbyte&And[BitPos];}  //elsesign=valueex>>(runsize-1);if(sign)vvalue=valueex;else{valueex=valueex^0xffff;temp=0xffff<<runsize;vvalue=-(short)(valueex^temp);}return FUNC_OK;
}
/
void IQtIZzMCUComponent(short flag)
{short H,VV;short i,j;int *pQtZzMCUBuffer;short  *pMCUBuffer;switch(flag){case 0:H=SampRate_Y_H;VV=SampRate_Y_V;pMCUBuffer=MCUBuffer;pQtZzMCUBuffer=QtZzMCUBuffer;break;case 1:H=SampRate_U_H;VV=SampRate_U_V;pMCUBuffer=MCUBuffer+Y_in_MCU*64;pQtZzMCUBuffer=QtZzMCUBuffer+Y_in_MCU*64;break;case 2:H=SampRate_V_H;VV=SampRate_V_V;pMCUBuffer=MCUBuffer+(Y_in_MCU+U_in_MCU)*64;pQtZzMCUBuffer=QtZzMCUBuffer+(Y_in_MCU+U_in_MCU)*64;break;}for(i=0;i<VV;i++)for (j=0;j<H;j++)IQtIZzBlock(pMCUBuffer+(i*H+j)*64,pQtZzMCUBuffer+(i*H+j)*64,flag);
}
//
void IQtIZzBlock(short  *s ,int * d,short flag)
{short i,j;short tag;short *pQt;int buffer2[8][8];int *buffer1;short offset;switch(flag){case 0:pQt=YQtTable;offset=128;break;case 1:pQt=UQtTable;offset=0;break;case 2:pQt=VQtTable;offset=0;break;}for(i=0;i<8;i++)for(j=0;j<8;j++){tag=Zig_Zag[i][j];buffer2[i][j]=(int)s[tag]*(int)pQt[tag];}buffer1=(int *)buffer2;Fast_IDCT(buffer1);for(i=0;i<8;i++)for(j=0;j<8;j++)d[i*8+j]=buffer2[i][j]+offset;
}
///
void Fast_IDCT(int * block)
{short i;for (i=0; i<8; i++)idctrow(block+8*i);for (i=0; i<8; i++)idctcol(block+i);
}
///
BYTE  ReadByte()
{BYTE  i;i=*(lp++);if(i==0xff)lp++;BitPos=8;CurByte=i;return i;
}
///
void Initialize_Fast_IDCT()
{short i;iclp = iclip+512;for (i= -512; i<512; i++)iclp[i] = (i<-256) ? -256 : ((i>255) ? 255 : i);
}

void idctrow(int * blk)
{int x0, x1, x2, x3, x4, x5, x6, x7, x8;//intcutif (!((x1 = blk[4]<<11) | (x2 = blk[6]) | (x3 = blk[2]) |(x4 = blk[1]) | (x5 = blk[7]) | (x6 = blk[5]) | (x7 = blk[3]))){blk[0]=blk[1]=blk[2]=blk[3]=blk[4]=blk[5]=blk[6]=blk[7]=blk[0]<<3;return;}x0 = (blk[0]<<11) + 128; // for proper rounding in the fourth stage //first stagex8 = W7*(x4+x5);x4 = x8 + (W1-W7)*x4;x5 = x8 - (W1+W7)*x5;x8 = W3*(x6+x7);x6 = x8 - (W3-W5)*x6;x7 = x8 - (W3+W5)*x7;//second stagex8 = x0 + x1;x0 -= x1;x1 = W6*(x3+x2);x2 = x1 - (W2+W6)*x2;x3 = x1 + (W2-W6)*x3;x1 = x4 + x6;x4 -= x6;x6 = x5 + x7;x5 -= x7;//third stagex7 = x8 + x3;x8 -= x3;x3 = x0 + x2;x0 -= x2;x2 = (181*(x4+x5)+128)>>8;x4 = (181*(x4-x5)+128)>>8;//fourth stageblk[0] = (x7+x1)>>8;blk[1] = (x3+x2)>>8;blk[2] = (x0+x4)>>8;blk[3] = (x8+x6)>>8;blk[4] = (x8-x6)>>8;blk[5] = (x0-x4)>>8;blk[6] = (x3-x2)>>8;blk[7] = (x7-x1)>>8;
}
//
void idctcol(int * blk)
{int x0, x1, x2, x3, x4, x5, x6, x7, x8;//intcutif (!((x1 = (blk[8*4]<<8)) | (x2 = blk[8*6]) | (x3 = blk[8*2]) |(x4 = blk[8*1]) | (x5 = blk[8*7]) | (x6 = blk[8*5]) | (x7 = blk[8*3]))){blk[8*0]=blk[8*1]=blk[8*2]=blk[8*3]=blk[8*4]=blk[8*5]=blk[8*6]=blk[8*7]=iclp[(blk[8*0]+32)>>6];return;}x0 = (blk[8*0]<<8) + 8192;//first stagex8 = W7*(x4+x5) + 4;x4 = (x8+(W1-W7)*x4)>>3;x5 = (x8-(W1+W7)*x5)>>3;x8 = W3*(x6+x7) + 4;x6 = (x8-(W3-W5)*x6)>>3;x7 = (x8-(W3+W5)*x7)>>3;//second stagex8 = x0 + x1;x0 -= x1;x1 = W6*(x3+x2) + 4;x2 = (x1-(W2+W6)*x2)>>3;x3 = (x1+(W2-W6)*x3)>>3;x1 = x4 + x6;x4 -= x6;x6 = x5 + x7;x5 -= x7;//third stagex7 = x8 + x3;x8 -= x3;x3 = x0 + x2;x0 -= x2;x2 = (181*(x4+x5)+128)>>8;x4 = (181*(x4-x5)+128)>>8;//fourth stageblk[8*0] = iclp[(x7+x1)>>14];blk[8*1] = iclp[(x3+x2)>>14];blk[8*2] = iclp[(x0+x4)>>14];blk[8*3] = iclp[(x8+x6)>>14];blk[8*4] = iclp[(x8-x6)>>14];blk[8*5] = iclp[(x0-x4)>>14];blk[8*6] = iclp[(x3-x2)>>14];blk[8*7] = iclp[(x7-x1)>>14];
}//main(   )
//{
//        LoadJpegFile("test.jpg");
//}
View Code

xml解析,我用的是TinyXml2開源庫,這個就不貼源碼了。

?

關于Qt項目圖標制作

我用的Qt版本是4.8.5。

步驟如下:

  1. 在Qt工程目錄下新建一個文本文件,并將其名稱改為 *.rc (名字任取)
  2. 將你的圖標文件.ico添加到項目中
  3. 打開該 rc 文件,在該rc文件里面加入以下一行文本(將文本中的*換成你的圖標的名字):

    IDI_ICON   ICON    DISCARDABLE     "*.ico" 
  4. 在項目文件.pro中加入以下文本(將*換成你的rc文件名字):

?     RC_FILE = \
??         ? *.rc

????? 5. 重新編譯工程即可

   

關于Qt項目的發布

Qt項目發布最麻煩的就是動態依賴庫,常用的工具是hap-depends,它可以查看軟件的依賴庫(*.dll),直接用它打開你的.exe文件,查看缺失哪些.dll文件,找到它們后和exe放在相同目錄即可。

當然,發布之前需要經過多個平臺的測試。

?

最后祝大家生活愉快!

轉載于:https://www.cnblogs.com/xiaoxi666/p/6544478.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/255138.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/255138.shtml
英文地址,請注明出處:http://en.pswp.cn/news/255138.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

UIProgressView 圓角

里面外面都變成圓角 不用圖片 直接改變layer 重點是里面外面都是圓角哦 for (UIImageView * imageview in self.progress.subviews) { imageview.layer.cornerRadius 5; imageview.clipsToBounds YES; } 轉載于:https://www.cnblogs.com/huoran1120/p/5563991.html

HALCON示例程序holes.hdev孔洞提取

HALCON示例程序holes.hdev孔洞提取 示例程序源碼&#xff08;加注釋&#xff09; 關于顯示類函數解釋 read_image (Image, ‘progres’) get_image_size (Image, Width, Height) dev_close_window () dev_open_window (0, 0, Width, Height, ‘white’, WindowID) dev_set_co…

給實例動態增加方法VS給類動態增加方法

一、給實例綁定方法 object.method MethodType(method,object) >>>class Badbrains(): pass >>>def mocking(self): print(Brain\s Mocking) >>>b Badbrains() >>>from types import MethodType >>>b.mocking MethodType(moc…

一句DOS命令搞定文件合并

用Dos的copy命令實現&#xff1a; copy a.jsb.jsc.js abc.js /b 將 a.js b.js c.js 合并為一個 abc.js&#xff0c;最后的 /b 表示文件為二進位文件&#xff0c;copy 命令的其它參數可以在 cmd 里輸入 copy /? 學習 舉例&#xff1a;如果想要合并多個js文件到某個目錄下&#…

DataTables warning: Requested unknown parameter '0' from the data source for row '0'

問題&#xff1a;DataTables warning: Requested unknown parameter 0 from the data source for row 0 代碼&#xff1a; <script type"text/javascript">var data [{"Name":"UpdateBootProfile","Result":"PASS",&…

HALCON示例程序hull.hdev區域提取與凸度篩選

HALCON示例程序hull.hdev區域提取與凸度篩選 示例程序源碼&#xff08;加注釋&#xff09; 關于顯示類函數解釋 read_image (Hull, ‘hull’) get_image_size (Hull, Width, Height) dev_close_window () dev_open_window (0, 0, Width, Height, ‘black’, WindowID) dev_di…

我與Linux系統的交集

2019獨角獸企業重金招聘Python工程師標準>>> 一、初識Linux 第一次知道Linux還是在我剛進大學的時候&#xff0c;從開始聊QQ、玩斗地主的時候起我就是用的Windows&#xff0c;從Windows2000一直到Windows7&#xff0c;當時我已經完全習慣了使用Windows&#xff0c;而…

squid白名單

http_access deny all #取消注釋 http_access allow all --> http_access allow xxx_custom_ip#添加系統服務器IP白名單 acl xdaili_custom_ip src 60.191.4.xxx/32 acl xdaili_custom_ip src 139.196.210.xxx/32 acl xdaili_custom_ip src 139.196.172.xxx/32 acl xdail…

HALCON示例程序IC.hdev通過電路板元器件定位識別

HALCON示例程序IC.hdev通過電路板元器件定位識別 示例程序源碼&#xff08;加注釋&#xff09; 關于顯示類函數解釋 dev_close_window () read_image (Image, ‘ic’) get_image_size (Image, Width, Height) dev_open_window (0, 0, Width, Height, ‘black’, WindowID) de…

IP頭、TCP頭、UDP頭詳解以及定義

一、MAC幀頭定義 /*數據幀定義&#xff0c;頭14個字節&#xff0c;尾4個字節*/ typedef struct _MAC_FRAME_HEADER { char m_cDstMacAddress[6]; //目的mac地址 char m_cSrcMacAddress[6]; //源mac地址 short m_cType;      //上一層協議類型&#xff0c;如…

關于iOS 3D touch 指紋驗證的隨筆

file:///Users/OWen/Desktop/3DTouch.png 隨著iOS系統不斷的更新迭代&#xff0c;蘋果總會推出一些新的功能&#xff0c;今天就研究了一下iOS8之后推出的指紋驗證的功能&#xff0c;然后寫了一個小demo&#xff0c;與君分享。。 上demo&#xff1a; 1&#xff1a;首先導入一個…

HALCON示例程序inner_rectangle1.hdev木板有效區域提取

HALCON示例程序inner_rectangle1.hdev木板有效區域提取 示例程序源碼&#xff08;加注釋&#xff09; 關于顯示類函數解釋 dev_update_window (‘off’) dev_update_var (‘off’) dev_update_pc (‘off’) read_image (Image, ‘wood_knots’) get_image_size (Image, Width…

vsCode ext install 不工作

vsCode 擴展商店 不可用 ext 不可用 ext install eamodio.gitlens 1、搜索離線插件https://marketplace.visualstudio.com/vscode 2、插件離線插件模板https://marketplace.gallery.vsassets.io/_apis/public/gallery/publisher/marketplace/extension/${extension name}/${ver…

遞歸實現 十進制轉換其他進制(2-16)

1 def to_str(n, base): 2 convert_string "0123456789ABCDEF" 3 if n < base: 4 return convert_string[n] 5 else: 6 return to_str(n / base, base) convert_string[n % base] 7 8 print to_str(168, 8) 轉載于:https://www.cn…

在UltraEdit的查找和替換中使用正則表達式 (轉)

很多朋友都用過或者正在用UltraEdit&#xff0c;這個編輯器陪伴我也好幾年了&#xff0c;從很多地方影響著我寫代碼的快捷鍵習慣&#xff0c;Ultraedit提供了非常豐富的編輯功能&#xff0c;其中非常重要的查找和替換功能一定大家都用過&#xff0c;Ultraedit提供的查找替換功能…

基本 TCP 套接字編程講解

基于 TCP 的套接字編程的所有客戶端和服務器端都是從調用socket 開始&#xff0c;它返回一個套接字描述符。客戶端隨后調用connect 函數&#xff0c;服務器端則調用 bind、listen 和accept 函數。 使用套接口客戶機服務器的的例子 sever.c #include <stdio.h> #include &…

HALCON示例程序inspect_bga.hdev測量bga焊點缺陷

HALCON示例程序inspect_bga.hdev測量bga焊點缺陷 示例程序源碼&#xff08;加注釋&#xff09; 關于顯示類函數解釋 read_image (Image, ‘bga_14x14_model’) get_image_pointer1 (Image, Pointer, Type, Width, Height) dev_update_off () dev_close_window () dev_open_win…

怎樣屏蔽微信朋友圈視頻?局域網如何禁止員工看朋友圈視頻?

上班時間刷刷朋友圈&#xff0c;一眨眼半小時就過去了。不但會影響工作效率&#xff0c;而且朋友圈的視頻會占用大量的帶寬。所以對企業管理人員來說&#xff0c;很多時候需要禁止員工在工作時段刷朋友圈。但是行政手段要和技術手段配合&#xff0c;才可以發揮真正的作用。本文…

cf414B(dp)

題目鏈接&#xff1a;http://codeforces.com/problemset/problem/414/B 題意&#xff1a;定義所有元素是其前一個元素的倍數的數列為good sequence&#xff0c;給出 n, 和 k&#xff0c;求1....n組成的長度為k的good sequence 的數目&#xff1b; 思路&#xff1a;dp 用dp[i][j…

安裝IIS

安裝IIS過程中我們需要很多系統文件,這個時候我們就要下載一個非GHOST版本的系統安裝文件就可以了, 雨林木風安裝版8.0 http://dx.lwkb.com/setup/YlmF_XPSP3_YS8.0F/YlmF_XPSP3_YS8.0F.iso 這個不錯 轉載于:https://www.cnblogs.com/toSeeMyDream/p/5574884.html