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

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

?? treeview.cpp

?? 隨機LS文法生成樹(在LS文法中引入隨機變量
?? CPP
字號:
// TreeView.cpp : implementation of the CMyTreeView class
//

#include "stdafx.h"
#include "Tree.h"

#include "TreeDoc.h"
#include "TreeView.h"
#include "math.h"
#define  PI 3.14159

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CMyTreeView

IMPLEMENT_DYNCREATE(CMyTreeView, CView)

BEGIN_MESSAGE_MAP(CMyTreeView, CView)
	//{{AFX_MSG_MAP(CMyTreeView)
	ON_WM_LBUTTONDBLCLK()
	//}}AFX_MSG_MAP
	// Standard printing commands
	ON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CMyTreeView construction/destruction

CMyTreeView::CMyTreeView()
{
	// TODO: add construction code here
	unit[0] =   "F[+F]F[-F]F";
	unit[1] =   "F[+F]F[-F[+F]]";
	unit[2] =   "FF-[-F+F+F]+[+F-F-F]";
	
	len =3 ;  //象素長
	angle  = 30 ;  //轉角為30度
	degree = 5; //迭代次數
	ox = 450 ;
	oy = 650 ;
	

}

CMyTreeView::~CMyTreeView()
{
}

BOOL CMyTreeView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs
 
	return CView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CMyTreeView drawing

void CMyTreeView::OnDraw(CDC* pDC)
{
	CTreeDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);

	AfxGetMainWnd()->SetWindowText("隨機L系統(分形頻道:fractal.cn)2004    請雙擊窗體");
	if(tree.IsEmpty ())
		return ;
	else 
	{
		CKNOT  mNextKnot ,mCurKnot;
  		mCurKnot.x = ox ;
		mCurKnot.y = oy ;
		mCurKnot.direction = 90 ;
		
		int treelength = tree.GetLength ();
		int  i = 0;
		pDC ->MoveTo (ox,oy);
		while (i<treelength)
		{
			switch(tree[i])
			{
				case 'F':
		 			mNextKnot.x = mCurKnot.x  + len * cos(mCurKnot.direction * PI /180);
					mNextKnot.y = mCurKnot.y  - len * sin(mCurKnot.direction * PI /180);
					mNextKnot.direction = mCurKnot.direction ;
					pDC ->LineTo (mNextKnot.x ,mNextKnot.y);
					mCurKnot = mNextKnot ;
					break ;
				case '[':
					stack[stackpushpos] = mCurKnot ;
					stackpushpos ++;
					break;
				case ']':
					mCurKnot = stack[stackpushpos-1]; 
					stackpushpos -- ;
					pDC ->MoveTo (mCurKnot.x,mCurKnot.y);
					break;
				case '+':
					mCurKnot.direction = mCurKnot.direction + angle;
					break;
				case '-':
					mCurKnot.direction = mCurKnot.direction - angle;
					break;
				default:
					;
			}
			i++;
		}
	}
	// TODO: add draw code for native data here
}

/////////////////////////////////////////////////////////////////////////////
// CMyTreeView printing

BOOL CMyTreeView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// default preparation
	return DoPreparePrinting(pInfo);
}

void CMyTreeView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add extra initialization before printing
}

void CMyTreeView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add cleanup after printing
}

/////////////////////////////////////////////////////////////////////////////
// CMyTreeView diagnostics

#ifdef _DEBUG
void CMyTreeView::AssertValid() const
{
	CView::AssertValid();
}

void CMyTreeView::Dump(CDumpContext& dc) const
{
	CView::Dump(dc);
}

CTreeDoc* CMyTreeView::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CTreeDoc)));
	return (CTreeDoc*)m_pDocument;
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CMyTreeView message handlers

void CMyTreeView::OnLButtonDblClk(UINT nFlags, CPoint point) 
{
	// TODO: Add your message handler code here and/or call default
	///////////////////////////////////////////////////////////////
	//////初始化///////////////////////////////////////////////////
	for (int i = 0 ; i <1024 ; i++ )
	{
		stack[i].x =  0 ;
		stack[i].direction = NULL ;
	}
	stackpushpos = 0 ;
	formtree  = unit[rand() % 3] ;
	tree.Empty ();
	//////////////////////////////////////////////////////////////
	int random ;
	for ( i = 1 ; i <= degree ; i++)
	{
		int curlen = formtree.GetLength ();
		int pos=0 , j = 0 ;
		while (j < curlen)
		{
			if(formtree[j] == 'F' )
			{
				random = rand() % 3 ;
 				tree += unit[random];
				j++;
				pos = tree.GetLength () -1 ;
			}
			else 
			{	
				tree += formtree[j] ;
				pos ++;
				j++;
			}
		}
 
		formtree = tree ;
 
		tree.Empty ();
	}
	tree = formtree ;
	Invalidate();
	
	 
}

BOOL CMyTreeView::OnScroll(UINT nScrollCode, UINT nPos, BOOL bDoScroll) 
{
	// TODO: Add your specialized code here and/or call the base class
	
	return CView::OnScroll(nScrollCode, nPos, bDoScroll);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产高清精品久久久久| 成人激情文学综合网| 波多野结衣在线aⅴ中文字幕不卡 波多野结衣在线一区 | 亚洲自拍偷拍网站| 91蜜桃网址入口| 亚洲另类色综合网站| 欧美日产国产精品| 久久99热这里只有精品| 国产肉丝袜一区二区| 99综合电影在线视频| 亚洲精品成人少妇| 91精品欧美综合在线观看最新| 免费精品视频最新在线| 国产三级久久久| 色老汉一区二区三区| 日本视频一区二区| 欧美激情一区二区三区不卡| 欧美综合色免费| 久久国内精品自在自线400部| 亚洲国产精品成人综合| 在线观看不卡视频| 91久久香蕉国产日韩欧美9色| 天天色图综合网| 久久久久久久av麻豆果冻| 日本韩国一区二区三区视频| 六月婷婷色综合| 亚洲欧美日韩国产中文在线| 日韩精品自拍偷拍| 91免费观看视频在线| 天堂va蜜桃一区二区三区漫画版| 亚洲精品在线观看视频| 欧洲一区在线观看| 国产成人午夜片在线观看高清观看| 一区二区三区中文免费| 欧美精品一区二区三区四区| 91福利视频在线| 丁香亚洲综合激情啪啪综合| 五月天亚洲精品| 国产精品拍天天在线| 日韩欧美久久久| 欧美日韩久久不卡| 粉嫩蜜臀av国产精品网站| 青娱乐精品在线视频| 成人免费在线视频| 精品成人a区在线观看| 欧美日韩精品专区| 99精品视频中文字幕| 国产在线不卡一卡二卡三卡四卡| 香蕉影视欧美成人| 亚洲人成影院在线观看| 久久久久久久av麻豆果冻| 欧美一区二区三区白人| 在线看日韩精品电影| 99精品桃花视频在线观看| 国产成人av电影在线| 韩国av一区二区| 久久福利视频一区二区| 丝袜国产日韩另类美女| 亚洲国产精品久久一线不卡| 亚洲天堂2016| 亚洲国产精品成人综合| 久久精品在这里| 亚洲精品一区二区三区四区高清 | 日韩高清在线电影| 亚洲在线观看免费视频| **欧美大码日韩| 国产精品福利一区二区三区| 欧美—级在线免费片| 国产亚洲欧美色| 国产午夜精品一区二区| 国产日韩欧美高清| 久久久91精品国产一区二区三区| 精品日韩一区二区三区 | 欧美一a一片一级一片| 99re热这里只有精品视频| 成人免费毛片a| 成人网男人的天堂| 91蜜桃网址入口| 久久嫩草精品久久久久| 精品国产免费视频| 久久久久久久久久久久电影 | 精品一区二区三区免费播放| 日本不卡中文字幕| 久久精品国产秦先生| 国内精品自线一区二区三区视频| 久久成人av少妇免费| 国产永久精品大片wwwapp | 一区二区三区在线观看网站| 一区二区视频在线| 午夜精品久久一牛影视| 久久精品国产一区二区| 成人网在线播放| 欧美日韩中文字幕一区| 91麻豆精品91久久久久久清纯 | 五月天久久比比资源色| 另类综合日韩欧美亚洲| 国产**成人网毛片九色 | 日韩电影免费在线看| 久久精品国产网站| 成人av一区二区三区| 97久久超碰国产精品电影| 欧美另类z0zxhd电影| 久久一夜天堂av一区二区三区| 中文字幕的久久| 亚洲成在人线在线播放| 久久精品999| 97久久精品人人做人人爽| 欧美日韩国产小视频在线观看| 精品国产免费人成在线观看| 中文字幕在线不卡| 日产精品久久久久久久性色| 福利91精品一区二区三区| 欧洲激情一区二区| 久久精品综合网| 亚洲国产精品尤物yw在线观看| 韩国女主播成人在线观看| 色综合久久久久综合体桃花网| 欧美一区二区三区免费在线看| 国产精品嫩草久久久久| 日韩高清电影一区| 99久久er热在这里只有精品66| 91麻豆精品91久久久久久清纯| 国产精品免费久久久久| 免费成人av资源网| 一本色道久久综合亚洲精品按摩| 精品国产自在久精品国产| 玉米视频成人免费看| 国产一区二区三区观看| 欧美日韩一区二区三区四区| 中文字幕久久午夜不卡| 免费国产亚洲视频| 日本高清成人免费播放| 国产精品免费视频观看| 精品亚洲成av人在线观看| 在线观看视频一区| 国产精品美女www爽爽爽| 毛片基地黄久久久久久天堂| 欧美在线视频日韩| 亚洲欧洲国产专区| 国产精品 欧美精品| 欧美大片顶级少妇| 五月天激情综合| 91成人免费在线视频| **性色生活片久久毛片| 国产传媒日韩欧美成人| 精品乱人伦一区二区三区| 午夜精品免费在线| 欧美亚洲一区三区| 一区二区三区在线视频免费观看| 成人avav在线| 国产精品久线观看视频| 国产不卡视频在线播放| 欧美精品一区二区三区蜜臀| 久久 天天综合| 精品毛片乱码1区2区3区| 蜜桃久久久久久| 91精品国产品国语在线不卡| 午夜免费久久看| 欧美日韩久久久一区| 亚洲成人av在线电影| 欧美三级日韩在线| 亚洲va国产va欧美va观看| 欧美久久一二区| 日韩中文字幕亚洲一区二区va在线| 在线观看www91| 亚洲h精品动漫在线观看| 欧美三级资源在线| 午夜精品久久久久久久99水蜜桃| 欧美日韩亚洲综合| 丝袜国产日韩另类美女| 欧美一区日本一区韩国一区| 日韩av电影免费观看高清完整版 | 国产成人aaa| 国产精品沙发午睡系列990531| 成人一级黄色片| 国产精品大尺度| 91成人国产精品| 全部av―极品视觉盛宴亚洲| 精品福利视频一区二区三区| 国产精品亚洲视频| 亚洲视频1区2区| 91久久国产综合久久| 日韩av一区二区在线影视| 精品国产第一区二区三区观看体验| 国产电影精品久久禁18| 中文字幕一区二区三区在线观看| 一本在线高清不卡dvd| 午夜视频在线观看一区二区| 日韩午夜av电影| 国产91精品精华液一区二区三区| 亚洲欧洲制服丝袜| 91精品国产综合久久蜜臀| 国产精品99久久久久久久vr| 亚洲视频香蕉人妖| 日韩三区在线观看| 成人avav在线| 美女国产一区二区三区| 中文子幕无线码一区tr| 欧美日韩成人综合天天影院| 国产在线播放一区二区三区|