主頁 >  其他 > MFC第一天——雙緩沖繪圖演算法

MFC第一天——雙緩沖繪圖演算法

2022-09-12 06:43:54 其他

2022-09-11

雙緩沖演算法的一個實體即為如下影片:

 

 

 

 

 由結果圖可以看出,

(1)其中有一個白色的小球,因此需要創建一個小球類,在創建小球類之前,先創建一個MFC專案,

  創建一個MFC專案的步驟:

    首先打開VS,點擊新建;點擊MFC應用;更改存放路徑,更改專案名稱,例如:“DoubleBufferes”,點擊下一步;在彈出的“MFC應用程式”視窗中,找到“應用程式型別”,點擊下拉選單,選擇“單個檔案”;在這一頁旁邊的“專案樣式”中選擇“MFC standard”樣式,之后點擊完成,即創建好了一個MFC應用專案,

創建好專案后,添加一個小球類,步驟如下:

    在右側的“解決方案”中,選中專案名稱“DoubleBufferes”,右擊點擊“添加”,選擇“類”;在彈出的類的設定中,填寫類名,例如:“CSphere”

CSphere.h檔案

 1 #pragma once
 2 class CSphere
 3 {
 4 public:
 5     CSphere(void);//建構式
 6     virtual ~CSphere(void);//解構式
 7     void SetParameter(int R,CPoint CenterPoint);
 8     void Draw(CDC* pDC);
 9 public:
10     int R;//球體半徑
11     CPoint CenterPoint;
12 
13 };

  說明:

    ①一直以來,我不太明白,建構式明明是 “CSphere()”,那為什么第5行內部要加一個void,很不理解,后來我查了一下,給出的解釋是這樣的,如果將void 作為引數傳給建構式或者其他函式,則說明該函式不支持引數的傳入,就相當于CSphere(),可能就是一個習慣寫法吧,

    ②代碼第6行:是一個解構式的宣告,那為啥解構式前面要加上“virtual”虛函式的關鍵字呢?這里要特別加入“virtual”關鍵字是為了防止記憶體泄露,那為啥不使用“virtual”關鍵字修飾就會發生記憶體泄露呢?這里有一種這樣的情況,如果該類作為父類,創建了子類后,創建子類物件后,子類物件占用了一定的記憶體空間后,當洗掉子類物件時,要呼叫子類解構式,由于沒有使用“virtual”虛關鍵字,就構不成動態系結,實際上只呼叫了父類的解構式,但沒有呼叫子類的解構式,那么子類占用的那部分記憶體空間就會得不到釋放,造成記憶體泄露,

    ③代碼第7行:設定球心的坐標,以及半徑,

    ④代碼第8行:表示使用CDC繪制小球,

  

  注意:

    在上面的定義,在第7行代碼中,寫到"CPoint”和第8行“CDC”時,發現飄紅了,就很奇怪,這后又重新看了一下講課視頻,發現了這個問題產生的原因是還未寫完全,沒有宣告,需要點擊“DoubleBufferesView.h”檔案,打開后,從上往下找到第三個“protected:”,在里面添加要宣告的內容,如下:

protected:
    int nWidth, nHeight;
    CSphere sphere;
    CPoint direction;
    BOOL bPlay;

  注意:

    在定義“CSphere”類的變數時,需要添加一個頭檔案,

#include"CSphere.h"

CSphere.cpp檔案:

 1 #include "pch.h"
 2 #include "CSphere.h"
 3 CSphere::CSphere(void){
 4 }
 5 CSphere::~CSphere(void){
 6 }
 7 void CSphere::SetParameter(int R, CPoint CenterPoint) {
 8     this->R = R;
 9     this->CenterPoint = CenterPoint;
10 }
11 
12 void CSphere::Draw(CDC* pDC) {
13     CPoint TopLet(CenterPoint.x - R, CenterPoint.y - R);
14     CPoint BottomRight(CenterPoint.x + R, CenterPoint.y + R);
15     CRect Square(TopLet, BottomRight);
16     pDC->Ellipse(Square);
17 }

  說明:

    在繪制小球的函式中(第12行代碼),先設定了兩個點,一個是左上角點,另一個是右下角點,需要說明的一點是,客戶區內的x-y軸中的圓點初始是設定在左上角點,x軸是用上到下,y軸是從左到右,設定兩個點后,將他們作為“CRect”類的兩個引數進行傳入,最后使用繪圖指標“pDC”進行繪制橢圓,參入的引數即為上面設定好的矩形,這里表示的是在給定的矩形內繪制它的內切橢圓,

(2)由運行結果圖中可以看出,

  選單欄中有“檔案”、“幫助”、“圖形(G)”,其中在圖形的下拉選單中還有一個“繪圖(A)”的選項,而且在第二行中有一個“播放的紅色的按鈕”,在這一步中需要設定選單欄的選項,

  ①首先,點擊選單欄中的“視圖”,找到“其他視窗”,點擊“資源視圖”,

  ②在資源視圖中,找到“Menu”檔案夾,點擊其檔案夾下的“IDR_MAINFRAME”,打開后會看到一橫排“檔案”、“編輯”...工具列,現在可以將不用的選項洗掉,只留下“檔案(F)”,“幫助(H)”;在這一排的后面會有一個文本框,顯示“請在此處鍵入”,可以輸入“圖形(G)”;后選中“圖形(G)”,在它的內部設定一個選項“繪圖(A)”,

  選中“繪圖(A)”,右擊屬性,找到“ID”,將“ID”設定為“ID_ANIMATION”,ctrl+s保存,這一步一定要記住設定,因為后面會設定回應函式,需要用到,

  ③設定“播放按鈕圖示”,點擊“資源視圖”中的“Toolbar”,"Toolbar"是設定圖示的地方,點擊“Toolbar”內部的“IDR_MAINFRAME”,會看到第一排是一些常用的圖示,此處將這些圖示洗掉,留下最后一個就可以,如果這里直接選中圖示然后點擊“Delete”會發現里面的圖示是洗掉了,但是會遺留下很多白色的小方塊,so如果要洗掉,那么要將第一排的小方塊拖到第二排左邊就洗掉了,

  在最后一個小方塊中,可以先用上面工具列中的放大鏡放大,之后使用畫筆工具畫一個“播放按鈕”,此時,點擊第一排繪制好的“播放按鈕”,右擊,選擇屬性,將ID仍然設定為“ID_ANIMATION”,

  此時,運行結果圖中的選單欄已設定完成,

 

 (3)有一個小的細節,結果圖中的名稱是“雙緩沖演算法”,那么它是如何設定的呢?

    找到“解決方案資源管理器”,點擊“DoubleBufferes.cpp”,找到第125行代碼,在它下面加入一條陳述句,用于設定標題的名稱,如下

m_pMainWnd->SetWindowTextW(CString("雙緩沖演算法"));

 

 (4)由結果圖可以看出小球有規律地在運動,so里面使用了一個定時器,那么就設定一個定時器

  首先,點擊"DoubleBufferesView.cpp"檔案,在該檔案中的建構式中,寫入如下代碼,設定小球

1 CDoubleBufferesView::CDoubleBufferesView() noexcept
2 {
3     // TODO: 在此處添加構造代碼
4     bPlay = FALSE;
5     sphere.R = GetSystemMetrics(SM_CXFULLSCREEN) / 20;
6     sphere.CenterPoint.x = 200, sphere.CenterPoint.y = 200;
7     direction.x = 1, direction.y = 1;
8 
9 }

    說明:

      在第5行代碼中,“GetSystemMetrics(SM_CXFULLSCREEN)”陳述句表示“客戶區的寬度1280”,第4行先設定了一個影片開始按鈕的標志,初始值設為“FALSE”,第5,6行設定小球物件的球心與半徑,第7行設定x軸與y軸移動的步長,

   

  繪制小球(DrawObject):

    添加函式的步驟:

      點擊“專案”,點擊“類向導”,在類名中,定位到“CDoubleBufferesView”,點擊“方法”,添加方法,設定好函式名,回傳值,引數,點擊確定,代碼如下:

 

1 void CDoubleBufferesView::DrawObject(CDC* pDC)//繪制圖形
2 {
3     // TODO: 在此處添加實作代碼.
4     sphere.Draw(pDC);
5 }

 

  

  其次,設定定時器,

    步驟:

      ①點擊"專案",之后點擊“類向導”,在彈出的“類向導”中,找到“類名(N)”,在下拉選單中,定位到“CDoubleBufferesView”;之后點擊“訊息”,在輸入框中輸入“WM——TIMER”,點擊它,右邊有一個“添加處理程式”點擊,

      ②同時設定映射函式,此時設定映射函式是為了在里面設定控制定時器的內容,點擊“命令”找到剛剛設定的“ID_ANIMATION”,點擊右邊“訊息”中的“COMMAND”,點擊“添加處理程式”;統一的操作再來一次,這回“訊息”設定為“UPDATE_COMMAND_UI”,

      ③最后,點擊“確定”,

    

    定時器內部的代碼:

1 void CDoubleBufferesView::OnTimer(UINT_PTR nIDEvent)
2 {
3     // TODO: 在此添加訊息處理程式代碼和/或呼叫默認值
4     sphere.CenterPoint += direction;
5     Invalidate(FALSE);
6 
7     CView::OnTimer(nIDEvent);
8 }

        說明:

          在第4行代碼中,每次移動一次,則將小球中心點的位置增加一個步長的單位,第5行代碼表示停止畫面一直重繪,

    

    OnAnimation函式中的代碼:

 1 void CDoubleBufferesView::OnAnimation()
 2 {
 3     // TODO: 在此添加命令處理程式代碼
 4     bPlay = !bPlay;
 5     if (bPlay)
 6         SetTimer(1, 10, NULL);
 7     else
 8         KillTimer(1);
 9 
10 }

        說明:

          該函式表明,如果影片按鈕標志“bPlay”為“True”,即點擊了單數次按鈕,那么影片開始播放;如果影片按鈕標志“bPlay”為“False”,即點擊了雙數次按鈕,那么影片停止播放,

 

    OnUpdateAnimation函式:

1 void CDoubleBufferesView::OnUpdateAnimation(CCmdUI *pCmdUI)
2 {
3     // TODO: 在此添加命令更新用戶界面處理程式代碼
4     if (bPlay)
5         pCmdUI->SetCheck(TRUE);
6     else
7         pCmdUI->SetCheck(FALSE);
8 }

 

(4)從運行結果圖,可以看到當小球碰到客戶區四周后,會反彈,那么當碰到后,會有一個檢查函式,用來改變方向,碰撞函式“CollisionDetection”的添加,點擊“專案”,點擊“類向導”,在彈出的“類向導”中,定位“類名”為“CDoubleBufferesView”,點擊“方法”,點擊“添加方法”,設定“函式名”、“回傳型別”、“引數”等,點擊確定,

  CollisionDetection函式

 1 void CDoubleBufferesView::CollisionDetection(void)
 2 {
 3     // TODO: 在此處添加實作代碼.
 4     if (sphere.CenterPoint.x - sphere.R < 0)
 5         direction.x = 1;
 6     if (sphere.CenterPoint.x + sphere.R > nWidth)
 7         direction.x = -1;
 8     if (sphere.CenterPoint.y - sphere.R < 0)
 9         direction.y = 1;
10     if (sphere.CenterPoint.y + sphere.R > nHeight)
11         direction.y = -1;
12 }

    說明:

      第4行是碰到左邊框、第6行是碰到右邊框、第8行是碰到上邊框、第10行是碰到下邊框,

      當碰到左邊框時,小球的x坐標向右增加,其他的同理,

 

(5)從運行結果圖可以看出,小球的運動影像是平滑的,不會一幀一陣的閃,那是因為設定了雙緩沖函式,

    添加函式步驟添同添加碰撞函式類似,代碼如下:

 1 void CDoubleBufferesView::DoubleBuffer(CDC* pDC)//雙緩沖繪圖
 2 {
 3     // TODO: 在此處添加實作代碼.
 4     CRect rect;
 5     GetClientRect(&rect);
 6     nWidth = rect.Width(), nHeight = rect.Height();
 7     CDC memDC;
 8     memDC.CreateCompatibleDC(pDC);
 9     CBitmap NewBitmap, *poldBitmap;
10     NewBitmap.CreateCompatibleBitmap(pDC, rect.Width(), rect.Height());
11     memDC.FillSolidRect(rect, RGB(0, 0, 0));
12     poldBitmap = memDC.SelectObject(&NewBitmap);
13     DrawObject(&memDC);
14     CollisionDetection();
15     pDC->BitBlt(0, 0, nWidth, nHeight, &memDC, 0, 0, SRCCOPY);
16     memDC.SelectObject(poldBitmap);
17     NewBitmap.DeleteObject();
18     memDC.DeleteDC();
19 }

      說明:

        第4,5,6行代碼是設定了一個客戶區矩形,

        第7行:定義記憶體DC,

        第8行:創建一個與顯示DC兼容的記憶體DC,

        第9行設定一個新的矢量圖和一個舊的矢量圖指針,

        第10行創建兼容記憶體位圖,

        第11行使用黑色填充客戶區,

        第12行將兼容位圖選入記憶體DC,

        第13行繪制小球,

        第14行碰撞檢測,

        第15行顯示記憶體位圖,

        第16,17,18恢復記憶體緩沖區,并洗掉新位圖和緩沖區,

 

(6)最后在OnDraw函式中呼叫雙緩沖函式,完成,

  注意:此處引數中“pDC”是注釋的,要先將注釋去掉,

 1 void CDoubleBufferesView::OnDraw(CDC* pDC)
 2 {
 3     CDoubleBufferesDoc* pDoc = GetDocument();
 4     ASSERT_VALID(pDoc);
 5     if (!pDoc)
 6         return;
 7 
 8     // TODO: 在此處為本機資料添加繪制代碼
 9     DoubleBuffer(pDC);
10 }

 

 

 

   

    

  

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/506135.html

標籤:其他

上一篇:真正在大廠干了幾年,我學會了反內卷[轉]

下一篇:匿名遠程啟動jenkins的job

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more