欧美日韩在线第一页-欧美日韩在线观看精品-欧美日韩在线观看一区二区-欧美日韩在线免费看-欧美日韩在线视频不卡一区二区三区

編程代碼
新聞詳情

萬花模擬器(C/C++基礎)

發布時間:2021-01-11 10:55:18 瀏覽次數:2845

/****************************

還記得小時候玩的萬花尺么?好好玩,各種不同的點距能畫出各種各樣形狀圖形。

C語言程序萬花尺模擬

函數功能:每隔5秒隨機生成萬花圖形 并自動保存作圖參數以及圖形到當前目錄,圖像格式為jpg

提示:

相關參數范圍可以自行設置,用自定義mySetRand函數設置作圖尺寸范圍

注意:

內圓半徑不能大于外圓半徑,內圓作圖點不能大于內圓半徑

*****************************/

/*以下是完整代碼,可自行個性化更改參數*/

#include<time.h>

#include<stdio.h>

#include<math.h>

#include<conio.h>

#include<graphics.h>

#include<wchar.h>

int mySetRand(int num, int min, int max);

#define PI 3.1415926536

int main()

{


int k = 0;

wchar_t s[255] = { NULL };

int R; // 靜圓半徑

int r; // 動圓半徑

int dr; // 動圓上的作圖點到圓心的距離

while (1)

{

//產生一個100-395之間的隨機數

R = mySetRand(1, 100, 395);

r = R - mySetRand(1, 5, 95);

dr = r - mySetRand(1,2, r-5);


// 求執行次數(最小公倍數/靜圓半徑)

int m = R, n = r;

int tmp;

while (n != 0)

{

tmp = m % n;

m = n;

n = tmp;

}

double maxdegree = r / m * 2 * PI;

//清屏

//cleardevice();

system("cls");


initgraph(800, 610);

setbkcolor(RGB(200, 200, 200));

// 設置作圖原點坐標,使其在窗口中心畫圖

setorigin(400, 300);


// 開始繪圖

int x, y;

for (double degree = 0; degree < maxdegree; degree += 0.01)

{

x = (int)(dr * cos(degree*(double(R) / r - 1)) + (R - r) * cos(degree));

y = (int)(dr * sin(degree*(double(R) / r - 1)) - (R - r) * sin(degree));

putpixel(x, y, RGB(255,255,0));

}


//歸位原點坐標

setorigin(0, 0);

_stprintf_s(s, _T("作圖參數:外圓半徑%.3d像素\\內圓半徑%.3d像素\\作圖點到圓心距離%.3d像素"), R, r, dr);

settextstyle(20, 0, _T("黑體"));

settextcolor(RED);

outtextxy(60, 587, s);

//保存圖形到當前目錄

k++;

_stprintf_s(s, _T("%.6d.jpg"), k);

saveimage(s);

//畫面停留5秒后,清屏重新畫另一個圖

Sleep(5000);

closegraph();

}

return 0;


}

//指定范圍隨機數產生

//num產生個數,產生范圍min到max(包括min和max)

int mySetRand(int num, int min, int max)

{

int *p_num = &num;

int *p_min = &min;

int *p_max = &max;

int a = 0;

int p1 = 0, p2 = 0;

if ((*p_num)<0 || (*p_min>*p_max))

{

printf("最大值與最小值反過來了?\n元素個數為負數了?");

getchar();

return -1;

}

srand((unsigned int)time(0));

for (size_t i = 0; i < *p_num; i++)

{

a = rand();

if (*p_min == 0)

{

p2 = a % (*p_max + 1);

}

else if (*p_min>0)

{

p1 = a / (*p_max - *p_min + 1);

p2 = a - p1*(*p_max - *p_min + 1) + *p_min;

}

else

{

printf("處理出錯!");

getchar();

return -2;

}

if (p2>*p_max || p2<*p_min)

{

printf("數據有誤!");

getchar();

}


}

return p2;

}


//部分代碼截圖以及效果圖展現如下

萬花模擬器(C/C++基礎)

萬花模擬器(C/C++基礎)

萬花模擬器(C/C++基礎)

萬花模擬器(C/C++基礎)

萬花模擬器(C/C++基礎)

萬花模擬器(C/C++基礎)

萬花模擬器(C/C++基礎)

萬花模擬器(C/C++基礎)

萬花模擬器(C/C++基礎)
在線客服 雙翌客服
客服電話
  • 0755-23712116
  • 13310869691
主站蜘蛛池模板: 中文在线观看永久免费| 色综合久久久久久中文网| 国产精品情侣| 欧美精品成人一区二区视频一| 中文字幕在线观看一区二区三区| 国产亚洲精品久久久久久久久激情 | 黄色动态视频| 免费香蕉一区二区在线观看| 久久88香港三级台湾三级中文| 欧美一二区视频| 黑人的逼| 另类 欧美 视频二区| 一区二区三区四区视频在线| 成人综合在线视频| 国产精品在线观看| 国产精品福利久久2020| 亚洲精品91在线| 日本aaaaa高清免费看| 青青操在线观看| 国产精品系列在线一区| 精品欧美一区二区在线观看欧美熟| 奇米四区| 91福利国产在线观看网站| 亚洲精品综合网在线8050影院| 国产黄a三级三级三级| 国产l精品国产亚洲区在线观看| 午夜亚洲精品久久久久久| 大陆一级毛片| 久久精品免视看国产成人2021 | 日韩a无v码在线播放免费| 免费一级欧美大片视频在线| 国产精品色| 黄色avav| 国产精品久久婷婷六月丁香| 九九国产精品九九| 亚洲国产系列久久精品99人人| 一级做a爰片性色毛片黄书| 亚洲欧美不卡| 免费观看黄a一级视频| 国产伦精品一区二区三区精品 | 国产一级一级一级成人毛片|