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

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

?? scope.cpp

?? 產生一個隨機數
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
	//畫豎線
	for(i=1;i<=3;i++)
	{
		pDC->MoveTo(m_rectCurve.left+i*m_rectCurve.Width()/4,m_rectCurve.top);
		pDC->LineTo(m_rectCurve.left+i*m_rectCurve.Width()/4,m_rectCurve.bottom);
	}
	pDC->SelectClipRgn(NULL);
	pDC->SelectObject(pOldPen);

}
void CScope::DrawTrack(CDC *pDC,BOOL bPressed)
{
	CPen *pOldPen;
	pDC->FillRect(&m_rectScroll,&m_PanelBrush);
	pOldPen = pDC->SelectObject(&m_PenDarkLine);
	pDC->MoveTo(m_rectScroll.left,m_rectScroll.top);
	pDC->LineTo(m_rectScroll.left,m_rectScroll.bottom);
	pDC->MoveTo(m_rectScroll.left,m_rectScroll.top);
	pDC->LineTo(m_rectScroll.right,m_rectScroll.top);

	pDC->SelectObject(&m_PenBrightLine);
	pDC->MoveTo(m_rectScroll.right,m_rectScroll.top);
	pDC->LineTo(m_rectScroll.right,m_rectScroll.bottom);
	pDC->MoveTo(m_rectScroll.left,m_rectScroll.bottom);
	pDC->LineTo(m_rectScroll.right,m_rectScroll.bottom);
	pDC->SelectObject(pOldPen);

	CBitmap *pBmp;
	CDC dcMem;
	BITMAP bm;
	m_bitmapTrack.GetObject(sizeof(BITMAP),&bm);
	dcMem.CreateCompatibleDC(pDC);
	pBmp = dcMem.SelectObject(&m_bitmapTrack);
	int nPosY = (int)(m_nBase/(double)m_nRange*(m_rectScroll.Height()-bm.bmHeight))+m_rectScroll.top;
	if(bPressed)
		pDC->BitBlt(m_rectScroll.left,nPosY,bm.bmWidth,bm.bmHeight,&dcMem,0,0,NOTSRCCOPY);
	else
		pDC->BitBlt(m_rectScroll.left,nPosY,bm.bmWidth,bm.bmHeight,&dcMem,0,0,SRCCOPY);
	dcMem.SelectObject(pBmp);
}
void CScope::DrawAxis(CDC *pDC)
{
	CFont *pOldFont;
	int i,nPosY;
	CString str;
	pOldFont = pDC->SelectObject(&m_FontAxis);
	pDC->SetTextColor(RGB(255,255,0));
	pDC->SetBkMode(TRANSPARENT);
	pDC->SetTextAlign(TA_RIGHT|TA_BASELINE);
	int nCenterY = m_rectCurve.top+(int)((double)m_nBase/(double)m_nRange*m_rectCurve.Height());
	nPosY = nCenterY;
	if(nPosY<=m_rectCurve.top+10)
		nPosY += 10;
	if(m_dDimY<1)
		pDC->TextOut(m_rectCurve.left-2,nPosY,CString("0.0"));
	else
		pDC->TextOut(m_rectCurve.left-2,nPosY,CString("0"));
	
	for(i=1;i<=4;i++)
	{
		nPosY = nCenterY+i*m_rectCurve.Height()/4;
		if(nPosY<=m_rectCurve.bottom)
		{
			if(m_dDimY<1)
				str.Format("%.1f",-i*m_dDimY);
			else if(m_dDimY<1000)
				str.Format("%.0f",-i*m_dDimY);
			else
				str.Format("%.0fK",-i*m_dDimY/1000);
			pDC->TextOut(m_rectCurve.left-2,nPosY,str);
		}
	}

	for(i=1;i<=4;i++)
	{
		nPosY = nCenterY-i*m_rectCurve.Height()/4;
		if(nPosY>=m_rectCurve.top)
		{
			if(nPosY<=m_rectCurve.top+10)
				nPosY += 10;
			if(m_dDimY<1)
				str.Format("%.1f",i*m_dDimY);
			else if(m_dDimY<1000)
				str.Format("%.0f",i*m_dDimY);
			else
				str.Format("%.0fK",i*m_dDimY/1000);
			pDC->TextOut(m_rectCurve.left-2,nPosY,str);
		}
	}
	//橫坐標
	pDC->SetTextAlign(TA_LEFT|TA_TOP);
	pDC->TextOut(m_rectCurve.left,m_rectCurve.bottom+2,CString("0.0"));
	pDC->SetTextAlign(TA_CENTER|TA_TOP);
	for(i=1;i<=3;i++)
	{
		str.Format("%.1f",i*m_dDimT);
		pDC->TextOut(m_rectCurve.left+i*m_rectCurve.Width()/4,m_rectCurve.bottom+2,str);
	}
	pDC->SetTextAlign(TA_RIGHT|TA_TOP);
	str.Format("%.1f",4*m_dDimT);
	pDC->TextOut(m_rectCurve.right,m_rectCurve.bottom+2,str);
	pDC->SelectObject(&pOldFont);
}

void CScope::OnLButtonUp(UINT nFlags, CPoint point) 
{
	CClientDC dc(this);
	ReleaseCapture();
	m_bPressed = FALSE;
	DrawTrack(&dc,m_bPressed);
	CStatic::OnLButtonUp(nFlags, point);
}

void CScope::OnLButtonDown(UINT nFlags, CPoint point) 
{
	
	if(m_rgnYPlus.PtInRegion(point))
	{
		if(m_dDimY>=1&&m_dDimY<10)
			m_dDimY+=1;
		if(m_dDimY>=10&&m_dDimY<100)
			m_dDimY+=10;
		if(m_dDimY>=100&&m_dDimY<1000)
			m_dDimY+=100;
		if(m_dDimY>=1000)
			m_dDimY+=1000;
		Invalidate();
	}
	if(m_rgnYMinus.PtInRegion(point))
	{
		if(m_dDimY>1&&m_dDimY<=10)
			m_dDimY-=1;
		if(m_dDimY>10&&m_dDimY<=100)
			m_dDimY-=10;
		if(m_dDimY>100&&m_dDimY<=1000)
			m_dDimY-=100;
		if(m_dDimY>1000)
			m_dDimY-=1000;
		if(m_dDimY<=1)
			m_dDimY=max(m_dDimY-0.1,0.1);
		Invalidate();
	}

	if(m_rgnTPlus.PtInRegion(point))
	{
		m_dDimT+=0.1;
		Invalidate();
	}
	if(m_rgnTMinus.PtInRegion(point))
	{
		m_dDimT=max(m_dDimT-0.1,0.1);
		Invalidate();
	}
	if(m_rectScroll.PtInRect(point))
	{
		SetCapture();
		m_bPressed = TRUE;
		m_nBase = (int)(((point.y-m_rectScroll.top+m_rectScroll.Height()/m_nRange/2)/(double)m_rectScroll.Height())*m_nRange);
		Invalidate();
	}
	CStatic::OnLButtonDown(nFlags, point);
}

void CScope::OnMouseMove(UINT nFlags, CPoint point) 
{
	CClientDC dc(this);
	if(m_rgnYPlus.PtInRegion(point)&&m_nArrowIndex !=0)
	{
		m_nArrowIndex =0;
		DrawArrow(&dc,m_nArrowIndex,TRUE);
	}
	if(m_rgnYMinus.PtInRegion(point)&&m_nArrowIndex !=1)
	{
		m_nArrowIndex =1;
		DrawArrow(&dc,m_nArrowIndex,TRUE);
	}
	if(m_rgnTPlus.PtInRegion(point)&&m_nArrowIndex !=2)
	{
		m_nArrowIndex =2;
		DrawArrow(&dc,m_nArrowIndex,TRUE);
	}
	if(m_rgnTMinus.PtInRegion(point)&&m_nArrowIndex !=3)
	{
		m_nArrowIndex =3;
		DrawArrow(&dc,m_nArrowIndex,TRUE);
	}
	if(!m_rgnYPlus.PtInRegion(point)&&
		!m_rgnYMinus.PtInRegion(point)&&
		!m_rgnTPlus.PtInRegion(point)&&
		!m_rgnTMinus.PtInRegion(point)&&
		m_nArrowIndex!=-1)
	{
		DrawArrow(&dc,m_nArrowIndex,FALSE);
		m_nArrowIndex = -1;	
	}
	if(m_bPressed)
	{
		int newBase = (int)(((point.y-m_rectScroll.top+m_rectScroll.Height()/m_nRange/2)/(double)m_rectScroll.Height())*m_nRange);
		if(newBase<0)
			newBase =0;
		if(newBase>m_nRange)
			newBase =m_nRange;
		if(newBase !=m_nBase )
		{
			m_nBase = newBase;
			DrawCurvePanel(&dc);
			DrawCurvePanel(&dc);
			DrawGrid(&dc);
			DrawCurve(&dc);

			DrawAxis(&dc);
			DrawTrack(&dc,m_bPressed);
			DrawArrow(&dc,0,FALSE);
			DrawArrow(&dc,1,FALSE);
			DrawArrow(&dc,2,FALSE);
			DrawArrow(&dc,3,FALSE);
		}

	}

	CStatic::OnMouseMove(nFlags, point);
}
void CScope::DrawArrow(CDC *pDC,int nIndex,BOOL bLighted)
{
	CBrush brush1(RGB(192,192,192)),brush2(RGB(0,255,0));
	switch(nIndex)
	{
	case 0:
		if(bLighted)
			pDC->FillRgn(&m_rgnYPlus,&brush2);
		else
			pDC->FillRgn(&m_rgnYPlus,&brush1);
		break;
	case 1:
		if(bLighted)
			pDC->FillRgn(&m_rgnYMinus,&brush2);
		else
			pDC->FillRgn(&m_rgnYMinus,&brush1);
		break;
	case 2:
		if(bLighted)
			pDC->FillRgn(&m_rgnTPlus,&brush2);
		else
			pDC->FillRgn(&m_rgnTPlus,&brush1);
		break;
	case 3:
		if(bLighted)
			pDC->FillRgn(&m_rgnTMinus,&brush2);
		else
			pDC->FillRgn(&m_rgnTMinus,&brush1);
		break;

	}

}
void CScope::DrawCurve(CDC *pDC)
{
	m_bDrawing = TRUE;
	int nSize = m_TimeList.size();

	POINT *pPointArray =(POINT *) new POINT[nSize];
	int i;
	
	std::list<double>::iterator time_it = m_TimeList.begin();
	std::list<double>::iterator value_it = m_ValueList.begin();
	std::list<double>::iterator time_begin = time_it;
	for(i=0;i<nSize;i++)
	{
		pPointArray[i].x = ConvertTimeToAxisX(*time_it-*time_begin);
		pPointArray[i].y = ConvertValueToAxisY(*value_it);
		time_it++;
		value_it++;
	}
	m_bDrawing =FALSE;
	CPen *pOldPen = pDC->SelectObject(&m_PenCurve);
	pDC->SelectClipRgn(&m_rgnCurve);
	pDC->Polyline(pPointArray,nSize);
	pDC->SelectClipRgn(NULL);
	pDC->SelectObject(pOldPen);
	
	delete []pPointArray;


	
	 
}
void CScope::UpdateCurve()
{
	
	CClientDC dc(this);
	CRect rect;
	GetClientRect(&rect);
	CDC memDC;
	memDC.CreateCompatibleDC(&dc);
	CBitmap bitmap,*pOldBmp;
	bitmap.CreateCompatibleBitmap(&dc,rect.Width(),rect.Height());
	pOldBmp = memDC.SelectObject(&bitmap);
	DrawGrid(&memDC);
	DrawCurve(&memDC);
	dc.BitBlt(m_rectCurve.left,m_rectCurve.top,m_rectCurve.Width(),m_rectCurve.Height(),&memDC,m_rectCurve.left,m_rectCurve.top,SRCCOPY);
	memDC.SelectObject(pOldBmp);
}

UINT CScope::OnNcHitTest(CPoint point) 
{
	// TODO: Add your message handler code here and/or call default
	
	return HTCLIENT;
}
void CScope::AddValue(double dTime,double dValue)
{
	if(m_bDrawing)
		return;

	m_TimeList.push_back(dTime);
	m_ValueList.push_back(dValue);
	std::list<double>::iterator start_it = m_TimeList.begin();
	std::list<double>::iterator end_it = m_TimeList.end();
	end_it--;
	double dStartTime = *start_it;
	double dEndTime = *(end_it);
	while(dEndTime-dStartTime>4*m_dDimT)
	{
		m_TimeList.pop_front();
		m_ValueList.pop_front();
		
		start_it = m_TimeList.begin();
		end_it = m_TimeList.end();
		end_it--;

		dStartTime = *start_it;
		dEndTime = *(end_it);
	}
}

inline int CScope::ConvertTimeToAxisX(double dTime)
{
	int nReturn;
	nReturn = m_rectCurve.left+dTime/(4.0*m_dDimT)*m_rectCurve.Width();
	return nReturn;
}
inline int CScope::ConvertValueToAxisY(double dValue)
{
	int nReturn;
	int nCenterY  = m_rectCurve.top+(int)(m_nBase/(double)m_nRange*m_rectCurve.Height());

	nReturn = nCenterY - dValue/(4.0*m_dDimY)*m_rectCurve.Height();
	return nReturn;
}
void CScope::SetValueString(CString strTitle,CString strUnit)
{
	m_strValueName = strTitle;
	m_strUnitName = strUnit;
	Invalidate();
}
void CScope::Clear()
{
	m_TimeList.clear();
	m_ValueList.clear();
	UpdateCurve();
//	SetValue(0.0);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99久久99小草精品免视看| 日韩欧美二区三区| 日韩伦理av电影| youjizz国产精品| 亚洲欧美另类综合偷拍| 日本福利一区二区| 亚洲动漫第一页| 欧美高清一级片在线| 奇米一区二区三区av| 日韩一级大片在线观看| 国产麻豆午夜三级精品| 国产精品人人做人人爽人人添| 成人激情图片网| 亚洲自拍偷拍欧美| 日韩亚洲欧美一区| 国产91对白在线观看九色| 亚洲欧美另类在线| 制服丝袜中文字幕一区| 激情六月婷婷久久| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 国内精品视频666| 国产校园另类小说区| 一本大道久久精品懂色aⅴ| 亚洲国产日日夜夜| 精品少妇一区二区三区日产乱码 | 亚洲欧洲美洲综合色网| 色一情一乱一乱一91av| 丝袜脚交一区二区| 欧美国产一区视频在线观看| 一本色道久久综合亚洲91| 日韩激情一区二区| 中文字幕电影一区| 欧洲一区二区三区在线| 国精品**一区二区三区在线蜜桃| 国产精品久久久久久久久动漫 | 日韩美女视频在线| 91网上在线视频| 免费一级欧美片在线观看| 国产欧美日韩精品a在线观看| 欧美视频在线一区| 国产91综合一区在线观看| 日韩一区精品视频| 国产精品你懂的在线| 欧美一级日韩一级| 99久久精品一区二区| 免费高清不卡av| 亚洲欧洲中文日韩久久av乱码| 精品欧美久久久| 91激情在线视频| 国内精品在线播放| 午夜精品爽啪视频| 亚洲天天做日日做天天谢日日欢| 日韩欧美三级在线| 欧美日本乱大交xxxxx| 成人视屏免费看| 蜜臀av一区二区在线观看| 一色屋精品亚洲香蕉网站| 日韩欧美国产午夜精品| 欧美性大战久久久| 91网址在线看| 波多野结衣视频一区| 激情综合一区二区三区| 午夜视频在线观看一区| 亚洲色图都市小说| 中文字幕第一页久久| 久久久久久亚洲综合影院红桃 | 成人性生交大片免费看视频在线| 日精品一区二区三区| 亚洲成人第一页| 亚洲综合久久av| 亚洲欧美色一区| 国产精品精品国产色婷婷| 国产人成亚洲第一网站在线播放 | 国产ts人妖一区二区| 精品一区精品二区高清| 日韩综合在线视频| 日韩激情av在线| 午夜伊人狠狠久久| 一区二区欧美国产| 一区二区三区自拍| 亚洲综合视频网| 一区二区三区在线观看动漫| 亚洲老司机在线| 亚洲视频在线一区| 亚洲综合色婷婷| 亚洲一区二区三区小说| 亚洲精选一二三| 亚洲综合激情网| 午夜视频一区二区三区| 日产精品久久久久久久性色| 免费在线观看视频一区| 蜜桃av一区二区| 国产精品资源在线观看| 高清av一区二区| 成人一级视频在线观看| 99国产麻豆精品| 91小视频在线免费看| 欧美三级日韩三级国产三级| 欧美电影一区二区三区| 精品福利视频一区二区三区| 欧美mv和日韩mv国产网站| 国产色产综合产在线视频| 成人免费在线视频| 亚洲成人综合网站| 久久国产精品99精品国产 | 一区二区三区色| 日韩在线a电影| 国产乱人伦偷精品视频不卡| 丁香网亚洲国际| 色婷婷久久久亚洲一区二区三区 | 亚洲第一久久影院| 精品一区二区三区在线观看国产| 国产**成人网毛片九色| 91亚洲精品久久久蜜桃| 欧美日韩国产综合久久| 精品久久国产老人久久综合| 国产精品人成在线观看免费| 一个色妞综合视频在线观看| 理论电影国产精品| 色哟哟在线观看一区二区三区| 欧美精品99久久久**| 国产偷国产偷精品高清尤物 | 久久综合九色综合欧美98| 成人免费一区二区三区在线观看 | 91美女蜜桃在线| 日韩欧美在线不卡| 18成人在线观看| 蜜臀av性久久久久蜜臀av麻豆| 国产福利精品导航| 精品视频一区三区九区| 久久久久久久综合日本| 午夜在线成人av| 99久久久久免费精品国产| 精品少妇一区二区三区在线视频| 亚洲免费观看高清完整版在线观看| 青青草国产精品97视觉盛宴| 91视频91自| 久久综合五月天婷婷伊人| 亚洲同性同志一二三专区| 韩国精品免费视频| 欧美日韩成人一区二区| 国产精品久久一级| 久久av老司机精品网站导航| 欧美无砖专区一中文字| 国产欧美精品一区二区色综合| 爽好久久久欧美精品| 91成人网在线| 中文字幕一区二区三区在线播放| 看电影不卡的网站| 欧美日韩午夜在线视频| 自拍偷自拍亚洲精品播放| 国产呦萝稀缺另类资源| 69久久夜色精品国产69蝌蚪网| 亚洲色图都市小说| 成人国产一区二区三区精品| 日韩欧美不卡在线观看视频| 亚洲a一区二区| 色哟哟一区二区| 最新成人av在线| 成人亚洲一区二区一| 久久久久久免费网| 国产毛片精品视频| 精品福利一区二区三区免费视频| 蜜臀av性久久久久蜜臀aⅴ流畅| 欧美日韩不卡一区| 亚洲国产欧美在线| 欧美日韩激情一区二区三区| 亚洲电影一级片| 在线视频国内一区二区| 一级精品视频在线观看宜春院 | 麻豆freexxxx性91精品| 91麻豆精品国产91久久久久久久久 | 欧美一区二区在线不卡| 性欧美大战久久久久久久久| 欧美图片一区二区三区| 亚洲自拍偷拍网站| 欧美日韩国产综合一区二区三区| 夜夜嗨av一区二区三区中文字幕| 色综合视频在线观看| 中文字幕日韩一区| 色综合av在线| 亚洲成人777| 日韩欧美国产综合一区 | 色综合亚洲欧洲| 一区二区三区小说| 欧美日韩亚洲综合| 日韩不卡手机在线v区| 日韩欧美一区二区视频| 国产一区二区三区黄视频 | 国产成人小视频| 国产精品网站一区| 91在线国产福利| 亚洲一区日韩精品中文字幕| 欧美日韩精品一区二区三区四区 | 日本一区二区三区国色天香| 国产成人av网站| 亚洲欧美日韩国产综合| 欧美日韩免费观看一区三区| 毛片av一区二区三区| 久久久久久9999|