C++畫心型的算法代碼_第1頁
C++畫心型的算法代碼_第2頁
C++畫心型的算法代碼_第3頁
C++畫心型的算法代碼_第4頁
C++畫心型的算法代碼_第5頁
已閱讀5頁,還剩12頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

C++畫心型算法的代碼V1.0.0Nick2012簡單說明該方法模擬動(dòng)態(tài)繪畫心型圖(兩個(gè)紅心,部分重疊),還有丘比特之箭...該文檔中代碼只是繪畫代碼,僅供參考繪畫算法比較粗劣,代碼運(yùn)行效率比較低,讀者可以繼續(xù)優(yōu)化希望有更好的算法的讀者可以發(fā)布出來,實(shí)現(xiàn)共享,共同學(xué)習(xí),共同進(jìn)步效果圖效果圖繪圖代碼CPaintDCdc(this);CPenpen(PS_SOLID,5,0x000000FF);CPen*pOldPen=dc.SelectObject(&pen);intpos_x=100,pos_y=100;intloop_time=180;intsleep_time=10;intc_angle=90;doublepi=3.1415926;doubleth=pi/180;繪圖代碼doubler=20;doublelast_x=r*(2*cos(0*th)-cos(2*0*th))/*+pos_x*/;doublelast_y=r*(2*sin(0*th)-sin(2*0*th))/*+pos_y*/;繪圖代碼doubletemp_x=last_x;doubletemp_y=last_y;doublel_x[180];doublel_y[180];doubler_x[180];doubler_y[180];繪圖代碼last_x=temp_x*cos(c_angle*th)-temp_y*sin(c_angle*th)+pos_x;last_y=pos_y-(last_y*cos(c_angle*th)+temp_x*sin(c_angle*th));doublex0=last_x;doubley0=last_y;繪圖代碼for(doublei=0;i<loop_time;i++){ l_x[(int)i]=r*(2*cos(i*th)-cos(2*i*th))/*+pos_x*/; l_y[(int)i]=r*(2*sin(i*th)-sin(2*i*th))/*+pos_y*/; temp_x=l_x[(int)i]; temp_y=l_y[(int)i];繪圖代碼 l_x[(int)i]=temp_x*cos(c_angle*th)-temp_y*sin(c_angle*th)+pos_x; l_y[(int)i]=pos_y-(temp_y*sin(c_angle*th)+temp_x*sin(c_angle*th)); r_x[(int)i]=x0+(x0-l_x[(int)i]); r_y[(int)i]=l_y[(int)i];繪圖代碼dc.MoveTo((int)last_x,(int)last_y); dc.LineTo((int)l_x[(int)i],(int)l_y[(int)i]); dc.MoveTo((int)last_x+50,(int)last_y/*+10*/);dc.LineTo((int)l_x[(int)i]+50,(int)l_y[(int)i]/*+10*/);繪圖代碼 last_x=l_x[(int)i]; last_y=l_y[(int)i]; Sleep(sleep_time);}for(intj=loop_time-1;j>0;j--){繪圖代碼if((r_x[j]<=l_x[j]+50&&r_y[j]>=y0)||(r_x[j]>=l_x[j]+50&&r_y[j]<=y0)){ dc.MoveTo((int)last_x,(int)last_y); dc.LineTo((int)r_x[j],(int)r_y[j]);} dc.MoveTo((int)last_x+50,(int)last_y/*+10*/); dc.LineTo((int)r_x[j]+50,(int)r_y[j]/*+10*/);繪圖代碼last_x=r_x[j]; last_y=r_y[j]; Sleep(sleep_time);}dc.MoveTo((int)x0-80,(int)y0);dc.LineTo((int)x0-50,(int)y0);繪圖代碼Sleep(100);dc.MoveTo((int)x0+80,(int)y0);dc.LineTo((int)x0+130,(int)y0);Sleep(100);dc.MoveTo((int)x0+130,(int)y0);dc.LineTo((int)x0+120,(int)y0-10);繪圖代碼Sleep(100);dc.MoveTo((int)x0+130,(int)y0);dc.LineTo((int)x0+120,(int)y0+10);Sleep(200);CStringstrText="NickandKady...Love...";CRectrect(CPoint(x0-20,y0+120)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論