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

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

?? windowanima.cpp

?? 一個簡單的demo
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
			// foreach segment that is now staggered
			for(int i=0;i<seg;i++){
				int hd=wx+nStepHeight-cumulator;
				if(hd+m_czWnd.cx>0) {
					m_pdcScreen->BitBlt(hd,wy+nSegOffset,m_czWnd.cx,segWidth,
						m_pdcMemWnd,0,nSegOffset,SRCCOPY);
					Sleep(nSleeptime);
				}
				nSegOffset+=segWidth;
				nStepHeight+=step;
			}

			nSegOffset=0;
			nStepHeight=0;

			// repaint original screen to avoid animation trail.  Here
			// we only paint nDrop length of the segment which further
			// speeds up the process
			for(i=0;i<seg;i++){
				int hd=m_czWnd.cx+wx+nStepHeight-cumulator2;
				if(hd+m_czWnd.cx>0)
					m_pdcScreen->BitBlt(hd,wy+nSegOffset,step,segWidth,
						m_pdcMemScr,hd,wy+nSegOffset,SRCCOPY);
				nSegOffset+=segWidth;
				nStepHeight+=step;
			}
			cumulator+=step;
			cumulator2=cumulator;
		}
	}
}

/************************************************************************************
	Melts the window segment by segment towards the right of the screen
************************************************************************************/
void CWindowAnima::MeltRight(int nSegments, int nDrop, int nSleeptime)
{
	int wx=m_rectWnd.left, wy=m_rectWnd.top;
	int cumulator=0, cumulator2=0;
	int step=nDrop;

	int nVisibleLimit=m_czScr.cx-wx/step;

	int segWidth=m_czWnd.cy/nSegments;

	if(m_czWnd.cy%nSegments!=0)
		nSegments++;

	PrintWindow();

	for(int a=0;a<nVisibleLimit;a++){
		for(int seg=0;seg<nSegments;seg++){
			if(a>0)
				seg=nSegments;
			int nSegOffset=0;
			int nStepHeight=0;
			for(int i=0;i<seg;i++){
				int hd=wx+cumulator-nStepHeight;
				if(hd<=m_czScr.cx) {
					m_pdcScreen->BitBlt(hd,wy+nSegOffset,m_czWnd.cx,segWidth,
						m_pdcMemWnd,0,nSegOffset,SRCCOPY);
					Sleep(nSleeptime);
				}
				nSegOffset+=segWidth;
				nStepHeight+=step;
			}

			nSegOffset=0;
			nStepHeight=0;

			for(i=0;i<seg;i++){
				int hd=wx+cumulator2-nStepHeight;
				if(hd<=m_czScr.cx)
					m_pdcScreen->BitBlt(hd,wy+nSegOffset,step,segWidth,
						m_pdcMemScr,hd,wy+nSegOffset,SRCCOPY);
				nSegOffset+=segWidth;
				nStepHeight+=step;
			}
			cumulator2=cumulator;
			cumulator+=step;
		}
	}
}

/************************************************************************************
	Melts the window segment by segment towards the bottom of the screen
************************************************************************************/
void CWindowAnima::MeltDown(int nSegments, int nDrop, int nSleeptime)
{
	int wx=m_rectWnd.left, wy=m_rectWnd.top;
	int cumulator=0, cumulator2=0;
	int step=nDrop;

	int nVisibleLimit=((m_czScr.cy-wy)/step)+2;
	int segWidth=m_czWnd.cx/nSegments;

	if(m_czWnd.cx%nSegments!=0)
		nSegments++;

	PrintWindow();

	for(int a=0;a<nVisibleLimit;a++){
		for(int seg=0;seg<nSegments;seg++){
			if(a>0)
				seg=nSegments;
			int nSegOffset=0;
			int nStepHeight=0;
			for(int i=0;i<seg;i++){
				int hd=wy+cumulator-nStepHeight;
				if(hd<=m_czScr.cy) {
					m_pdcScreen->BitBlt(wx+nSegOffset,hd,segWidth,m_czWnd.cy,
						m_pdcMemWnd,nSegOffset,0,SRCCOPY);
					Sleep(nSleeptime);
				}
				nSegOffset+=segWidth;
				nStepHeight+=step;
			}

			nSegOffset=0;
			nStepHeight=0;

			for(i=0;i<seg;i++){
				int hd=wy+cumulator2-nStepHeight;
				if(hd<=m_czScr.cy)
					m_pdcScreen->BitBlt(wx+nSegOffset,hd, segWidth,step,
						m_pdcMemScr,wx+nSegOffset,hd,SRCCOPY);
				nSegOffset+=segWidth;
				nStepHeight+=step;
			}
			cumulator2=cumulator;
			cumulator+=step;
		}
	}
}

/************************************************************************************
	Melts the window segment by segment towards the top of the screen
************************************************************************************/
void CWindowAnima::MeltUp(int nSegments, int nDrop, int nSleeptime)
{
	int wx=m_rectWnd.left, wy=m_rectWnd.top;
	int cumulator=0, cumulator2=0;
	int step=nDrop;

	int nVisibleLimit=((m_rectWnd.bottom)/step)+3;
	int segWidth=m_czWnd.cx/nSegments;

	if(m_czWnd.cy%nSegments!=0)
		nSegments++;

	PrintWindow();

	for(int a=0;a<nVisibleLimit;a++){
		for(int seg=0;seg<nSegments;seg++){
			if(a>0)
				seg=nSegments;
			int nSegOffset=0;
			int nStepHeight=0;
			for(int i=0;i<seg;i++){
				int hd=wy+nStepHeight-cumulator;
				if(hd>=0-m_czWnd.cy) {
					m_pdcScreen->BitBlt(wx+nSegOffset,hd,segWidth,m_czWnd.cy,
						m_pdcMemWnd,nSegOffset,0,SRCCOPY);
					Sleep(nSleeptime);
				}
				nSegOffset+=segWidth;
				nStepHeight+=step;
			}

			nSegOffset=0;
			nStepHeight=0;

			for(i=0;i<seg;i++){
				int hd=wy+m_czWnd.cy+nStepHeight-cumulator2;
				if(hd>-step)
					m_pdcScreen->BitBlt(wx+nSegOffset,hd, segWidth,step,
						m_pdcMemScr,wx+nSegOffset,hd,SRCCOPY);
				nSegOffset+=segWidth;
				nStepHeight+=step;
			}
			cumulator2=cumulator;
			cumulator+=step;
		}
	}
}

/************************************************************************************
	Returns the direction a window's top-left corner should take to reach the closest
	edge of the screen.
************************************************************************************/
int CWindowAnima::GetClosestSide()
{
	// check if position is closer to top edge than bottom edge
	int ClosestY=(m_rectWnd.top < (m_czScr.cy-m_rectWnd.top) ? 
		m_rectWnd.top : (m_czScr.cy-m_rectWnd.top));
	// check if position is closer to left edge than right edge
	int ClosestX=(m_rectWnd.left < (m_czScr.cx-m_rectWnd.left) ? 
		m_rectWnd.left : (m_czScr.cx-m_rectWnd.left));

	// check if postion is closer to a horizontal edge than a vertical edge
	if(ClosestX < ClosestY)
		return (ClosestX==m_rectWnd.left ? WA_LEFT : WA_RIGHT);
	else
		return (ClosestY==m_rectWnd.top ? WA_UP : WA_DOWN);
}

/************************************************************************************
	UnMelts the window segment by segment from the left of the screen to the right
************************************************************************************/
void CWindowAnima::UnMeltLeft(int nSegments, int nDrop, int nSleeptime)
{
	int wx=m_rectWnd.left, wy=m_rectWnd.top;
	int step=nDrop;
	int cumulator=0-m_czWnd.cx;
	int cumulator2=cumulator-step;

	int segWidth=m_czWnd.cy/nSegments;

	if(m_czWnd.cy%nSegments!=0)
		nSegments++;

	int nVisibleLimit=((m_czWnd.cx+m_rectWnd.left)/step)+2;

	for(int a=0;a<nVisibleLimit;a++){
		for(int seg=0;seg<nSegments;seg++){
			if(a>0)
				seg=nSegments;
			int nStepHeight=0;
			int nStepOffset=0;
			for(int i=0;i<seg;i++){
				int hd=cumulator-nStepHeight;
				if(hd<wx) {
					m_pdcScreen->BitBlt(hd,wy+nStepOffset,m_czWnd.cx,segWidth,
						m_pdcMemWnd,0,nStepOffset,SRCCOPY);
					Sleep(nSleeptime);
				} else {
					m_pdcScreen->BitBlt(wx,wy+nStepOffset,m_czWnd.cx,segWidth,
						m_pdcMemWnd,0,nStepOffset,SRCCOPY);
					Sleep(nSleeptime);						
				}
				nStepHeight+=step;
				nStepOffset+=segWidth;
			}

			nStepHeight=0;
			nStepOffset=0;

			for(i=0;i<seg;i++){
				int hd=cumulator2-nStepHeight;
				if(hd<=m_rectWnd.left)
					m_pdcScreen->BitBlt(hd,wy+nStepOffset,step,segWidth,
						m_pdcMemScr,hd,wy+nStepOffset,SRCCOPY);

				nStepHeight+=step;
				nStepOffset+=segWidth;
			}
			cumulator2=cumulator;
			cumulator+=step;
		}
	}
}

/************************************************************************************
	UnMelts the window segment by segment from the right of the screen to the left
************************************************************************************/
void CWindowAnima::UnMeltRight(int nSegments, int nDrop, int nSleeptime)
{
	int wx=m_rectWnd.left, wy=m_rectWnd.top;
	int step=nDrop;
	int cumulator=m_czScr.cx-m_rectWnd.left;
	int cumulator2=cumulator-step;

	int segWidth=m_czWnd.cy/nSegments;

	if(m_czWnd.cy%nSegments!=0)
		nSegments++;

	int nVisibleLimit=((m_czScr.cx-m_rectWnd.left)/step)+1;

	for(int a=0;a<nVisibleLimit;a++){
		for(int seg=0;seg<nSegments;seg++){
			if(a>0)
				seg=nSegments;
			int nStepHeight=0;
			int nStepOffset=0;
			for(int i=0;i<seg;i++){
				int hd=wx+cumulator+nStepHeight;
				if(hd>=wx) {
					m_pdcScreen->BitBlt(hd,wy+nStepOffset,m_czWnd.cx,segWidth,
						m_pdcMemWnd,0,nStepOffset,SRCCOPY);
					Sleep(nSleeptime);
				} else {
					m_pdcScreen->BitBlt(wx,wy+nStepOffset,m_czWnd.cx,segWidth,
						m_pdcMemWnd,0,nStepOffset,SRCCOPY);
					Sleep(nSleeptime);						
				}
				nStepHeight+=step;
				nStepOffset+=segWidth;
			}

			nStepHeight=0;
			nStepOffset=0;

			for(i=0;i<seg;i++){
				int hd=cumulator2+nStepHeight+wx+m_czWnd.cx;
				if(hd>=m_rectWnd.left-step)
					m_pdcScreen->BitBlt(hd,wy+nStepOffset,step,segWidth,
						m_pdcMemScr,hd,wy+nStepOffset,SRCCOPY);

				nStepHeight+=step;
				nStepOffset+=segWidth;
			}
			cumulator-=step;
			cumulator2=cumulator-step;
		}
	}
}

/************************************************************************************
	UnMelts the window segment by segment from the bottom of the screen upwards
************************************************************************************/
void CWindowAnima::UnMeltUp(int nSegments, int nDrop, int nSleeptime)
{
	int wx=m_rectWnd.left, wy=m_rectWnd.top;
	int step=nDrop;
	int cumulator=m_czScr.cy+m_rectWnd.top;
	int cumulator2=cumulator-step;

	int segWidth=m_czWnd.cx/nSegments;

	if(m_czWnd.cx%nSegments!=0)
		nSegments++;

	int nVisibleLimit=((m_czScr.cy+wy)/step)+2;

	for(int a=0;a<nVisibleLimit;a++){
		for(int seg=0;seg<nSegments;seg++){
			if(a>0)
				seg=nSegments;
			int nStepHeight=0;
			int nStepOffset=0;
			for(int i=0;i<seg;i++){
				int hd=wy-nStepHeight-cumulator;
				if(hd<=wy) {
					m_pdcScreen->BitBlt(wx+nStepOffset,hd,segWidth,m_czWnd.cy,
						m_pdcMemWnd,nStepOffset,0,SRCCOPY);
					Sleep(nSleeptime);
				} else {
					m_pdcScreen->BitBlt(wx+nStepOffset,wy,segWidth,m_czWnd.cy,
						m_pdcMemWnd,nStepOffset,0,SRCCOPY);
					Sleep(nSleeptime);						
				}
				nStepHeight+=step;
				nStepOffset+=segWidth;
			}

			nStepHeight=0;
			nStepOffset=0;

			for(i=0;i<seg;i++){
				int hd=wy-cumulator2-nStepHeight;
				if(hd<=m_rectWnd.top)
					m_pdcScreen->BitBlt(wx+nStepOffset,hd,segWidth,step,
						m_pdcMemScr,wx+nStepOffset,hd,SRCCOPY);

				nStepHeight+=step;
				nStepOffset+=segWidth;
			}
			cumulator2=cumulator;
			cumulator-=step;
		}
	}
}

/************************************************************************************
	UnMelts the window segment by segment from the top of the screen downwards
************************************************************************************/
void CWindowAnima::UnMeltDown(int nSegments, int nDrop, int nSleeptime)
{
	int wx=m_rectWnd.left, wy=m_rectWnd.top;
	int step=nDrop;
	int cumulator=m_czScr.cy-m_rectWnd.top;
	int cumulator2=cumulator-step;

	int segWidth=m_czWnd.cx/nSegments;

	if(m_czWnd.cx%nSegments!=0)
		nSegments++;

	int nVisibleLimit=((m_czScr.cy-wy)/step)+2;

	for(int a=0;a<nVisibleLimit;a++){

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区视频在线观看| 大尺度一区二区| 日韩伦理电影网| 国产日韩综合av| 久久夜色精品一区| 26uuu另类欧美| 久久久久久久电影| 国产亚洲综合色| 国产精品美女久久久久久2018| 亚洲精品在线观看视频| 久久综合狠狠综合久久综合88 | 91麻豆精品91久久久久同性| 欧美羞羞免费网站| 欧美电影一区二区| 91精品久久久久久久99蜜桃| 欧美成人性战久久| 国产女同互慰高潮91漫画| 国产精品剧情在线亚洲| 亚洲色图视频网站| 亚洲国产另类精品专区| 日韩成人免费电影| 久久国产精品一区二区| 国产成人免费av在线| 91美女视频网站| 欧美日韩aaaaa| 久久综合九色综合欧美就去吻| 国产精品全国免费观看高清| 亚洲视频综合在线| 亚洲国产精品久久久久秋霞影院 | 亚洲乱码中文字幕综合| 亚洲丰满少妇videoshd| 国产乱理伦片在线观看夜一区| 成人精品在线视频观看| 在线播放视频一区| 亚洲国产精品av| 日韩精彩视频在线观看| 成人午夜精品一区二区三区| 欧美日韩精品一区视频| 久久久国产精品不卡| 亚洲线精品一区二区三区八戒| 国产在线精品免费| 91啪亚洲精品| 91精品国产91久久久久久一区二区| 精品国产电影一区二区| 久久久噜噜噜久久人人看| 亚洲视频资源在线| 麻豆精品一区二区综合av| 一区二区三区**美女毛片| 极品少妇一区二区三区精品视频| 成人av在线电影| 欧美日韩一区在线| 国产欧美一区二区精品性色超碰 | 日韩一区二区在线播放| 久久久久久亚洲综合影院红桃| 国产精品热久久久久夜色精品三区| 夜夜嗨av一区二区三区中文字幕| 麻豆91精品视频| 在线观看日韩电影| 久久精品夜色噜噜亚洲aⅴ| 一区二区三区四区在线免费观看| 欧美a级理论片| 91网址在线看| 日韩欧美国产综合在线一区二区三区| 国产三区在线成人av| 国产精品成人网| 狠狠色丁香久久婷婷综| 欧美老女人在线| 中文字幕亚洲综合久久菠萝蜜| 美国欧美日韩国产在线播放| 99精品偷自拍| 日韩欧美久久久| 亚洲一区二区精品久久av| 国产成人av一区二区三区在线观看| 欧美三级一区二区| www久久精品| 日韩欧美中文一区| 亚洲成a人v欧美综合天堂下载 | 国产在线一区二区| 欧美性大战久久| 一区在线观看免费| 国产成人夜色高潮福利影视| 欧美va亚洲va香蕉在线| 日本视频在线一区| 在线观看av一区| 日韩精品久久理论片| 91久久奴性调教| 午夜激情一区二区三区| 91在线云播放| 国产精品白丝在线| 精久久久久久久久久久| 精品国产乱子伦一区| 久久国产婷婷国产香蕉| 7799精品视频| 免费观看一级欧美片| 日韩欧美亚洲国产另类| 美女视频一区二区三区| av中文字幕不卡| 亚洲二区视频在线| 欧美日韩精品福利| 日产国产高清一区二区三区 | 欧美日韩国产一级片| 亚洲福利视频一区二区| 777午夜精品免费视频| 午夜伦理一区二区| 91麻豆精品久久久久蜜臀| 日韩激情一二三区| 欧美成人猛片aaaaaaa| 国产一本一道久久香蕉| 国产日产欧美一区二区三区| www.性欧美| 成人免费一区二区三区视频| 在线不卡免费欧美| 黑人精品欧美一区二区蜜桃| 国产亚洲短视频| 91在线无精精品入口| 亚洲高清免费观看 | 国产麻豆精品theporn| 国产精品区一区二区三| 欧洲一区在线电影| 精品午夜久久福利影院| 精品美女在线播放| 久草中文综合在线| 亚洲精品一区二区三区在线观看 | 色悠久久久久综合欧美99| 一区二区三区四区不卡在线| 91精品午夜视频| 成人精品亚洲人成在线| 五月天网站亚洲| 中文av一区二区| 欧美一区二区三区思思人| 成人av网站免费观看| 一区二区三区四区高清精品免费观看| 欧美一区二区三区性视频| 成人动漫av在线| 日韩成人午夜精品| 亚洲黄一区二区三区| 久久久亚洲精品石原莉奈| 日本福利一区二区| 国产成人精品一区二区三区四区| 亚洲国产wwwccc36天堂| 日本一区二区三区在线观看| 欧美精品电影在线播放| 99精品国产视频| 91在线视频18| 久久er99精品| 亚洲免费观看在线观看| 国产精品美女久久久久久2018| 91精品国产综合久久福利软件| 91在线视频官网| 国产91对白在线观看九色| 日韩中文欧美在线| 亚洲精品中文字幕乱码三区| 欧美国产日韩精品免费观看| 精品久久国产字幕高潮| 99久久夜色精品国产网站| 国产永久精品大片wwwapp| 午夜精品一区二区三区三上悠亚| 中文字幕一区二区在线观看| 久久久精品综合| 欧美精品一区在线观看| 91麻豆精品国产91久久久使用方法 | 日韩一二三区不卡| 欧美男生操女生| 欧美日韩国产一级二级| 欧美日韩国产美女| 在线欧美一区二区| 在线精品国精品国产尤物884a| 99久久久久久99| 国产乱色国产精品免费视频| 久久精品久久精品| 精品在线观看免费| 国产一区二区三区最好精华液| 国内精品国产三级国产a久久| 久久国产综合精品| 国产一区二区三区在线看麻豆| 国产一区二区导航在线播放| 国产+成+人+亚洲欧洲自线| 国产精品99久| 国产在线精品一区二区三区不卡| 久久99久国产精品黄毛片色诱| 久久精品二区亚洲w码| 日本在线不卡视频一二三区| 久久av老司机精品网站导航| 国产主播一区二区| 成人v精品蜜桃久久一区| 色综合久久中文综合久久牛| 欧洲精品一区二区| 欧美日韩一卡二卡三卡| 欧美性videosxxxxx| 欧美一区二区三区播放老司机 | 亚洲美女免费视频| 亚洲国产wwwccc36天堂| 亚洲 欧美综合在线网络| 国产高清精品久久久久| 97久久精品人人做人人爽| 欧美乱妇15p| 国产日韩欧美a| 亚洲国产精品精华液网站| 蜜桃久久精品一区二区| 色欧美乱欧美15图片|