巴恩斯利蕨

来源:互联网 发布:epub360 知乎 编辑:程序博客网 时间:2024/06/06 01:53

使用visualstudio创建一个win32项目(不要选择空项目),在代码中“此处添加绘图代码”的注释处添加绘图代码,是用SetPixel(hdc,x,y,rgb)

                                 int  r;  double x, y;  x = 0.0; y = 0.0;  srand(0);  for (int i = 0; i < 200000; i++){                                          /*错误实例*/         //SetPixel(hdc, (int)(50.0 + x)*5.0, (int)(50-y )*5.0, 0); // SetPixel(hdc, (int)(x*50.0) + 200, (int)y * 50 + 100, 0);  //SetPixel(hdc, ((int)(x)+200) * 50, ((int)(y)+100)*50, 0);  r = rand() % 100;  if (r == 0)  {  x = 0;  y = 0.16*y;  }  else if ((r>0) && (r <= 85))  {  x = 0.85*x + 0.04*y;  y = -0.04*x + 0.85*y + 1.6;  }  else if ((r > 85) && (r <= 92))  {  x = 0.2*x - 0.26*y;  y = 0.23*x + 0.22*y + 1.6;  }  else  {  x = -0.15*x + 0.28*y;  y = 0.26*x + 0.24*y + 0.44;  }  //SetPixel(hdc, r, i, 0);  SetPixel(hdc, (int)((x * 25) + 200), (int)((y * 25) + 100), 0x00FF00);  }
原理:巴恩斯利蕨有四种可能的绘图公式,概率分别为1%,85%,7%,7%,使用这四种公式进行迭代。本次实验碰到的问题:第一:在setPixel()函数中x,y的取值问题,代码中,x,y为double类型,画点函数需要int类型,需要将结果强制转化,否则(x,y)的值会产生不知名的变化;第二:将一个图形放大,首先需要将x,y的值乘上一个常数,然后平移;第三:将结果点转化成int,需要在所有计算之后,否则误差过大,无法画出图形。
0 0
原创粉丝点击