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

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

?? fractalview.cpp

?? VC小波應(yīng)用 分形和混沌 FRACTAL AND GRASS DEMO
?? CPP
字號(hào):
// FractalView.cpp : implementation of the CFractalView class
//

#include "stdafx.h"
#include "Fractal.h"

#include "FractalDoc.h"
#include "FractalView.h"
#include "stdlib.h"
#include "math.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CFractalView

IMPLEMENT_DYNCREATE(CFractalView, CView)

BEGIN_MESSAGE_MAP(CFractalView, CView)
	//{{AFX_MSG_MAP(CFractalView)
	ON_WM_LBUTTONDOWN()
	ON_WM_LBUTTONUP()
	ON_WM_MOUSEMOVE()
	ON_WM_RBUTTONDOWN()
	//}}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()

/////////////////////////////////////////////////////////////////////////////
// CFractalView construction/destruction

CFractalView::CFractalView()
{
	// TODO: add construction code here
	flag=0;
	mdown=0;
}

CFractalView::~CFractalView()
{
}

BOOL CFractalView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return CView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CFractalView drawing

void CFractalView::OnDraw(CDC* pDC)
{
	CFractalDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	GetClientRect(rect);
	width=rect.right;
	height=rect.bottom;	
	flag=pDoc->flag;
	if(flag==1)
	{
		x0=pDoc->x0;
		lanbuda1=pDoc->lanbuda1;
		lanbuda2=pDoc->lanbuda2;
		fractal1(x0,lanbuda1,lanbuda2);
	}
	if(flag==2)
	{
		p=pDoc->p;
		q=pDoc->q;
		fractal2(p,q);
	}
	if(flag==3)
	{
		left=(double)rect.left;
		top=(double)rect.top;
		right=(double)rect.right;
		bottom=(double)rect.bottom;
		fractal3(left,top,right,bottom);
	}
	// TODO: add draw code for native data here
}

/////////////////////////////////////////////////////////////////////////////
// CFractalView printing

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

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

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

/////////////////////////////////////////////////////////////////////////////
// CFractalView diagnostics

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

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

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

/////////////////////////////////////////////////////////////////////////////
// CFractalView message handlers

// -------------------------------------------------------------------------
// 混沌分叉曲線
// -------------------------------------------------------------------------

void CFractalView::fractal1(double x0, double lanbuda1,double lanbuda2)
{
	//混沌分叉曲線
	double xn,d_lanbuda,t_lanbuda;
	int x,y;
	CClientDC dc(this);
	OnPrepareDC(&dc);
	d_lanbuda=(lanbuda2-lanbuda1)/(double)width;
	t_lanbuda=lanbuda1;	
	for(int j=0;j<=width;j++)
	{
		xn=x0;
		for(int k=0;k<300;k++)
			xn=t_lanbuda*xn*(1.0-xn);
		for(int i=0;i<1000;i++)
		{
			xn=t_lanbuda*xn*(1.0-xn);			
			x=(int)((double)width*(t_lanbuda-lanbuda1)/(lanbuda2-lanbuda1)+0.5);
			y=height-(int)(xn*(double)height-10.0+0.5);
			dc.SetPixel(x,y,RGB(rand()%255,rand()%255,rand()%255));
			//dc.SetPixel(x,y,RGB(255,0,0));
		}
		t_lanbuda+=d_lanbuda;
	}
	flag=0;
}
// -------------------------------------------------------------------------
// Julia集
// -------------------------------------------------------------------------

void CFractalView::fractal2(double p,double q)
{
	int x,y,k;
	double dx,dy;
	double xk,yk,r,temp;
	double M=100.0;
	int exit=0;
	double xmin=-1.5,ymin=-1.5,xmax=1.5,ymax=1.5;
	CClientDC dc(this);
	dx=(xmax-xmin)/(double)(width-1.0);
	dy=(ymax-ymin)/(double)(height-1.0);
	for(x=0;x<width;x++)
	 for(y=0;y<height;y++)
	 {
		 xk=xmin+(double)x*dx;
		 yk=ymin+(double)y*dy;
		 k=0;
		 exit=0;
		 while(!exit)
		 {
			temp=xk;
			xk=xk*xk-yk*yk+p;
			yk=2.0*temp*yk+q;
			k++;
			r=sqrt(xk*xk+yk*yk);
			if(r>M)
			{
				exit=1;
			}
			if(k==255)
			{
				//dc.SetPixel(x,y,RGB(rand()%255,rand()%255,rand()%255));
				dc.SetPixel(x,y,RGB(255,0,0));
				exit=1;
			}
		 }
	 }
	 flag=0;
}

// -------------------------------------------------------------------------
// Mandelbrot集
// -------------------------------------------------------------------------

void CFractalView::fractal3(double wleft,double wtop,double wright,double wbottom)
{
	int x,y,k;
	double nx,ny;
	double dx,dy;
	double dp,dq,p,q;
	double xk,yk,r,temp;
	double M=100.0;
	int exit=0;
	double pmin=-2.25,qmin=-1.5,pmax=0.75,qmax=1.5;	
	CClientDC dc(this);
	dx=(wright-wleft)/(double)width;
	dy=(wbottom-wtop)/(double)height;
	dp=(pmax-pmin)/(double)(width-1.0);
	dq=(qmax-qmin)/(double)(height-1.0);
	nx=wleft;
	ny=wtop;
	for(x=0;x<width;x++)
	{
	ny=(double)wtop;
	for(y=0;y<height;y++)
	 {
		 p=pmin+nx*dp;
		 q=qmin+ny*dq;
		 xk=yk=0;
		 k=0;
		 exit=0;
		 while(!exit)
		 {
			temp=xk;
			xk=xk*xk-yk*yk+p;
			yk=2.0*temp*yk+q;
			k++;
			r=sqrt(xk*xk+yk*yk);
			if(r>M)
			{
				exit=1;
			}
			if(k==128)
			{
				dc.SetPixel(x,y,RGB(30,126,48));
				exit=1;
			}			
		 }
		 ny=ny+dy;		 		 
	 }
	nx=nx+dx;
	}
	 flag=0;
}

void CFractalView::OnLButtonDown(UINT nFlags, CPoint point) 
{
	// TODO: Add your message handler code here and/or call default
		if(flag==0)
		{
			tempy=temprect.top=point.y;
			tempx=temprect.left=point.x;
			mdown=1;
		}
		CView::OnLButtonDown(nFlags, point);
}

void CFractalView::OnLButtonUp(UINT nFlags, CPoint point) 
{
	// TODO: Add your message handler code here and/or call default
	temprect.bottom=point.y;
	temprect.right=point.x;
	mdown=0;
	CView::OnLButtonUp(nFlags, point);
}

void CFractalView::OnMouseMove(UINT nFlags, CPoint point) 
{
	// TODO: Add your message handler code here and/or call default
	if(mdown)
	{
		CClientDC dc(this);
		CGdiObject *pOldBrush = dc.SelectStockObject(NULL_BRUSH);
		CPen newpen(PS_DASH,1,RGB(0,0,0));
		CPen *oldpen=dc.SelectObject(&newpen);
		int oldmode = dc.SetROP2(R2_NOTXORPEN);
		dc.Rectangle(temprect.left,temprect.top,tempx,tempy);
		dc.Rectangle(temprect.left,temprect.top,point.x,point.y);
		dc.SelectObject(pOldBrush);
		dc.SetROP2(oldmode);
		dc.SelectObject(oldpen);
		tempx=point.x;
		tempy=point.y;
	}
	CView::OnMouseMove(nFlags, point);
}

void CFractalView::OnRButtonDown(UINT nFlags, CPoint point) 
{
	// TODO: Add your message handler code here and/or call default
	CClientDC dc(this);
	dc.FillSolidRect(rect,RGB(255,255,255));
	double tempw,temph,templ,tempt;
	tempw=right-left;
	temph=bottom-top;
	templ=left;
	tempt=top;
	left=templ+tempw*(double)temprect.left/(double)width;
	top=tempt+temph*(double)temprect.top/(double)height;
	right=templ+tempw*(double)temprect.right/(double)width;
	bottom=tempt+temph*(double)temprect.bottom/(double)height;
	fractal3(left,top,right,bottom);
	CView::OnRButtonDown(nFlags, point);
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
不卡高清视频专区| 国产视频一区二区在线| 国产一区二区调教| 亚洲欧美日韩国产成人精品影院| 555www色欧美视频| 91精品福利视频| 国产福利一区二区三区| 日本不卡不码高清免费观看| 中文字幕永久在线不卡| 精品国产1区2区3区| 精品视频在线免费看| 成人黄色网址在线观看| 久久99久久精品| 天天综合网 天天综合色| 亚洲色图欧洲色图| 国产亚洲欧美一级| 精品精品国产高清a毛片牛牛 | 91传媒视频在线播放| 狠狠色丁香久久婷婷综合丁香| 亚洲国产视频直播| 亚洲欧美一区二区三区孕妇| 国产色产综合色产在线视频| 欧美一区二区福利在线| 欧美福利视频一区| 欧美日韩色一区| 欧美主播一区二区三区美女| 91丨九色丨尤物| 99麻豆久久久国产精品免费优播| 国产麻豆午夜三级精品| 久久99热国产| 国产中文字幕精品| 久久99精品久久久久久| 蜜桃一区二区三区在线观看| 日日骚欧美日韩| 日韩中文字幕不卡| 五月开心婷婷久久| 肉色丝袜一区二区| 日本成人在线一区| 日韩avvvv在线播放| 日韩国产欧美在线观看| 石原莉奈一区二区三区在线观看| 亚洲国产成人tv| 午夜视频在线观看一区| 日韩精品一级二级| 久久国产生活片100| 久久精品国产色蜜蜜麻豆| 另类小说综合欧美亚洲| 九色综合狠狠综合久久| 国产成人综合网| 成人h动漫精品一区二区| 91视频com| 欧美在线短视频| 在线不卡a资源高清| 日韩一区二区中文字幕| 精品第一国产综合精品aⅴ| 亚洲精品一区二区精华| 国产欧美精品一区二区色综合| 中文子幕无线码一区tr| 中文字幕字幕中文在线中不卡视频| 亚洲欧美日韩久久| 日韩制服丝袜av| 韩国毛片一区二区三区| 99久久婷婷国产| 欧美性xxxxxx少妇| 日韩欧美一级二级三级| 久久久国产精品午夜一区ai换脸| 国产精品美女久久福利网站| 亚洲乱码国产乱码精品精小说| 性欧美大战久久久久久久久| 久久超碰97中文字幕| 成人精品视频一区| 欧美日韩国产片| 国产日韩精品一区二区三区在线| 18成人在线观看| 麻豆精品在线视频| 成人福利视频网站| 欧美午夜精品一区二区三区 | 欧美日韩成人综合天天影院 | 91精品国产色综合久久ai换脸| 久久午夜电影网| 亚洲欧美福利一区二区| 视频一区国产视频| 成人免费高清视频| 777欧美精品| 亚洲天堂精品视频| 激情欧美一区二区三区在线观看| 91色porny蝌蚪| 精品福利一二区| 亚洲精品国产第一综合99久久 | 国产福利91精品一区二区三区| 91丨九色丨国产丨porny| 欧美一级日韩免费不卡| 亚洲人成在线播放网站岛国| 五月天精品一区二区三区| 成人免费精品视频| 欧美va天堂va视频va在线| 亚洲欧美乱综合| 国产乱码精品一区二区三| 在线观看成人免费视频| 欧美国产日本韩| 另类小说综合欧美亚洲| 色哟哟精品一区| 久久久精品免费观看| 亚洲成av人片在线| 91丨九色丨国产丨porny| 久久久.com| 日本亚洲天堂网| 欧美一a一片一级一片| 国产嫩草影院久久久久| 精品影视av免费| 欧美日韩高清一区二区不卡| 亚洲日本电影在线| 国产 日韩 欧美大片| 日韩一区二区高清| 午夜精品一区在线观看| 91色视频在线| 中文字幕一区av| 波多野洁衣一区| 国产欧美一区二区三区网站| 久久精品国产在热久久| 欧美色图免费看| 一区二区三区在线视频观看58| av资源网一区| 欧美经典一区二区三区| 国产在线播放一区三区四| 欧美一区二区视频网站| 日韩一区精品字幕| 欧美精品一二三| 午夜影院久久久| 欧美日韩国产欧美日美国产精品| 一区二区日韩av| 在线观看日韩毛片| 亚洲精品国产a久久久久久| 91蜜桃视频在线| 一区二区三区中文字幕| 色先锋资源久久综合| 亚洲免费观看高清完整版在线观看 | 国产精品免费av| 成人高清视频在线| 亚洲男人天堂av网| 日本精品视频一区二区| 亚洲一区二区黄色| 91麻豆精品国产91久久久久久久久| 亚洲777理论| 欧美日本不卡视频| 日本欧美在线观看| 欧美电影免费观看完整版| 狠狠色丁香婷婷综合久久片| 国产日本欧洲亚洲| 99精品久久99久久久久| 亚洲国产精品人人做人人爽| 欧美视频中文字幕| 日韩高清不卡一区| 精品国产免费人成电影在线观看四季| 看片的网站亚洲| 中文字幕 久热精品 视频在线| 成人开心网精品视频| 亚洲综合免费观看高清在线观看| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 午夜久久福利影院| 久久蜜桃一区二区| 91色综合久久久久婷婷| 视频一区欧美日韩| 国产香蕉久久精品综合网| 成人高清伦理免费影院在线观看| 一区二区三区在线播放| 91精品国产色综合久久| 国产99久久精品| 亚洲国产裸拍裸体视频在线观看乱了 | 国产精品系列在线观看| 欧美日韩精品一区二区三区四区| 青青草97国产精品免费观看 | 国产精品伊人色| 一区二区久久久| 欧美va在线播放| 97精品国产97久久久久久久久久久久| 亚洲国产精品人人做人人爽| 精品久久久久香蕉网| 99视频在线观看一区三区| 日韩激情视频在线观看| 国产欧美日韩不卡| 欧美二区乱c少妇| 99这里都是精品| 青青草成人在线观看| 中文字幕一区二区三区蜜月| 日韩一区二区三区观看| 成人午夜电影网站| 日韩av中文字幕一区二区| 国产精品毛片无遮挡高清| 欧美狂野另类xxxxoooo| 北条麻妃一区二区三区| 青娱乐精品在线视频| 亚洲视频每日更新| 久久人人爽人人爽| 欧美日韩国产影片| 成人h动漫精品一区二区| 久久精品国产色蜜蜜麻豆| 亚洲一区在线观看视频| 中文字幕制服丝袜一区二区三区 | 亚洲国产日韩综合久久精品|