亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
色www精品视频在线观看| 处破女av一区二区| 色一区在线观看| 国产精品美女久久久久久久久| 成人一区二区三区视频| 26uuu色噜噜精品一区二区| 亚洲免费av高清| av欧美精品.com| 久久午夜羞羞影院免费观看| 免费日韩伦理电影| 白白色 亚洲乱淫| 国产精品美女久久久久久久久久久| 成人精品国产福利| 欧美精品一区二区久久久| 视频一区二区中文字幕| 91精品国产欧美日韩| 污片在线观看一区二区| 欧美伦理电影网| 亚洲国产欧美在线| 精品盗摄一区二区三区| 99精品欧美一区| 一区二区三区精品视频| 欧美巨大另类极品videosbest | 国产午夜精品一区二区| 国产剧情在线观看一区二区| 精品久久久久久久一区二区蜜臀| 国产.精品.日韩.另类.中文.在线.播放| 国产日韩av一区二区| 成人午夜激情影院| 亚洲自拍偷拍综合| 精品久久国产老人久久综合| 麻豆精品视频在线观看视频| 久久久久综合网| 欧美综合视频在线观看| 激情综合网最新| 亚洲女性喷水在线观看一区| 欧洲精品一区二区三区在线观看| 日本伊人色综合网| 成人欧美一区二区三区视频网页| 日韩女优毛片在线| 欧美视频你懂的| aaa欧美日韩| 轻轻草成人在线| 亚洲精选一二三| 国产女人18水真多18精品一级做| 欧美一区二区视频在线观看2022| 色综合久久中文综合久久97| 日韩精彩视频在线观看| 亚洲欧美aⅴ...| 国产精品免费视频网站| 日韩欧美成人激情| 在线成人av网站| 欧美日韩亚洲综合| 色狠狠av一区二区三区| 大胆欧美人体老妇| 美女网站一区二区| 久久99精品久久久久久国产越南 | 91麻豆国产精品久久| 成人动漫中文字幕| 男人的天堂久久精品| 午夜电影一区二区三区| 日本色综合中文字幕| 亚洲精品一卡二卡| 亚洲精品菠萝久久久久久久| 最新国产の精品合集bt伙计| 国产精品久久久久久久久晋中 | 91猫先生在线| 欧美日韩国产综合久久| 91麻豆成人久久精品二区三区| 一本大道综合伊人精品热热| 色成人在线视频| 正在播放亚洲一区| 日韩一区二区三区三四区视频在线观看| 色94色欧美sute亚洲13| 欧美伊人久久大香线蕉综合69| 在线精品亚洲一区二区不卡| 777a∨成人精品桃花网| 成人国产精品免费网站| 成+人+亚洲+综合天堂| 日本韩国欧美国产| 7777精品伊人久久久大香线蕉的| 日韩久久精品一区| 亚洲欧美日韩国产中文在线| 日韩高清欧美激情| 成人免费毛片片v| 日韩欧美国产系列| 中文字幕亚洲欧美在线不卡| 免费成人在线观看视频| 久久精品国产精品亚洲红杏| 成人免费观看视频| 日韩欧美123| 麻豆视频一区二区| 91在线码无精品| 日韩高清不卡在线| 欧美日韩1区2区| 热久久一区二区| 国产成人日日夜夜| 欧美一级一级性生活免费录像| 国产肉丝袜一区二区| 亚洲成人av一区二区| 91福利视频网站| 亚洲国产精品一区二区久久恐怖片 | 国产精品久久久久久久岛一牛影视| 国产一区二区三区在线看麻豆| 精品福利av导航| 国产精品原创巨作av| 精品久久久影院| 狠狠色丁香婷婷综合久久片| 精品免费日韩av| 成人午夜在线视频| 国产精品全国免费观看高清| 国产99一区视频免费| 中文一区在线播放| 95精品视频在线| 日日夜夜精品免费视频| 精品国产欧美一区二区| 精品亚洲国产成人av制服丝袜| 欧美大度的电影原声| 国产精品一区久久久久| 亚洲天堂av老司机| 精品视频在线视频| 久久99久久久欧美国产| 国产日产精品1区| 欧洲国内综合视频| 国产乱码一区二区三区| 亚洲va国产天堂va久久en| 91精品国产91热久久久做人人| 久久99这里只有精品| www久久精品| 91国产免费观看| 精品影院一区二区久久久| 亚洲最大成人综合| 久久久久久久综合日本| 色老综合老女人久久久| 国产麻豆精品视频| 五月天婷婷综合| 一区二区三区日韩欧美精品| 久久综合久久鬼色| 欧美丝袜丝nylons| 久久99国产乱子伦精品免费| 亚洲一区二区三区精品在线| 国产色产综合色产在线视频| 欧美不卡一区二区三区四区| 99久久综合精品| 久久精品久久久精品美女| 日韩国产高清影视| 五月激情综合婷婷| 亚洲一区二区影院| 亚洲免费视频中文字幕| 欧美激情一区在线| 久久久91精品国产一区二区精品| 日韩欧美一区二区三区在线| 欧美肥妇bbw| 欧美日韩国产一区| 欧美亚洲尤物久久| 色婷婷精品久久二区二区蜜臂av| 不卡电影免费在线播放一区| 成人福利视频在线| 国产v日产∨综合v精品视频| 97精品视频在线观看自产线路二| 色乱码一区二区三区88| 欧美电影影音先锋| 精品国产凹凸成av人导航| 国产三级精品三级在线专区| 国产精品激情偷乱一区二区∴| 亚洲欧美成aⅴ人在线观看| 男男成人高潮片免费网站| 久久疯狂做爰流白浆xx| jizz一区二区| 欧美日韩国产123区| 久久久亚洲午夜电影| 中文字幕精品三区| 亚洲午夜电影在线观看| 国产九色精品成人porny | 亚洲色大成网站www久久九九| 亚洲午夜激情网站| 成人理论电影网| 7777精品伊人久久久大香线蕉| 久久只精品国产| 亚洲制服丝袜av| 波多野结衣91| 欧美精品一区男女天堂| 亚洲色图丝袜美腿| 久久97超碰色| 欧美在线看片a免费观看| 久久色.com| 蜜臂av日日欢夜夜爽一区| 91福利国产精品| 日韩欧美一二三区| 一区二区视频免费在线观看| 国产激情精品久久久第一区二区| 欧美日韩五月天| 午夜欧美视频在线观看| 91色综合久久久久婷婷| 国产日韩欧美麻豆| 国产一区二区不卡老阿姨| 精品久久久久久久久久久久久久久 | 午夜精品福利在线| 99re8在线精品视频免费播放| 久久欧美中文字幕|