自繪static控制元件,實現特殊效果
#pragma once
// CMyStatic
class CMyStatic : public CStatic
{
DECLARE_DYNAMIC(CMyStatic)
public:
CMyStatic();
virtual ~CMyStatic();
protected:
DECLARE_MESSAGE_MAP()
private:
int m_iDrawFlag;//0無繪,1左繪,2右繪,3左右繪
int m_iDrawNum;//序列迴圈次數
int m_iDrawType;//需要繪製的圖片
bool m_bSelected;//當前是否被選中
public:
void SetDrawFlag(int iDrawFlag) {m_iDrawFlag = iDrawFlag;}
void SetDrawNum(int iDrawNum) {m_iDrawNum = iDrawNum;}
void SetDrawType(int iDrawType) {m_iDrawType = iDrawType;}
void SetSelected(bool bSel) {m_bSelected = bSel;}
afx_msg void OnPaint();
};
// MyStatic.cpp : 實現檔案
//
#include "stdafx.h"
#include "TestDock.h"
#include "MyStatic.h"
// CMyStatic
IMPLEMENT_DYNAMIC(CMyStatic, CStatic)
CMyStatic::CMyStatic()
: m_iDrawFlag(0)
, m_iDrawNum(0)
, m_iDrawType(0)
, m_bSelected(false)
{
//ModifyStyle(0,SS_BITMAP|SS_CENTERIMAGE);
}
CMyStatic::~CMyStatic()
{
}
BEGIN_MESSAGE_MAP(CMyStatic, CStatic)
ON_WM_PAINT()
END_MESSAGE_MAP()
// CMyStatic 訊息處理程式
void CMyStatic::OnPaint()
{
CPaintDC dc(this); // device context for painting
// TODO: 在此處新增訊息處理程式程式碼
// 不為繪圖訊息呼叫 CStatic::OnPaint()
CRect reWnd;
GetClientRect(&reWnd);
//dc.MoveTo(reWnd.left+2, reWnd.top+2);
//dc.LineTo(reWnd.left+2, reWnd.bottom-2);
//dc.MoveTo(reWnd.right-2, reWnd.top+2);
//dc.LineTo(reWnd.right-2, reWnd.bottom-2);
dc.SetTextColor(RGB(255,0,255));
dc.SetBkMode(TRANSPARENT);
CPen pen(PS_SOLID, 2, RGB(255,0,0));
CPen* pOldPen = dc.SelectObject(&pen);
if (!m_bSelected)
{
dc.FillSolidRect(reWnd, RGB(0,255,255));
}
else
{
dc.FillSolidRect(reWnd, RGB(255,255,0));
}
CImage img;
if (m_iDrawType == 0)
{
img.Load(L"res\\self.png");
}
else
{
img.Load(L"res\\CurTrade.png");
}
CRect reImg = reWnd;
reImg.DeflateRect(3,3);
img.Draw(dc.m_hDC, reImg);
const int ciLeft = 6;
const int ciTop = 6;
if (m_iDrawFlag == 3)
{
//左右繪
dc.MoveTo(reWnd.left+ciLeft*2, reWnd.top+ciTop);
dc.LineTo(reWnd.left+ciLeft, reWnd.top+ciTop);
dc.LineTo(reWnd.left+ciLeft, reWnd.bottom-ciTop);
dc.LineTo(reWnd.left+ciLeft*2, reWnd.bottom-ciTop);
CString csText;
csText.Format(L"%d", m_iDrawNum);
dc.TextOutW(reWnd.right-ciLeft*4, reWnd.top+ciTop*2, csText);
dc.MoveTo(reWnd.right-ciLeft*2, reWnd.top+ciTop);
dc.LineTo(reWnd.right-ciLeft, reWnd.top+ciTop);
dc.LineTo(reWnd.right-ciLeft, reWnd.bottom-ciTop);
dc.LineTo(reWnd.right-ciLeft*2, reWnd.bottom-ciTop);
}
else if (m_iDrawFlag == 1)
{
//左繪
dc.MoveTo(reWnd.left+ciLeft*2, reWnd.top+ciTop);
dc.LineTo(reWnd.left+ciLeft, reWnd.top+ciTop);
dc.LineTo(reWnd.left+ciLeft, reWnd.bottom-ciTop);
dc.LineTo(reWnd.left+ciLeft*2, reWnd.bottom-ciTop);
}
else if (m_iDrawFlag == 2)
{
//右繪
CString csText;
csText.Format(L"%d", m_iDrawNum);
dc.TextOutW(reWnd.right-ciLeft*4, reWnd.top+ciTop*2, csText);
dc.MoveTo(reWnd.right-ciLeft*2, reWnd.top+ciTop);
dc.LineTo(reWnd.right-ciLeft, reWnd.top+ciTop);
dc.LineTo(reWnd.right-ciLeft, reWnd.bottom-ciTop);
dc.LineTo(reWnd.right-ciLeft*2, reWnd.bottom-ciTop);
}
else
{
//無繪
}
dc.SelectObject(pOldPen);
}
相關文章
- Qt實現表格樹控制元件-自繪樹節點虛線QT控制元件
- QML::自繪基礎控制元件控制元件
- 自繪選單的實現 (轉)
- 自繪實現半透明水晶按鈕
- 自繪按鈕實現顏色選擇器
- 用VC++實現自繪按鈕控制 (轉)
- android: 一次自繪控制元件的體驗Android控制元件
- 利用static來實現單例模式單例模式
- 繪圖的實現繪圖
- QTableView表格控制元件區域選擇-自繪選擇區域QTView控制元件
- 第十講 特殊效果操作
- 如何透過前端表格控制元件實現自動化報表?前端控制元件
- JavaScript實現類的private、protected、public、static以及繼承JavaScript繼承
- Qt實現自定義控制元件QT控制元件
- Jquery實現拖拽式繪圖工具jQuery繪圖
- Android動畫實現繪製原理Android動畫
- Flask SocketIO 實現動態繪圖Flask繪圖
- canvas實現手動繪製矩形Canvas
- 在 Maui 中自繪元件1:繪製UI元件
- 自定義DropDownList控制元件的實現控制元件
- C#實現控制元件陣列C#控制元件陣列
- Repeater控制元件的分頁實現控制元件
- CentOS6.5下實現R繪圖CentOS繪圖
- PyQt5視窗繪圖控制元件QT繪圖控制元件
- 實現控制元件的移動、改變大小(DELPHI實現) (轉)控制元件
- 自定義TextBox控制元件的實現控制元件
- C#實現控制元件陣列 (轉)C#控制元件陣列
- .Net中用ajax控制元件實現功能(例)控制元件
- WPF實現html中的table控制元件HTML控制元件
- Android模擬器繪製實現概述Android
- PyQt5——視窗繪圖類控制元件QT繪圖控制元件
- Qt實現控制元件的漸隱漸現動效QT控制元件
- DELPHI也可以實現控制元件陣列,用定義陣列變數實現控制元件陣列 (轉)控制元件陣列變數
- 微信小程式Tree自定義控制元件實現微信小程式控制元件
- QT實現可拖動自定義控制元件QT控制元件
- 實現對DataGird控制元件的繫結操作控制元件
- Android實現圖片滾動控制元件Android控制元件
- 使用javascript 實現.net 驗證控制元件功能JavaScript控制元件