亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? roundb~2.cpp

?? 《vc游戲編程導學》一書的原代碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// RoundButton.cpp : implementation file
//
// Round Buttons!
//
//
// This code may be used in compiled form in any way you desire. This
// file may be redistributed unmodified by any means PROVIDING it is 
// not sold for profit without the authors written consent, and 
// providing that this notice and the authors name is included. If 
// the source code in this file is used in any commercial application 
// then a simple email would be nice.
//
// This file is provided "as is" with no expressed or implied warranty.
// The author accepts no liability if it causes any damage to your
// computer, causes your pet cat to fall ill, increases baldness or
// makes you car start emitting strange noises when you start it up.
//
// Expect bugs.
// 
// Please use and enjoy. Please let me know of any bugs/mods/improvements 
// that you have found/implemented and I will fix/incorporate them into this
// file. 
//
/////////////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "math.h"
#include "RoundButton.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

// prototypes
COLORREF GetColour(double dAngle, COLORREF crBright, COLORREF crDark);
void DrawCircle(CDC* pDC, CPoint p, LONG lRadius, COLORREF crColour, BOOL bDashed = FALSE);
void DrawCircleLeft(CDC* pDC, CPoint p, LONG lRadius, COLORREF crBright, COLORREF crDark);
void DrawCircleRight(CDC* pDC, CPoint p, LONG lRadius, COLORREF crBright, COLORREF crDark);


// Calculate colour for a point at the given angle by performing a linear
// interpolation between the colours crBright and crDark based on the cosine
// of the angle between the light source and the point.
//
// Angles are measured from the +ve x-axis (i.e. (1,0) = 0 degrees, (0,1) = 90 degrees )
// But remember: +y points down!

COLORREF GetColour(double dAngle, COLORREF crBright, COLORREF crDark)
{
#define Rad2Deg	180.0/3.1415 

// For better light-continuity along the edge of a stretched button: 
//	LIGHT_SOURCE_ANGLE == -1.88
	
//#define LIGHT_SOURCE_ANGLE	-2.356		// -2.356 radians = -135 degrees, i.e. From top left
#define LIGHT_SOURCE_ANGLE	-1.88

	ASSERT(dAngle > -3.1416 && dAngle < 3.1416);
	double dAngleDifference = LIGHT_SOURCE_ANGLE - dAngle;

	if (dAngleDifference < -3.1415) dAngleDifference = 6.293 + dAngleDifference;
	else if (dAngleDifference > 3.1415) dAngleDifference = 6.293 - dAngleDifference;

	double Weight = 0.5*(cos(dAngleDifference)+1.0);

	BYTE Red   = (BYTE) (Weight*GetRValue(crBright) + (1.0-Weight)*GetRValue(crDark));
	BYTE Green = (BYTE) (Weight*GetGValue(crBright) + (1.0-Weight)*GetGValue(crDark));
	BYTE Blue  = (BYTE) (Weight*GetBValue(crBright) + (1.0-Weight)*GetBValue(crDark));

	//TRACE("LightAngle = %0.0f, Angle = %3.0f, Diff = %3.0f, Weight = %0.2f, RGB %3d,%3d,%3d\n", 
	//	  LIGHT_SOURCE_ANGLE*Rad2Deg, dAngle*Rad2Deg, dAngleDifference*Rad2Deg, Weight,Red,Green,Blue);

	return RGB(Red, Green, Blue);
}

void DrawCircle(CDC* pDC, CPoint p, LONG lRadius, COLORREF crColour, BOOL bDashed)
{
	const int nDashLength = 1;
	LONG lError, lXoffset, lYoffset;
	int  nDash = 0;
	BOOL bDashOn = TRUE;

	//Check to see that the coordinates are valid
	ASSERT( (p.x + lRadius <= LONG_MAX) && (p.y + lRadius <= LONG_MAX) );
	ASSERT( (p.x - lRadius >= LONG_MIN) && (p.y - lRadius >= LONG_MIN) );

	//Set starting values
	lXoffset = lRadius;
	lYoffset = 0;
	lError   = -lRadius;

	do {
		if (bDashOn) {
			pDC->SetPixelV(p.x + lXoffset, p.y + lYoffset, crColour);
			pDC->SetPixelV(p.x + lXoffset, p.y - lYoffset, crColour);
			pDC->SetPixelV(p.x + lYoffset, p.y + lXoffset, crColour);
			pDC->SetPixelV(p.x + lYoffset, p.y - lXoffset, crColour);
			pDC->SetPixelV(p.x - lYoffset, p.y + lXoffset, crColour);
			pDC->SetPixelV(p.x - lYoffset, p.y - lXoffset, crColour);
			pDC->SetPixelV(p.x - lXoffset, p.y + lYoffset, crColour);
			pDC->SetPixelV(p.x - lXoffset, p.y - lYoffset, crColour);
		}

		//Advance the error term and the constant X axis step
		lError += lYoffset++;

		//Check to see if error term has overflowed
		if ((lError += lYoffset) >= 0)
			lError -= --lXoffset * 2;

		if (bDashed && (++nDash == nDashLength)) {
			nDash = 0;
			bDashOn = !bDashOn;
		}

	} while (lYoffset <= lXoffset);	//Continue until halfway point
} 

// The original Drawcircle function is split up into DrawCircleRight and DrawCircleLeft
// to make stretched buttons
//
void DrawCircleRight(CDC* pDC, CPoint p, LONG lRadius, COLORREF crBright, COLORREF crDark)
{
	LONG lError, lXoffset, lYoffset;

	//Check to see that the coordinates are valid
	ASSERT( (p.x + lRadius <= LONG_MAX) && (p.y + lRadius <= LONG_MAX) );
	ASSERT( (p.x - lRadius >= LONG_MIN) && (p.y - lRadius >= LONG_MIN) );

	//Set starting values
	lXoffset = lRadius;
	lYoffset = 0;
	lError   = -lRadius;

	do {
		const double Pi = 3.141592654, 
					 Pi_on_2 = Pi * 0.5,
					 Three_Pi_on_2 = Pi * 1.5;
		COLORREF crColour;
		double   dAngle = atan2(lYoffset, lXoffset);

		//Draw the current pixel, reflected across all four arcs

		crColour = GetColour(dAngle, crBright, crDark);
		pDC->SetPixelV(p.x + lXoffset, p.y + lYoffset, crColour);

		crColour = GetColour(Pi_on_2 - dAngle, crBright, crDark);
		pDC->SetPixelV(p.x + lYoffset, p.y + lXoffset, crColour);

		crColour = GetColour(-Pi_on_2 + dAngle, crBright, crDark);
		pDC->SetPixelV(p.x + lYoffset, p.y - lXoffset, crColour);

		crColour = GetColour(-dAngle, crBright, crDark);
		pDC->SetPixelV(p.x + lXoffset, p.y - lYoffset, crColour);

		//Advance the error term and the constant X axis step
		lError += lYoffset++;

		//Check to see if error term has overflowed
		if ((lError += lYoffset) >= 0)
			lError -= --lXoffset * 2;

	} while (lYoffset <= lXoffset);	//Continue until halfway point
} 

// The original Drawcircle function is split up into DrawCircleRight and DrawCircleLeft
// to make stretched buttons
//
void DrawCircleLeft(CDC* pDC, CPoint p, LONG lRadius, COLORREF crBright, COLORREF crDark)
{
	LONG lError, lXoffset, lYoffset;

	//Check to see that the coordinates are valid
	ASSERT( (p.x + lRadius <= LONG_MAX) && (p.y + lRadius <= LONG_MAX) );
	ASSERT( (p.x - lRadius >= LONG_MIN) && (p.y - lRadius >= LONG_MIN) );

	//Set starting values
	lXoffset = lRadius;
	lYoffset = 0;
	lError   = -lRadius;

	do {
		const double Pi = 3.141592654, 
					 Pi_on_2 = Pi * 0.5,
					 Three_Pi_on_2 = Pi * 1.5;
		COLORREF crColour;
		double   dAngle = atan2(lYoffset, lXoffset);

		//Draw the current pixel, reflected across all eight arcs

		crColour = GetColour(Pi_on_2 + dAngle, crBright, crDark);
		pDC->SetPixelV(p.x - lYoffset, p.y + lXoffset, crColour);

		crColour = GetColour(Pi - dAngle, crBright, crDark);
		pDC->SetPixelV(p.x - lXoffset, p.y + lYoffset, crColour);

		crColour = GetColour(-Pi + dAngle, crBright, crDark);
		pDC->SetPixelV(p.x - lXoffset, p.y - lYoffset, crColour);

		crColour = GetColour(-Pi_on_2 - dAngle, crBright, crDark);
		pDC->SetPixelV(p.x - lYoffset, p.y - lXoffset, crColour);

		//Advance the error term and the constant X axis step
		lError += lYoffset++;

		//Check to see if error term has overflowed
		if ((lError += lYoffset) >= 0)
			lError -= --lXoffset * 2;

	} while (lYoffset <= lXoffset);	//Continue until halfway point
} 

static void	CreateButtonRgn(CRgn & rgn, const CRect & rect, const CPoint & ptLeft, const CPoint & ptRight, int nRadius) {
	CBrush brush;
	brush.CreateSolidBrush(::GetSysColor(COLOR_BTNFACE));

	// left circle
	CRgn rgnLeftCircle;
	VERIFY(rgnLeftCircle.CreateEllipticRgn(ptLeft.x-nRadius, ptLeft.y-nRadius, ptLeft.x+nRadius, ptLeft.y+nRadius));
	VERIFY(rgn.CreateEllipticRgn(ptLeft.x-nRadius, ptLeft.y-nRadius, ptLeft.x+nRadius, ptLeft.y+nRadius));
	CRgn rgnLeftPart;
	VERIFY(rgnLeftPart.CreateEllipticRgn(ptLeft.x-nRadius, ptLeft.y-nRadius, ptLeft.x+nRadius, ptLeft.y+nRadius));

	// main body
	CRgn rgnMainBody;
	VERIFY(rgnMainBody.CreateRectRgn(rect.left+nRadius, rect.top, rect.right-nRadius, rect.bottom));

	CRgn rgnRightCircle;
	VERIFY(rgnRightCircle.CreateEllipticRgn(ptRight.x+2+nRadius, ptRight.y+nRadius, ptRight.x+2-nRadius, ptRight.y-nRadius));

	// OK now combine the regions
	VERIFY(rgnLeftPart.CombineRgn(&rgnLeftCircle, &rgnMainBody, RGN_OR) != ERROR);

	VERIFY(rgn.CombineRgn(&rgnLeftPart, &rgnRightCircle, RGN_OR) != ERROR);
}

/////////////////////////////////////////////////////////////////////////////
// CRoundButton

CRoundButton::CRoundButton()
{
	m_bDrawDashedFocusCircle = TRUE;
}

CRoundButton::~CRoundButton()
{
	m_rgn.DeleteObject();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91亚洲男人天堂| 在线播放日韩导航| 7777精品久久久大香线蕉| 久久―日本道色综合久久| 一区二区三区在线免费视频| 激情小说亚洲一区| 欧美美女激情18p| 亚洲乱码国产乱码精品精的特点| 蜜臀精品久久久久久蜜臀 | 美女视频黄久久| 色综合天天综合网国产成人综合天| 日韩亚洲电影在线| 亚洲一区在线观看免费| 99久久er热在这里只有精品15 | 在线观看av一区二区| 日本一区二区视频在线| 午夜精品久久久久久久久久久| 国产激情91久久精品导航| 欧美一区二区视频观看视频| 一区二区三区四区在线| av一区二区不卡| 国产精品婷婷午夜在线观看| 美女网站色91| 日韩免费视频一区二区| 日韩av电影免费观看高清完整版| 在线看国产一区二区| 综合av第一页| 一本色道综合亚洲| 亚洲欧美色图小说| 色综合久久99| 亚洲一区二区精品久久av| 在线欧美日韩国产| 午夜免费欧美电影| 在线观看不卡视频| 亚洲高清视频的网址| 欧美喷潮久久久xxxxx| 亚洲第一福利一区| 69p69国产精品| 理论电影国产精品| 26uuu精品一区二区| 国产盗摄女厕一区二区三区| 亚洲自拍都市欧美小说| 色婷婷av一区二区三区gif | 午夜精品久久久久久久久| 欧美日韩久久久久久| 婷婷久久综合九色综合伊人色| 欧美人成免费网站| 国内精品免费在线观看| 国产三级欧美三级日产三级99| 成人免费看黄yyy456| 最新国产の精品合集bt伙计| 91国偷自产一区二区使用方法| 天堂蜜桃一区二区三区| 欧美精品一区二区三区四区| 国产成人aaaa| 亚洲一区电影777| 欧美一级欧美三级| 成人开心网精品视频| 亚洲国产三级在线| 精品第一国产综合精品aⅴ| 成人午夜视频在线观看| 亚洲一区二区欧美激情| 日韩小视频在线观看专区| 国产成人精品影院| 亚洲一区二区三区不卡国产欧美 | 国产欧美一区二区精品忘忧草| 成人高清免费在线播放| 亚洲小说春色综合另类电影| 久久久欧美精品sm网站| 色天天综合久久久久综合片| 激情综合网天天干| 亚洲一区二区视频在线观看| 日韩精品中文字幕一区| 91麻豆精品视频| 紧缚奴在线一区二区三区| 日韩伦理免费电影| 精品久久久三级丝袜| 91女厕偷拍女厕偷拍高清| 国产曰批免费观看久久久| 一区二区三区在线不卡| 久久久久亚洲蜜桃| 欧美中文一区二区三区| 成人午夜短视频| 日本欧美大码aⅴ在线播放| 亚洲男帅同性gay1069| 精品91自产拍在线观看一区| 欧美精选一区二区| 91丝袜美女网| 国产91丝袜在线播放| 美女一区二区三区在线观看| 一区二区三区在线视频观看| 国产精品青草综合久久久久99| 日韩视频一区二区三区在线播放| 91网站视频在线观看| 国产精品99久久不卡二区| 奇米色一区二区三区四区| 亚洲乱码国产乱码精品精小说| 国产一区二区三区不卡在线观看 | 国产精品水嫩水嫩| 欧美在线免费播放| 国产jizzjizz一区二区| 久久不见久久见免费视频1| 亚洲国产婷婷综合在线精品| 亚洲色图另类专区| 中文字幕一区av| 国产精品乱人伦一区二区| 久久影视一区二区| 国产亚洲女人久久久久毛片| 精品久久久久久综合日本欧美| 在线综合亚洲欧美在线视频| 欧美最猛黑人xxxxx猛交| 色噜噜偷拍精品综合在线| 99国产精品久久久久久久久久| thepron国产精品| 91在线播放网址| 在线观看中文字幕不卡| 91福利精品视频| 欧美色综合久久| 欧美高清视频一二三区| 91麻豆精品国产91久久久| 日韩一区二区免费在线观看| 国产精品三级久久久久三级| 国产色产综合产在线视频| 亚洲一区二区在线播放相泽| 日韩一区二区三区视频在线观看| 欧美三片在线视频观看| 欧美日韩一区二区三区在线| 欧美高清www午色夜在线视频| 欧美一区二区在线免费播放| 欧美一级久久久| 久久―日本道色综合久久| 国产精品久久久久影院色老大| 亚洲色图欧洲色图婷婷| 亚洲午夜久久久久久久久电影院| 亚洲一区二区综合| 老司机精品视频导航| 国产在线观看一区二区 | 亚洲第一成人在线| 美女视频一区在线观看| 大胆亚洲人体视频| 欧美图区在线视频| 日韩精品专区在线影院观看| 国产精品视频你懂的| 亚洲人成网站影音先锋播放| 午夜电影一区二区三区| 国产精品资源在线看| 99r精品视频| 4hu四虎永久在线影院成人| www一区二区| 亚洲尤物在线视频观看| 看电视剧不卡顿的网站| fc2成人免费人成在线观看播放| 欧美区一区二区三区| 日本一区二区三区高清不卡| 亚洲高清久久久| 国产精品2024| 91麻豆精品国产无毒不卡在线观看| 日本一区二区三区视频视频| 亚洲sss视频在线视频| 国产成人久久精品77777最新版本| 色综合久久久久综合99| 久久色视频免费观看| 亚洲精品欧美专区| 国产99久久精品| 91精品欧美一区二区三区综合在| 国产精品国模大尺度视频| 另类小说图片综合网| 色综合中文字幕国产| 日韩三级精品电影久久久| 亚洲色图在线视频| 国产99一区视频免费| 日韩欧美国产午夜精品| 亚洲高清免费在线| 91丨九色丨尤物| 国产精品视频你懂的| 国产一区二区三区在线观看免费视频| 欧美午夜免费电影| 亚洲欧美一区二区视频| 国产剧情av麻豆香蕉精品| 日韩欧美国产综合在线一区二区三区| 一区二区三区四区亚洲| av福利精品导航| 中文字幕 久热精品 视频在线| 美脚の诱脚舐め脚责91| 欧美丰满高潮xxxx喷水动漫| 亚洲免费伊人电影| www.色综合.com| 欧美激情在线看| 粉嫩嫩av羞羞动漫久久久| 欧美刺激午夜性久久久久久久| 亚洲网友自拍偷拍| 欧美色图一区二区三区| 亚洲猫色日本管| 91在线porny国产在线看| 亚洲欧洲日韩一区二区三区| 成人app下载| 国产精品毛片a∨一区二区三区| 国产高清无密码一区二区三区| 欧美mv和日韩mv的网站| 麻豆一区二区在线|