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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? roundbutton1.cpp

?? 我的妙手連珠五子棋人工智能源代碼
?? CPP
字號(hào):
// RoundButton.cpp : implementation file
//
// Round Buttons!
//
// Written by Chris Maunder (chrismaunder@codeguru.com)
// Copyright (c) 1997,1998.
// 
// Modified: 2 Feb 1998 - Fix vis problem, CRgn resource leak,
//                        button reposition code redone. CJM.
//
// 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 "RoundButton1.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 DrawCircle(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 
#define LIGHT_SOURCE_ANGLE	-2.356		// -2.356 radians = -135 degrees, i.e. From top left

	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
} 

void DrawCircle(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(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(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);

		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
} 


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

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

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

BEGIN_MESSAGE_MAP(CRoundButton, CButton)
	//{{AFX_MSG_MAP(CRoundButton)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CRoundButton message handlers

void CRoundButton::PreSubclassWindow() 
{
	CButton::PreSubclassWindow();

	ModifyStyle(0, BS_OWNERDRAW);

	CRect rect;
	GetClientRect(rect);

	// Resize the window to make it square
	rect.bottom = rect.right = min(rect.bottom,rect.right);

	// Get the vital statistics of the window
	m_ptCentre = rect.CenterPoint();
	m_nRadius  = rect.bottom/2-1;

	// Set the window region so mouse clicks only activate the round section 
	// of the button
	m_rgn.DeleteObject(); 
	SetWindowRgn(NULL, FALSE);
	m_rgn.CreateEllipticRgnIndirect(rect);
	SetWindowRgn(m_rgn, TRUE);

	// Convert client coords to the parents client coords
	ClientToScreen(rect);
	CWnd* pParent = GetParent();
	if (pParent) pParent->ScreenToClient(rect);

	// Resize the window
	MoveWindow(rect.left, rect.top, rect.Width(), rect.Height(), TRUE);
}

void CRoundButton::DrawItem(LPDRAWITEMSTRUCT lpDrawItemStruct) 
{
	ASSERT(lpDrawItemStruct != NULL);
	
	CDC* pDC   = CDC::FromHandle(lpDrawItemStruct->hDC);
	CRect rect = lpDrawItemStruct->rcItem;
	UINT state = lpDrawItemStruct->itemState;
	UINT nStyle = GetStyle();
	int nRadius = m_nRadius;

	int nSavedDC = pDC->SaveDC();

	pDC->SelectStockObject(NULL_BRUSH);
	pDC->FillSolidRect(rect, ::GetSysColor(COLOR_BTNFACE));

	// Draw the focus circle around the button
	if ((state & ODS_FOCUS) && m_bDrawDashedFocusCircle)
		DrawCircle(pDC, m_ptCentre, nRadius--, RGB(0,0,0));

	// Draw the raised/sunken edges of the button (unless flat)
	if (nStyle & BS_FLAT) {
		DrawCircle(pDC, m_ptCentre, nRadius--, RGB(0,0,0));
		DrawCircle(pDC, m_ptCentre, nRadius--, ::GetSysColor(COLOR_3DHIGHLIGHT));
	} else {
		if ((state & ODS_SELECTED))	{
			DrawCircle(pDC, m_ptCentre, nRadius--, 
					   ::GetSysColor(COLOR_3DDKSHADOW), ::GetSysColor(COLOR_3DHIGHLIGHT));
			DrawCircle(pDC, m_ptCentre, nRadius--, 
					   ::GetSysColor(COLOR_3DSHADOW), ::GetSysColor(COLOR_3DLIGHT));
		} else {
			DrawCircle(pDC, m_ptCentre, nRadius--, 
					   ::GetSysColor(COLOR_3DHIGHLIGHT), ::GetSysColor(COLOR_3DDKSHADOW));
			DrawCircle(pDC, m_ptCentre, nRadius--, 
					   ::GetSysColor(COLOR_3DLIGHT), ::GetSysColor(COLOR_3DSHADOW));
		}
	}
	
	// draw the text if there is any
	CString strText;
	GetWindowText(strText);

	if (!strText.IsEmpty())
	{
		CRgn rgn;
		rgn.CreateEllipticRgn(m_ptCentre.x-nRadius, m_ptCentre.y-nRadius, 
							  m_ptCentre.x+nRadius, m_ptCentre.y+nRadius);
		pDC->SelectClipRgn(&rgn);

		CSize Extent = pDC->GetTextExtent(strText);
		CPoint pt = CPoint( m_ptCentre.x - Extent.cx/2, m_ptCentre.x - Extent.cy/2 );

		if (state & ODS_SELECTED) pt.Offset(1,1);

		pDC->SetBkMode(TRANSPARENT);

		if (state & ODS_DISABLED)
			pDC->DrawState(pt, Extent, strText, DSS_DISABLED, TRUE, 0, (HBRUSH)NULL);
		else
			pDC->TextOut(pt.x, pt.y, strText);

		pDC->SelectClipRgn(NULL);
		rgn.DeleteObject();
	}

	// Draw the focus circle on the inside of the button
	if ((state & ODS_FOCUS) && m_bDrawDashedFocusCircle)
		DrawCircle(pDC, m_ptCentre, nRadius-2, RGB(0,0,0), TRUE);

	pDC->RestoreDC(nSavedDC);
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产乱子伦一区二区三区国色天香| 乱中年女人伦av一区二区| 精久久久久久久久久久| 日韩一区二区在线观看视频| 亚洲一区二区在线观看视频| 波多野结衣中文一区| 国产日韩欧美a| 国产在线视频一区二区| 久久综合成人精品亚洲另类欧美| 久久成人精品无人区| 亚洲美腿欧美偷拍| 在线精品视频一区二区三四| 一区二区视频在线看| 国产一区 二区| 午夜a成v人精品| 日韩一区二区中文字幕| 在线观看日韩国产| 99久久精品情趣| 亚洲第一久久影院| 2020国产精品自拍| 91麻豆精品国产无毒不卡在线观看| 久久精品国产99久久6| 亚洲资源中文字幕| 亚洲欧美日韩国产成人精品影院 | 国产精品污网站| 丁香一区二区三区| 一区二区三区在线视频观看 | 日韩美女视频一区二区在线观看| 另类专区欧美蜜桃臀第一页| 亚洲色图制服诱惑| 91精品国产综合久久精品图片| 色综合天天综合| 亚洲一卡二卡三卡四卡五卡| 亚洲人成7777| 国产精品视频在线看| 国产日韩亚洲欧美综合| 日韩欧美一二三四区| 欧美大胆一级视频| 欧美成人国产一区二区| 色婷婷亚洲综合| 国产美女精品人人做人人爽| 精品午夜一区二区三区在线观看| 精品一二线国产| 国产在线一区观看| 高清不卡在线观看av| 丰满放荡岳乱妇91ww| 不卡一区二区三区四区| 99精品视频在线观看| 色就色 综合激情| 国产91高潮流白浆在线麻豆 | 99久久精品国产观看| 99国产精品久久| 91福利小视频| 欧美片网站yy| 99精品欧美一区二区蜜桃免费| 99国产精品久久久久久久久久| 91福利在线观看| 欧美一卡二卡三卡| 91丨九色丨尤物| 国产自产v一区二区三区c| 国产精品白丝jk黑袜喷水| 高清国产一区二区三区| 91福利视频久久久久| 欧美丰满美乳xxx高潮www| 在线观看www91| 欧美日韩国产片| 欧美精品一区二区蜜臀亚洲| 欧美猛男男办公室激情| 日韩精品专区在线| 国产精品日产欧美久久久久| 亚洲欧美欧美一区二区三区| 亚洲成a天堂v人片| 精品一区二区三区在线播放| 成人精品免费视频| 国产精品18久久久久久久久| 91亚洲午夜精品久久久久久| 91精品麻豆日日躁夜夜躁| 久久久综合网站| 久久精品人人做人人爽人人| 久久久亚洲欧洲日产国码αv| 最新热久久免费视频| 中文字幕一区二区三| 日本成人在线视频网站| 亚洲成人1区2区| 国产69精品久久99不卡| 欧美精品三级在线观看| 中文字幕免费不卡| 中文字幕一区av| 美女视频黄免费的久久| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产精品一级黄| 在线观看亚洲专区| 欧美激情中文不卡| 人人超碰91尤物精品国产| 美腿丝袜亚洲综合| 色综合天天视频在线观看 | 亚洲免费在线视频一区 二区| 日本视频中文字幕一区二区三区| 福利一区二区在线观看| 欧美三级韩国三级日本三斤| 欧美一二三四在线| 亚洲图片另类小说| 亚洲人123区| 亚洲女人小视频在线观看| 午夜av区久久| 北条麻妃一区二区三区| 99久久精品国产精品久久| 精品捆绑美女sm三区| 亚洲成人免费看| 91玉足脚交白嫩脚丫在线播放| 日韩精品一区二区三区老鸭窝| 国产精品欧美久久久久无广告| 日韩av电影免费观看高清完整版| 丁香一区二区三区| 日韩欧美在线影院| 亚洲第一主播视频| 色先锋资源久久综合| 欧美国产乱子伦| 国产一区啦啦啦在线观看| 日韩一级免费一区| 亚洲成人精品在线观看| 色偷偷久久人人79超碰人人澡| 中文文精品字幕一区二区| 国产美女精品人人做人人爽| 日韩精品一区二区三区视频| 日日摸夜夜添夜夜添亚洲女人| 久久精品国产99久久6| 欧美日韩www| 亚洲一二三四区不卡| 色吧成人激情小说| 一区二区三区在线视频播放| 色婷婷久久久综合中文字幕| 亚洲视频免费看| 色呦呦一区二区三区| 中文字幕日韩av资源站| eeuss影院一区二区三区| 国产精品午夜在线| 99视频精品免费视频| 国产精品夫妻自拍| 久久99久久99精品免视看婷婷 | 亚洲精品日韩一| 99久久伊人精品| 国产精品乱人伦中文| thepron国产精品| 国产精品久久久久久久第一福利 | 成人网页在线观看| 国产女人18水真多18精品一级做| 国产精品正在播放| 国产欧美日韩视频一区二区| 国产一区二区三区精品欧美日韩一区二区三区| 日韩欧美国产综合一区 | 欧美精品一区二区在线观看| 九九久久精品视频| www激情久久| 高清不卡一区二区| 一区二区三区产品免费精品久久75| 欧美性猛交xxxxxx富婆| 国产精品久久久久婷婷二区次| 99久久久久久| 亚洲成年人网站在线观看| 欧美成人r级一区二区三区| 国产在线观看免费一区| 国产精品污网站| 欧美色手机在线观看| 久久精品999| 国产精品盗摄一区二区三区| 欧美在线免费播放| 美女精品一区二区| 国产精品三级电影| 欧美日韩一级片网站| 狠狠色狠狠色综合系列| 国产精品国产a级| 91精品国产麻豆| 国产精品一色哟哟哟| 亚洲精品乱码久久久久久久久 | 乱一区二区av| 亚洲欧洲成人精品av97| 91精品啪在线观看国产60岁| 国产高清久久久久| 这里只有精品视频在线观看| 国产精品资源站在线| 亚洲va在线va天堂| 国产欧美精品一区二区三区四区| 欧美午夜一区二区| 国产一区二区导航在线播放| 亚洲女女做受ⅹxx高潮| 日韩欧美另类在线| 色综合天天综合网天天看片| 美女视频黄频大全不卡视频在线播放| 国产精品无遮挡| 欧美r级电影在线观看| 一本到不卡免费一区二区| 国产真实乱子伦精品视频| 亚洲综合男人的天堂| 欧美韩国日本综合| 日韩欧美一级精品久久| 欧洲av在线精品| 成人精品亚洲人成在线| 激情五月播播久久久精品| 香蕉成人啪国产精品视频综合网|