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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? roundb~2.cpp

?? 經(jīng)典的一款俄羅斯方塊-源程序.java.~
?? 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();

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产视频911| 粉嫩一区二区三区性色av| 337p粉嫩大胆色噜噜噜噜亚洲 | 日韩一区二区三区四区| 国产福利精品导航| 午夜精品一区二区三区电影天堂| 日本一区二区三区高清不卡| 69av一区二区三区| 91在线云播放| 风流少妇一区二区| 裸体一区二区三区| 亚洲福利视频一区| 国产精品国产三级国产三级人妇 | 日韩欧美成人午夜| 欧美亚洲高清一区二区三区不卡| 成人一级片网址| 精品一区二区影视| 日本不卡一区二区三区高清视频| 亚洲美女视频一区| 国产精品女人毛片| 精品国产一区二区三区av性色| 欧美日韩成人综合在线一区二区| 91小宝寻花一区二区三区| 粉嫩在线一区二区三区视频| 国产原创一区二区| 精品综合久久久久久8888| 天天影视网天天综合色在线播放| 一区二区三区国产精品| 综合欧美亚洲日本| 亚洲欧美综合另类在线卡通| 欧美国产一区二区| 国产视频911| 国产精品入口麻豆九色| 日韩av午夜在线观看| 国产婷婷色一区二区三区| 26uuu色噜噜精品一区二区| 日韩三级在线免费观看| 91精品国产综合久久精品麻豆| 欧美午夜一区二区| 欧美色图第一页| 欧美美女黄视频| 欧美久久婷婷综合色| 欧美精品第1页| 欧美一区二区三区白人| 精品乱人伦小说| 久久日韩粉嫩一区二区三区| 久久嫩草精品久久久精品一| 久久久一区二区三区| 欧美韩日一区二区三区四区| 国产精品私房写真福利视频| 亚洲日本在线a| 亚洲一区二区黄色| 日韩国产欧美一区二区三区| 精品一区二区三区日韩| 国产精品自拍三区| fc2成人免费人成在线观看播放| 99久久精品国产精品久久| 欧美专区日韩专区| 欧美一区二区三区视频免费播放| 精品人在线二区三区| 亚洲综合成人在线视频| 欧美日韩和欧美的一区二区| 欧美欧美欧美欧美首页| 日韩一级片网址| 久久久久国产免费免费| 中文字幕制服丝袜一区二区三区| 亚洲免费看黄网站| 日本美女一区二区三区视频| 国产一区不卡精品| av高清不卡在线| 4438成人网| 欧美韩国一区二区| 亚洲国产视频a| 精品在线观看免费| 91小视频免费观看| 精品福利在线导航| 综合激情网...| 麻豆精品视频在线| 色综合天天综合在线视频| 制服丝袜av成人在线看| 欧美国产日本韩| 三级成人在线视频| 成人免费看片app下载| 欧美另类videos死尸| 亚洲国产高清在线| 天天色天天爱天天射综合| 成人午夜av电影| 欧美一区二区视频在线观看2022 | 免费成人深夜小野草| zzijzzij亚洲日本少妇熟睡| 欧美高清视频一二三区| 国产精品私人自拍| 欧美区视频在线观看| 精品av久久707| 一区二区成人在线| 国产91精品一区二区| 91麻豆精品国产自产在线观看一区 | 国产成人精品免费看| 欧美日韩二区三区| 亚洲欧美一区二区三区孕妇| 狠狠色丁香久久婷婷综合_中| 在线观看视频一区二区欧美日韩| 久久精品欧美一区二区三区麻豆| 日日夜夜免费精品| 91老师片黄在线观看| 国产三级精品视频| 久久草av在线| 4438x成人网最大色成网站| 亚洲人成精品久久久久久| 国产精品一区2区| 精品奇米国产一区二区三区| 午夜视黄欧洲亚洲| 在线国产电影不卡| 中文字幕一区二区三区在线不卡 | 91在线国产福利| 久久久久国产精品麻豆| 麻豆精品精品国产自在97香蕉| 欧美亚洲高清一区| 一区二区三区色| 97精品久久久午夜一区二区三区 | 精品一区精品二区高清| 91麻豆精品91久久久久久清纯| 一区二区三区四区激情| 色婷婷激情综合| 亚洲婷婷在线视频| av不卡在线播放| 中文字幕亚洲精品在线观看| 丁香五精品蜜臀久久久久99网站| 国产日韩欧美精品电影三级在线| 激情久久五月天| 精品国产乱码久久久久久久久| 久久丁香综合五月国产三级网站| 欧美一区二区在线看| 久久精品国产亚洲a| 亚洲精品一区二区三区精华液| 国内久久精品视频| 久久久亚洲午夜电影| 国产精品一区二区在线观看不卡 | 一区二区三区在线视频播放| 92精品国产成人观看免费| 亚洲视频免费观看| 色婷婷国产精品久久包臀| 有坂深雪av一区二区精品| 91黄色免费看| 午夜av区久久| 日韩一区二区三区视频| 极品少妇一区二区| 国产午夜精品一区二区| 国产日韩精品视频一区| 精品一区中文字幕| 欧美激情一区二区三区四区| 99精品桃花视频在线观看| 一区二区视频免费在线观看| 欧美日韩高清一区| 国内精品自线一区二区三区视频| 欧美国产激情二区三区| 91免费在线看| 日韩专区一卡二卡| 久久综合九色综合97_久久久| 大桥未久av一区二区三区中文| 亚洲欧洲日产国码二区| 欧美午夜视频网站| 国产最新精品免费| 亚洲欧美日韩一区二区| 欧美精品色综合| 粉嫩绯色av一区二区在线观看| 亚洲欧洲一区二区在线播放| 欧美日韩在线播| 国精品**一区二区三区在线蜜桃| 欧美国产精品一区二区三区| 欧美日韩综合不卡| 国产一区二区三区四区五区入口| 日本一区二区视频在线观看| 欧美性感一区二区三区| 久久激五月天综合精品| 国产精品久久久久久久久久免费看| 欧美三区免费完整视频在线观看| 久久精品国产亚洲5555| 亚洲老司机在线| 日韩精品一区二区三区四区| 99精品视频一区| 六月丁香综合在线视频| 18欧美乱大交hd1984| 日韩美女在线视频| 99久久精品国产观看| 麻豆成人久久精品二区三区红| 国产精品成人免费精品自在线观看| 在线不卡中文字幕| 成人国产精品免费观看动漫| 日日夜夜精品视频免费| 亚洲日本一区二区三区| 精品剧情在线观看| 欧美午夜一区二区三区 | 欧美日韩一级大片网址| 国产精一区二区三区| 日韩1区2区3区| 亚洲欧美国产高清| 久久久久国产精品人| 日韩欧美国产综合一区| 欧美在线短视频|