万花模拟器(C/C++基础)

还记得小时候玩的万花尺么?好好玩,各种不同的点距能画出各种各样形状图形。

成都创新互联公司主营双流网站建设的网络公司,主营网站建设方案,成都App制作,双流h5小程序设计搭建,双流网站营销推广欢迎双流等地区企业咨询

C语言程序万花尺模拟

函数功能:每隔5秒随机生成万花图形 并自动保存作图参数以及图形到当前目录,图像格式为jpg

提示:

  • 相关参数范围可以自行设置,用自定义mySetRand函数设置作图尺寸范围

注意:

  • 内圆半径不能大于外圆半径,内圆作图点不能大于内圆半径

/*以下是完整代码,可自行个性化更改参数*/

 
 
 
  1. #include  
  2. #include  
  3. #include  
  4. #include  
  5. #include  
  6. #include  
  7. int mySetRand(int num, int min, int max);  
  8. #define PI 3.1415926536  
  9. int main()  
  10. {  
  11. int k = 0;  
  12. wchar_t s[255] = { NULL };  
  13. int R; // 静圆半径  
  14. int r; // 动圆半径  
  15. int dr; // 动圆上的作图点到圆心的距离  
  16. while (1)  
  17.  
  18. //产生一个100-395之间的随机数  
  19. R = mySetRand(1, 100, 395);  
  20. r = R - mySetRand(1, 5, 95);  
  21. dr = r - mySetRand(1,2, r-5);  
  22. // 求执行次数(最小公倍数/静圆半径)  
  23. int m = R, n = r;  
  24. int tmp;  
  25. while (n != 0)  
  26.  tmp = m % n;  
  27. m = n;  
  28. n = tmp;  
  29. }  
  30. double maxdegree = r / m * 2 * PI;  
  31. //清屏  
  32. //cleardevice();  
  33. system("cls");  
  34. initgraph(800, 610);  
  35. setbkcolor(RGB(200, 200, 200));  
  36. // 设置作图原点坐标,使其在窗口中心画图  
  37. setorigin(400, 300);  
  38. // 开始绘图  
  39. int x, y;  
  40. for (double degree = 0; degree < maxdegree; degree += 0.01)  
  41. {  
  42. x = (int)(dr * cos(degree*(double(R) / r - 1)) + (R - r) * cos(degree));  
  43. y = (int)(dr * sin(degree*(double(R) / r - 1)) - (R - r) * sin(degree));  
  44. putpixel(x, y, RGB(255,255,0));  
  45. }  
  46. //归位原点坐标  
  47. setorigin(0, 0);  
  48. _stprintf_s(s, _T("作图参数:外圆半径%.3d像素\\内圆半径%.3d像素\\作图点到圆心距离%.3d像素"), R, r, dr);  
  49. settextstyle(20, 0, _T("黑体")); 
  50.  settextcolor(RED);  
  51. outtextxy(60, 587, s);  
  52. //保存图形到当前目录  
  53. k++;  
  54. _stprintf_s(s, _T("%.6d.jpg"), k);  
  55. saveimage(s);  
  56. //画面停留5秒后,清屏重新画另一个图  
  57. Sleep(5000);  
  58. closegraph();  
  59. }  
  60. return 0;  
  61. }  
  62. //指定范围随机数产生  
  63. //num产生个数,产生范围min到max(包括min和max)  
  64. int mySetRand(int num, int min, int max)  
  65. {  
  66. int *p_num = #  
  67. int *p_min = &min;  
  68. int *p_max = &max;  
  69. int a = 0;  
  70. int p1 = 0, p2 = 0;  
  71. if ((*p_num)<0 || (*p_min>*p_max))  
  72. {  
  73. printf("最大值与最小值反过来了?\n元素个数为负数了?");  
  74. getchar();  
  75. return -1;  
  76. }  
  77. srand((unsigned int)time(0));  
  78. for (size_t i = 0; i < *p_num; i++)  
  79. {  
  80. a = rand(); 
  81.  if (*p_min == 0) 
  82.  { 
  83.  
  84. p2 = a % (*p_max + 1);  
  85.  
  86. else if (*p_min>0)  
  87. {  
  88. p1 = a / (*p_max - *p_min + 1);  
  89. p2 = a - p1*(*p_max - *p_min + 1) + *p_min; 
  90.  }  
  91. else  
  92.  printf("处理出错!");  
  93. getchar(); 
  94.  return -2;  
  95. }  
  96. if (p2>*p_max || p2<*p_min)  
  97.  printf("数据有误!");  
  98. getchar();  
  99. }  
  100.  return p2;  

//部分代码截图以及效果图展现如下

当前题目:万花模拟器(C/C++基础)
文章起源:http://www.csdahua.cn/qtweb/news28/285578.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网