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

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

?? roundb~2.cpp

?? 俄羅斯方塊源代碼
?? 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蜜桃网址入口| 北岛玲一区二区三区四区| 欧美少妇性性性| 国产精品伦理在线| 久色婷婷小香蕉久久| 日本乱人伦一区| 国产欧美日韩另类一区| 日本aⅴ精品一区二区三区| 91丝袜高跟美女视频| 国产日韩欧美精品电影三级在线| 亚洲综合999| av一二三不卡影片| 久久久久久亚洲综合影院红桃| 香蕉成人伊视频在线观看| 91麻豆精品在线观看| 欧美国产日本视频| 国产精品一区二区在线观看不卡| 日韩亚洲欧美在线观看| 天天影视色香欲综合网老头| 99re8在线精品视频免费播放| 久久综合色综合88| 精品一区二区免费| 欧美成人精品3d动漫h| 秋霞午夜av一区二区三区| 欧美高清hd18日本| 人人爽香蕉精品| 日韩亚洲欧美成人一区| 日本一区中文字幕| 日韩欧美中文字幕制服| 奇米精品一区二区三区四区| 欧美精品777| 久久99日本精品| 久久香蕉国产线看观看99| 韩国三级在线一区| 国产欧美日韩卡一| av网站免费线看精品| 亚洲欧美偷拍卡通变态| 欧洲亚洲精品在线| 亚洲成人av免费| 91麻豆精品91久久久久同性| 免费观看91视频大全| 日韩精品一区二区在线观看| 久久99精品久久久| 久久久久久久电影| 成人黄色av网站在线| 亚洲欧美另类小说| 8x福利精品第一导航| 精一区二区三区| 国产精品激情偷乱一区二区∴| 97精品电影院| 日产精品久久久久久久性色| 精品成人一区二区| 91色综合久久久久婷婷| 亚洲成国产人片在线观看| 日韩欧美中文字幕精品| 成人精品亚洲人成在线| 一个色妞综合视频在线观看| 欧美一卡2卡3卡4卡| 国产精品一二三区| 一区二区欧美在线观看| 日韩精品综合一本久道在线视频| 国产综合色产在线精品| 亚洲丝袜另类动漫二区| 在线综合亚洲欧美在线视频| 国产69精品一区二区亚洲孕妇| 亚洲人成伊人成综合网小说| 欧美一级黄色录像| av不卡在线播放| 日韩成人av影视| 国产精品久久久久久久久快鸭 | 精品国产免费一区二区三区四区 | 99精品国产视频| 亚洲v日本v欧美v久久精品| 精品久久久久久久人人人人传媒| 91亚洲精品乱码久久久久久蜜桃| 免费一级欧美片在线观看| 中文字幕一区免费在线观看| 91精品国产丝袜白色高跟鞋| 欧美日韩一区在线观看| 韩国精品主播一区二区在线观看| 亚洲欧美色图小说| 国产视频一区二区三区在线观看| 欧美色图激情小说| 91在线云播放| 国产成人免费在线观看不卡| 日韩在线卡一卡二| 亚洲免费av网站| 国产清纯白嫩初高生在线观看91 | 中文字幕五月欧美| 日韩免费看网站| 欧美日韩国产高清一区二区三区 | 欧美高清视频在线高清观看mv色露露十八 | 一区二区三区欧美| 日本一区二区三区四区在线视频| 日韩一区二区中文字幕| 欧美亚洲禁片免费| 日本福利一区二区| 97精品久久久久中文字幕| 国产99精品国产| 国产久卡久卡久卡久卡视频精品| 久久99精品久久久久久动态图| 日日夜夜一区二区| 天天色 色综合| 视频一区欧美日韩| 午夜精品视频在线观看| 亚洲国产精品一区二区久久恐怖片| 国产精品国产三级国产有无不卡| 久久精品在这里| 亚洲国产精品麻豆| 一区二区三区在线视频观看| 亚洲欧洲精品一区二区三区不卡| 国产欧美日韩三级| 国产精品青草久久| 国产精品成人免费精品自在线观看| 久久精品亚洲乱码伦伦中文| 久久综合av免费| www亚洲一区| 欧美国产国产综合| √…a在线天堂一区| 一二三区精品视频| 无码av免费一区二区三区试看| 日本aⅴ免费视频一区二区三区| 免费成人av在线播放| 精品一区二区三区免费| 国产·精品毛片| 色综合天天狠狠| 欧美日韩亚洲丝袜制服| 欧美一区二区黄| 精品福利视频一区二区三区| 国产欧美日本一区视频| 亚洲欧美一区二区三区久本道91| 一级日本不卡的影视| 日韩高清在线一区| 国产精品白丝jk黑袜喷水| 99久久国产综合色|国产精品| 欧美亚洲一区二区在线| 日韩精品一区二区三区四区| 国产亚洲短视频| 亚洲小说欧美激情另类| 免费日韩伦理电影| 99精品视频一区| 欧美一级黄色片| 亚洲色图另类专区| 麻豆精品久久久| 北条麻妃国产九九精品视频| 欧美人与禽zozo性伦| 久久久一区二区三区捆绑**| 亚洲日本va午夜在线影院| 婷婷久久综合九色国产成人| 国产精品亚洲第一| 欧美三日本三级三级在线播放| 日韩精品中文字幕一区| 亚洲美女偷拍久久| 毛片av一区二区| 在线亚洲一区二区| 久久久一区二区三区| 亚洲国产精品精华液网站| 国内精品伊人久久久久av影院| 91极品视觉盛宴| 欧美国产欧美综合| 麻豆精品国产91久久久久久| 91香蕉国产在线观看软件| 26uuu亚洲婷婷狠狠天堂| 亚洲图片欧美综合| 成人精品免费视频| 日韩一区二区三区视频在线观看| 亚洲人成精品久久久久| 国产精品资源网站| 日韩午夜激情视频| 午夜精品久久久久久久99水蜜桃 | 国产女人18水真多18精品一级做| 亚洲成av人片一区二区| 91网站最新网址| 国产午夜一区二区三区| 美女被吸乳得到大胸91| 欧美日韩精品一区二区天天拍小说| 国产精品污污网站在线观看| 开心九九激情九九欧美日韩精美视频电影 | 久久精品亚洲精品国产欧美kt∨| 天天做天天摸天天爽国产一区| 97精品国产97久久久久久久久久久久| 精品国产免费人成电影在线观看四季 | 欧美日韩小视频| 亚洲精品一二三| 91蜜桃传媒精品久久久一区二区| 国产亚洲成av人在线观看导航| 久久99精品久久久久久| 91精品一区二区三区久久久久久| 亚洲另类在线一区| 色国产综合视频| 亚洲在线视频网站| 欧美日韩你懂得| 婷婷综合久久一区二区三区| 欧美日韩综合在线| 偷拍自拍另类欧美| 欧美大片国产精品| 黄色日韩三级电影| 国产欧美综合在线观看第十页| 国产精品99久久久久久久vr |