将屏幕保存为图片,使用vs2008编译通过。
#include "stdafx.h" #include <windows.h> #include <atlimage.h> int __stdcall WinMain( HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nShowCmd) { HWND hwnd = ::GetDesktopWindow(); HDC hDC = ::GetDC(hwnd);//获取屏幕DC RECT rect; ::GetClientRect(hwnd, &rect);//获取屏幕大小 HDC hDCMem = ::CreateCompatibleDC(hDC);//创建兼容DC HBITMAP hBitMap = ::CreateCompatibleBitmap(hDC, rect.right, rect.bottom);//创建兼容位图 HBITMAP hOldMap = (HBITMAP)::SelectObject(hDCMem, hBitMap);//将位图选入DC,并保存返回值 ::BitBlt(hDCMem, 0, 0, rect.right, rect.bottom, hDC, 0, 0, SRCCOPY);//将屏幕DC的图象复制到内存DC中 CImage image; image.Attach(hBitMap); image.Save(_T("c://B.jpg"));//如果文件后缀为.bmp,则保存为为bmp格式 image.Detach(); ::SelectObject(hDCMem, hOldMap);//选入上次的返回值 //释放 ::DeleteObject(hBitMap); ::DeleteDC(hDCMem); ::DeleteDC(hDC); return 0; }
将当前MFC程序(这里是单文档程序)保存为图片,使用vs2005。第一个使用CImage类保存图片,第二个使用BITMAPINFO。
第一个:
void CMainFrame::OnGetMap() { HWND hwnd = this->GetSafeHwnd(); HDC hDC = ::GetWindowDC(hwnd);//获取DC RECT rect; ::GetWindowRect(hwnd, &rect);//获取屏幕大小 HDC hDCMem = ::CreateCompatibleDC(hDC);//创建兼容DC HBITMAP hBitMap = ::CreateCompatibleBitmap(hDC, rect.right-rect.left, rect.bottom-rect.top);//创建兼容位图 HBITMAP hOldMap = (HBITMAP)::SelectObject(hDCMem, hBitMap);//将位图选入DC,并保存返回值 ::BitBlt(hDCMem, 0, 0, rect.right-rect.left, rect.bottom-rect.top, hDC, 0, 0, SRCCOPY);//将屏幕DC的图象复制到内存DC中 CImage image;//需要#include <atlimage.h> image.Attach(hBitMap); image.Save(_T("c://B.jpg"));//如果文件后缀为.bmp,则保存为为bmp格式 image.Detach(); ::SelectObject(hDCMem, hOldMap);//选入上次的返回值 //释放 ::DeleteObject(hBitMap); ::DeleteDC(hDCMem); ::DeleteDC(hDC); }
第二个:
void CMainFrame::OnGetMap() { CDC* pDC = GetWindowDC(); CBitmap bitmap; CDC memDC ; CRect rect; GetWindowRect(rect); memDC.CreateCompatibleDC(pDC); bitmap.CreateCompatibleBitmap(pDC,rect.Width(),rect.Height()); memDC.SelectObject(&bitmap); memDC.BitBlt(0,0,rect.Width(),rect.Height(),pDC,0,0,SRCCOPY); CFileDialog fDlg(FALSE,_T("bmp"),NULL,OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,_T("位图文件|*.bmp"),this); if (fDlg.DoModal()==IDOK) { CString bmpfile = fDlg.GetPathName(); CFile file(bmpfile,CFile::modeCreate|CFile::modeWrite); BITMAP bInfo; bitmap.GetBitmap(&bInfo); //计算调色板大小 int panelsize = 0; if (bInfo.bmBitsPixel<24) //非真彩色 { panelsize = pow((double)2,bInfo.bmBitsPixel)*sizeof(RGBQUAD); } //定义位图信息 BITMAPINFO* bMapInfo = (BITMAPINFO*)LocalAlloc(LPTR,sizeof(BITMAPINFO)+panelsize); bMapInfo->bmiHeader.biBitCount = bInfo.bmBitsPixel; bMapInfo->bmiHeader.biClrImportant = 0; bMapInfo->bmiHeader.biCompression = 0; bMapInfo->bmiHeader.biHeight = bInfo.bmHeight; bMapInfo->bmiHeader.biPlanes = bInfo.bmPlanes; bMapInfo->bmiHeader.biSize = sizeof(BITMAPINFO); bMapInfo->bmiHeader.biSizeImage = bInfo.bmHeight*bInfo.bmWidthBytes; bMapInfo->bmiHeader.biWidth = bInfo.bmWidth; bMapInfo->bmiHeader.biXPelsPerMeter = 0; bMapInfo->bmiHeader.biYPelsPerMeter = 0; //获取位图的实际数据 char* pData = new char[bMapInfo->bmiHeader.biSizeImage]; int len = GetDIBits(pDC->m_hDC,bitmap,0,bInfo.bmHeight,pData,bMapInfo,DIB_RGB_COLORS); BITMAPFILEHEADER bFileHeader; bFileHeader.bfType = 0x4D42; bFileHeader.bfReserved1 = 0; bFileHeader.bfReserved2 = 0; bFileHeader.bfSize = sizeof(BITMAPFILEHEADER); bFileHeader.bfOffBits = sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER)+panelsize; //向文件中写入位图数据 file.Write(&bFileHeader,sizeof(BITMAPFILEHEADER)); file.Write(&bMapInfo->bmiHeader,sizeof(BITMAPINFOHEADER)); file.Write(pData,bMapInfo->bmiHeader.biSizeImage+panelsize); file.Close(); delete pData; LocalFree(bMapInfo); } bitmap.DeleteObject(); memDC.DeleteDC(); }
二叉樹 「二叉樹 binary tree」是一種非線性數據結構,代表“祖先”與“後代”之間的派生關係,體現了“一分爲二” 的分治邏輯。與鏈表類似,二叉樹的基本單元是節點,每個節點包含值、左子節點引用和右子節點引用。 每個節點都有兩個引
和c++中還是有些區別的,c#中需要new圖像,還有就是在設置size時,也要new一下。 using OpenCvSharp; using OpenCvSharp.Extensions; Mat resize_image = new
滴滴滴~ NebulaGraph 今年再次參與由中科院軟件所“開源軟件供應鏈點亮計劃”發起的開源之夏啦! 關於開源之夏 “開源之夏”(簡稱 OSPP)是中國科學院軟件研究所發起的“開源軟件供應鏈點亮計劃系列”暑期活動,旨
前面松哥寫了一篇文章和大家聊了 Spring6 中引入的新玩意 AOT(見Spring Boot3 新玩法,AOT 優化!)。 文章發出來之後,有小夥伴問松哥有沒有做性能比較,老實說,這個給落下了,所以今天再來一篇文章,和小夥伴們梳理比較小
cheerp 通用計算模塊(ccm1) 是基於cheerp 編譯器發射出平臺格式無關的wasm中間代碼,在不同宿主之內運行的一種模塊化方式。 0x1. 不同宿主的相同代碼實現 ccm1 的一般宿主是c++實現,不同平臺編譯引用就可以,目
從可視化編排到支持 YAML 編排 雲效流水線 Flow 是開箱即用的企業級持續集成和持續交付工具,支持豐富的代碼源、構建、自動化測試工具、多種部署類型和部署方式,與阿里雲深度集成,還提供多種企業級特性,助力企業高效完成從開發到上線 CIC
本文介紹了 InnoDB 支持哪幾類表鎖,以及它們分別都用在什麼場景下,還介紹了其中兩類表鎖爲什麼要存在。 作者:操盛春,愛可生技術專家,公衆號『一樹一溪』作者,專注於研究 MySQL 和 OceanBase 源碼。 愛可生開源社區出品,
原方法 /** * 動態更新form * @param form */ updateForm(form) { this.form.manholeId = form.manholeId; this.form
詳解 binlog 時間戳與 exec_time 的關係。 作者:李錫超,蘇商銀行DBA,負責數據庫和中間件運維和建設。擅長 MySQL、Python、Oracle,愛好騎行、技術研究和分享。 愛可生開源社區出品,原創內容未經授權不得隨意
背景 最近領導分配了個任務,測試sit環境一些功能相比之前慢了許多,需要優化一下。 問題排查過程 瀏覽器F12查看相關接口的響應,看到底是哪個接口反應慢,根據互聯網的要求,頁面3秒還沒有顯示出來,用戶體驗會非常差。 查看相關代碼的提交
1、下載: https://www.docker.com/products/docker-desktop/ 如果電腦分多個盤,建議下載到可用存儲較大的盤,安裝的時候默認安裝到 C 盤,安裝完成後雙擊啓動 如果出現【Docker
OpenAI 發佈 ChatGPT-4o,意味着人機交互進入新的時代。Chat-GPT4o 是一個跨文本、視覺和音頻端到端訓練的新模型,所有輸入和輸出都由同一個神經網絡處理。這也在告訴所有人,GenAI 連接非結構化數據,非結構化數據之間跨
CSDN應該是大家接觸到最多的博客平臺了,所以一款能夠發佈到CSDN的自動化工具還是非常有必要的。 今天給大家講講自動化CSDN博客發佈的思路和一些問題的解決辦法。 解決問題的思路一定是最重要的,知識是死的,問題是活的,如何在工作中解決遇
在某些生產環境下,我們僅需要一個原生的 K8s 集羣,無需部署 KubeSphere 這樣的圖形化管理控制檯。在我們已有的技術棧裏,已經習慣了利用 KubeKey 部署 KubeSphere 和 K8s 集羣。今天,我將爲大家實戰演示如何在
infoq的博客發佈界面也是非常簡潔的。首頁就只有基本的標題,內容和封面圖片,所以infoq的實現也相對比較簡單。 一起來看看吧。 前提條件 前提條件當然是先下載 blog-auto-publishing-tools這個博客自動發佈工具,地