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

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

?? draw_moun.cpp

?? 分形幾何被曼德勃羅喻為是大自然的幾何學。這個代碼
?? CPP
字號:
// draw_moun.cpp : Defines the entry point for the application.
//

#include "stdafx.h"
#include "resource.h"
#include <time.h>
#include <stdlib.h>
#include <list>
#define MAX_LOADSTRING 100
using namespace std;
// Global Variables:
HINSTANCE hInst;								// current instance
TCHAR szTitle[MAX_LOADSTRING];								// The title bar text
TCHAR szWindowClass[MAX_LOADSTRING];								// The title bar text




struct v_point 
{
	int x;
	int y; //x,y坐標
};
struct vertex
{
	v_point point;
	float z; //對于每個點有三個坐標,z表示在y方向上的上升坐標
};
list<vertex> lst_vertex;
//the count of iterations.
#define PLYS 7
static int g_plys=PLYS;
static HDC s_hdc; 
static HWND s_hwnd;

//funcions for drawing the triangles.
template<typename T> T midpoint(T x,T y);
vertex fraline(vertex vertex1,vertex vertex2);
void drawtriangle(v_point A,v_point B,v_point C);
void startdraw(v_point A,v_point B,v_point C,int plys);
void fratriangle(vertex A,vertex B,vertex C,int plys);
int sig();//return 1 or -1

// Foward declarations of functions included in this code module:
ATOM				MyRegisterClass(HINSTANCE hInstance);
BOOL				InitInstance(HINSTANCE, int);
LRESULT CALLBACK	WndProc(HWND, UINT, WPARAM, LPARAM);
LRESULT CALLBACK	About(HWND, UINT, WPARAM, LPARAM);

int APIENTRY WinMain(HINSTANCE hInstance,
                     HINSTANCE hPrevInstance,
                     LPSTR     lpCmdLine,
                     int       nCmdShow)
{
 	// TODO: Place code here.
	MSG msg;
	HACCEL hAccelTable;
	//seed the random number generator
	srand((unsigned int)time(NULL));
	#define Rnd(num) ((float)rand())/RAND_MAX*num
	#define Sig	(sig())//return 1 or -1
	// Initialize global strings
	LoadString(hInstance, IDS_APP_TITLE, szTitle, MAX_LOADSTRING);
	LoadString(hInstance, IDC_DRAW_MOUN, szWindowClass, MAX_LOADSTRING);
	MyRegisterClass(hInstance);

	// Perform application initialization:
	if (!InitInstance (hInstance, nCmdShow)) 
	{
		return FALSE;
	}

	hAccelTable = LoadAccelerators(hInstance, (LPCTSTR)IDC_DRAW_MOUN);

	// Main message loop:
	while (GetMessage(&msg, NULL, 0, 0)) 
	{
		if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg)) 
		{
			TranslateMessage(&msg);
			DispatchMessage(&msg);
		}
	}

	return msg.wParam;
}



//
//  FUNCTION: MyRegisterClass()
//
//  PURPOSE: Registers the window class.
//
//  COMMENTS:
//
//    This function and its usage is only necessary if you want this code
//    to be compatible with Win32 systems prior to the 'RegisterClassEx'
//    function that was added to Windows 95. It is important to call this function
//    so that the application will get 'well formed' small icons associated
//    with it.
//
ATOM MyRegisterClass(HINSTANCE hInstance)
{
	WNDCLASSEX wcex;

	wcex.cbSize = sizeof(WNDCLASSEX); 

	wcex.style			= CS_HREDRAW | CS_VREDRAW;
	wcex.lpfnWndProc	= (WNDPROC)WndProc;
	wcex.cbClsExtra		= 0;
	wcex.cbWndExtra		= 0;
	wcex.hInstance		= hInstance;
	wcex.hIcon			= LoadIcon(hInstance, (LPCTSTR)IDI_DRAW_MOUN);
	wcex.hCursor		= LoadCursor(NULL, IDC_ARROW);
	wcex.hbrBackground	= (HBRUSH)(COLOR_WINDOW+1);
	wcex.lpszMenuName	= (LPCSTR)IDC_DRAW_MOUN;
	wcex.lpszClassName	= szWindowClass;
	wcex.hIconSm		= LoadIcon(wcex.hInstance, (LPCTSTR)IDI_SMALL);

	return RegisterClassEx(&wcex);
}

//
//   FUNCTION: InitInstance(HANDLE, int)
//
//   PURPOSE: Saves instance handle and creates main window
//
//   COMMENTS:
//
//        In this function, we save the instance handle in a global variable and
//        create and display the main program window.
//
BOOL InitInstance(HINSTANCE hInstance, int nCmdShow)
{
   HWND hWnd;

   hInst = hInstance; // Store instance handle in our global variable

   hWnd = CreateWindow(szWindowClass, szTitle, WS_OVERLAPPEDWINDOW,
      CW_USEDEFAULT, 0, CW_USEDEFAULT, 0, NULL, NULL, hInstance, NULL);

   if (!hWnd)
   {
      return FALSE;
   }

   ShowWindow(hWnd, nCmdShow);
   UpdateWindow(hWnd);

   return TRUE;
}

//
//  FUNCTION: WndProc(HWND, unsigned, WORD, LONG)
//
//  PURPOSE:  Processes messages for the main window.
//
//  WM_COMMAND	- process the application menu
//  WM_PAINT	- Paint the main window
//  WM_DESTROY	- post a quit message and return
//
//
LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
{
	int wmId, wmEvent;
	PAINTSTRUCT ps;
	HDC hdc;
	TCHAR szHello[MAX_LOADSTRING];
	LoadString(hInst, IDS_HELLO, szHello, MAX_LOADSTRING);
	s_hwnd=hWnd;
	switch (message) 
	{
		case WM_COMMAND:
			wmId    = LOWORD(wParam); 
			wmEvent = HIWORD(wParam); 
			// Parse the menu selections:
			switch (wmId)
			{
				case IDM_ABOUT:
				   DialogBox(hInst, (LPCTSTR)IDD_ABOUTBOX, hWnd, (DLGPROC)About);
				   break;
				case IDM_EXIT:
				   DestroyWindow(hWnd);
				   break;
				default:
				   return DefWindowProc(hWnd, message, wParam, lParam);
			}
			break;
		case WM_PAINT:
			hdc = BeginPaint(hWnd, &ps);
			// TODO: Add any drawing code here...
			RECT rt;
			GetClientRect(hWnd, &rt);
			s_hdc=hdc;
			vertex v1,v2,v3;
			//x,y,z
//注意:在下面設置山的位置
			v1.point.x=100; 
			v1.point.y=300;
			v2.point.x=500;
			v2.point.y=200;
			v3.point.x=200;
			v3.point.y=500;
//注意:在下面設置山的參數
			v1.z=6;
			v2.z=2;
			v3.z=60;
			lst_vertex.push_back(v1);
			lst_vertex.push_back(v2);
			lst_vertex.push_back(v3);

			fratriangle(v1,v2,v3,PLYS);
			g_plys=PLYS;
			//for debugs.
	
			startdraw(v1.point,v2.point,v3.point,PLYS);
			EndPaint(hWnd, &ps);
			break;
		case WM_DESTROY:
			PostQuitMessage(0);
			break;
		default:
			return DefWindowProc(hWnd, message, wParam, lParam);
   }
   return 0;
}

// Mesage handler for about box.
LRESULT CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
{
	switch (message)
	{
		case WM_INITDIALOG:
				return TRUE;

		case WM_COMMAND:
			if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL) 
			{
				EndDialog(hDlg, LOWORD(wParam));
				return TRUE;
			}
			break;
	}
    return FALSE;
}

//make the middle point of point1 and point2.
template<typename T>
T midpoint(T x,T y)
{
	return (T)(x+y)/2;
}

vertex fraline(vertex vertex1,vertex vertex2)
{
	int mid_x=midpoint(vertex1.point.x , vertex2.point.x);
	list<vertex>::iterator ite;
	vertex node;
	//iterate the list for vetex.and find the point if exists.
	for(ite=lst_vertex.begin();ite!=lst_vertex.end();++ite)
	{
		if(ite->point.x==mid_x)
			return *ite;
	}
	
	node.point.x=mid_x;
	node.point.y=midpoint(vertex1.point.y,vertex2.point.y);
	//need the z posision.so the parameters must be vertex type.
	node.z=midpoint(vertex1.z,vertex2.z)+Rnd(4);
	//lst_vertex.push_front(node);
	lst_vertex.push_back(node);
	return node;
}
//vertexs are the three vertexs of the triangle.
void fratriangle(vertex A,vertex B,vertex C,int plys)
{	
	if(plys<=1) return;
	vertex AB,BC,CA;	
        AB=fraline(A,B);
	BC=fraline(B,C);
	CA=fraline(C,A);

	--plys;
	fratriangle(CA,BC,C,plys);
	fratriangle(AB,B,BC,plys);
	fratriangle(BC,CA,AB,plys);
	fratriangle(A,AB,CA,plys);
	
}


void startdraw(v_point A,v_point B,v_point C,int plys)
{
	v_point AB,BC,CA;
	if(plys==1)
		drawtriangle(A,B,C);
	else
	{
		AB.x=midpoint(A.x,B.x);
		AB.y=midpoint(A.y,B.y);
		BC.x=midpoint(B.x,C.x);
		BC.y=midpoint(B.y,C.y);
		CA.x=midpoint(C.x,A.x);
		CA.y=midpoint(C.y,A.y);
		--plys;
		startdraw(CA,BC,C,plys);
		startdraw(AB,B,BC,plys);
		startdraw(BC,CA,AB,plys);
		startdraw(A,AB,CA,plys);
		
	}
	
}

//draw the triangles.
void drawtriangle(v_point A,v_point B,v_point C)
{
	list<vertex>::iterator ite;
	int a_x=A.x;
	int b_x=B.x;
	int c_x=C.x;
	int a_z;
	int b_z;
        int c_z;
	v_point point[3];
	//i must come back to improve this algorithm.
	for(ite=lst_vertex.begin();ite!=lst_vertex.end();++ite)
	{
		if(ite->point.x==a_x)
			a_z=ite->z;
		else if(ite->point.x==b_x)
			b_z=ite->z;
		else if(ite->point.x==c_x)
			c_z=ite->z;
	}

	point[0].x=a_x;
	point[0].y=A.y+a_z;
	point[1].x=b_x;
	point[1].y=B.y+b_z;
	point[2].x=c_x;
	point[2].y=C.y+c_z;
	//NOTE:to improve the efficiency,we should create a brush array that is loaded on
	//the intialization of the program.
	static int loop=100; 
	HBRUSH br;
	HPEN pen;
	
	float rnd=Rnd(loop);

//注意:在下面修改山的顏色
	COLORREF cr=RGB(90+rnd,150+rnd,120+rnd);
	loop=loop-1;
	if(loop<1)
		loop=100;
	
//	int r=80+(int)(l*(rand-0.5)*60);
	br=CreateSolidBrush(cr);
	pen=CreatePen(PS_NULL,1,0);
	SelectObject(s_hdc,br);
	SelectObject(s_hdc,pen);
	Polygon(s_hdc,(POINT*)point,3);

	return;
}
int sig()
{
	if(Rnd(1)>0.5)
		return 1;
	else 
		return -1;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美国产激情二区三区| 国产一区在线精品| 国产日韩欧美不卡| 欧美乱妇23p| 欧美性生活一区| 久久99久久久久久久久久久| 中文字幕一区二区三区色视频| 欧美人与z0zoxxxx视频| 久久se精品一区精品二区| 亚洲va欧美va国产va天堂影院| 国产精品全国免费观看高清 | 久久精品国产亚洲高清剧情介绍| 一区二区三区精品在线观看| 中文字幕精品综合| 久久日韩精品一区二区五区| 91麻豆精品国产自产在线 | 日韩一区二区视频在线观看| 欧美日韩国产影片| 欧美日韩免费一区二区三区 | 欧美午夜精品久久久久久超碰| 97se亚洲国产综合自在线| 成人免费视频app| 99热精品国产| 99精品视频一区| 99精品久久免费看蜜臀剧情介绍| 成人福利在线看| 国产精品99久久久久久久vr| 国产久卡久卡久卡久卡视频精品| 久草热8精品视频在线观看| 极品少妇一区二区三区精品视频| 久久精品99国产精品| 精品一区二区三区在线播放视频| 成人午夜精品一区二区三区| 成人精品gif动图一区| aaa国产一区| 欧美性猛片aaaaaaa做受| 欧美在线色视频| 制服丝袜中文字幕一区| 欧美一级日韩一级| 国产亚洲综合av| 亚洲三级久久久| 天天色天天操综合| 国产精品一二三区在线| jiyouzz国产精品久久| 91官网在线免费观看| 宅男在线国产精品| 国产欧美一区二区在线| 国产精品久久久久久久久免费樱桃| 国产日韩精品一区二区浪潮av| 国产精品的网站| 日本不卡123| 成人18视频在线播放| 精品视频999| 国产视频一区二区在线| 亚洲精品久久嫩草网站秘色| 看电视剧不卡顿的网站| 91在线视频观看| 欧洲视频一区二区| 精品国产一区二区三区久久影院| 亚洲欧洲精品一区二区三区 | 在线观看亚洲精品| 日韩欧美在线观看一区二区三区| 国产精品久久久久久久久免费桃花 | 欧美成人一区二区三区在线观看| 久久久另类综合| 婷婷一区二区三区| 色婷婷激情综合| 久久亚洲一区二区三区明星换脸| 亚洲永久免费av| 成人h精品动漫一区二区三区| 欧美久久久久久久久久| 综合色中文字幕| 国产成人自拍网| 欧美一区二区精品在线| 精品久久久影院| 男女男精品网站| 欧美色欧美亚洲另类二区| 国产蜜臀97一区二区三区| 日韩精品一区第一页| 91老师国产黑色丝袜在线| 日韩一区二区免费在线观看| 一区二区三区免费看视频| av亚洲精华国产精华精华| 久久毛片高清国产| 激情六月婷婷综合| 日韩欧美久久一区| 人人爽香蕉精品| 欧美亚洲禁片免费| 一区二区三区在线免费播放 | 日本一区二区不卡视频| 亚洲在线免费播放| 欧美手机在线视频| 亚洲一区在线观看免费观看电影高清| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 曰韩精品一区二区| 99久久婷婷国产综合精品| 国产网站一区二区三区| 日韩精品电影在线观看| 欧美高清性hdvideosex| 亚洲va国产天堂va久久en| 欧美唯美清纯偷拍| 日韩av网站免费在线| 中文字幕欧美日韩一区| 免费看精品久久片| 精品福利av导航| 国产精品一二三| 国产精品水嫩水嫩| 色老汉av一区二区三区| 亚洲一区二区三区四区五区黄| 91国偷自产一区二区三区成为亚洲经典| 国产农村妇女毛片精品久久麻豆| 岛国一区二区在线观看| 亚洲欧美日韩人成在线播放| 日本女优在线视频一区二区| 2021中文字幕一区亚洲| 成人黄色国产精品网站大全在线免费观看| 日韩一区二区三区视频在线| 久草在线在线精品观看| 中文字幕色av一区二区三区| jvid福利写真一区二区三区| 亚洲午夜激情av| 欧美年轻男男videosbes| 乱中年女人伦av一区二区| 久久综合给合久久狠狠狠97色69| 国产成人超碰人人澡人人澡| 亚洲男人的天堂一区二区| 中文一区二区在线观看| 蜜臀av一区二区在线免费观看| 国产精品成人一区二区艾草| 精品久久人人做人人爱| 欧美日韩国产片| 色噜噜狠狠色综合中国| 成人爽a毛片一区二区免费| 蜜臀久久99精品久久久久宅男| 亚洲精品乱码久久久久久久久| 久久奇米777| 精品久久久久一区二区国产| 欧美日韩一区 二区 三区 久久精品| caoporen国产精品视频| 国产成人精品一区二区三区网站观看 | 欧美日韩国产精选| 在线视频欧美精品| 99国产精品久久久久久久久久久| 久久成人久久爱| 美日韩一区二区| 国产一区二区三区在线看麻豆| 亚洲一区二区精品久久av| 亚洲欧美日韩中文字幕一区二区三区| 国产片一区二区三区| 欧美精品一区二区三区高清aⅴ| 欧美日韩和欧美的一区二区| 欧美三级一区二区| 欧美精品v国产精品v日韩精品| 欧美影院午夜播放| 欧美图片一区二区三区| 欧美理论电影在线| 777精品伊人久久久久大香线蕉| 精品视频一区二区三区免费| 欧美日韩小视频| 日韩精品一区二区三区在线播放 | 亚洲国产高清在线| 国产精品国模大尺度视频| 亚洲人快播电影网| 夜夜嗨av一区二区三区网页| 香蕉久久夜色精品国产使用方法| 三级成人在线视频| 蜜臀久久99精品久久久画质超高清| 麻豆91在线播放| 成人sese在线| 欧美三级中文字幕| 精品国产一二三区| 国产精品久线观看视频| 亚洲激情在线激情| 久久精品国产亚洲一区二区三区| 国产精品一级在线| 一本色道久久综合亚洲aⅴ蜜桃 | 91麻豆免费视频| 欧美日韩情趣电影| 欧美成人在线直播| 综合欧美一区二区三区| 天堂精品中文字幕在线| 国产一二三精品| 欧美亚洲国产一卡| 精品99999| 亚洲一区二区中文在线| 久久99最新地址| 一本久久a久久精品亚洲| 欧美一区二区三区啪啪| 中文字幕av一区二区三区免费看| 亚洲第一av色| 夫妻av一区二区| 91精品免费观看| 日韩精品视频网| 不卡的av中国片| 日韩欧美123| 亚洲一区二区美女| 成人高清视频在线| 精品国产三级a在线观看| 亚洲一区二区三区中文字幕 | 狠狠色丁香婷综合久久|