手机分类
  导航: 电脑时代在线 · 程序设计 · C语言 · C语言编程实例
有问题吗?看 疑难解答 电脑术语

图形与动画-01

 
硬件盘点
手机推荐
 
『图形与动画-01』如果文章有大量图片,显示会较慢,请等待图片下载完成
 
点击数: 更新时间:2005-6-7 


1、分形图案
   分形图是一种较为流行的艺术图形。所谓分形,就是指组成部分与整体以某种方式相似,局部放大后可以在某种程度上再现整体,如图25所示,为一颗树的分形图,该树是由一些分支构成的,就其中某个分支来看,它具有与整颗树相似的形状。绘制的原则是,先按某一方向画一条直线,然后在此线段上找到一系列节点,在每一个节点处向左、右偏转60度各画一条分支。节点位置和节点处所画分支的长度比值按0.618分割。

/*分形图案1 QW41.C*/
#define g 0.618
#define PAI 3.14
#include <graphics.h>
#include<math.h>
#include<stdio.h>
#include<conio.h>
float thita=60.0;
void grow(int x,int y,float lenth,float fai);
void main()
{
   int gm,gd;
   detectgraph(&gd,&gm);
   initgraph(&gd,&gm,"\\tc\\bgi");
   grow(300,300,280.0,90.0);
   getch();
   closegraph();
}
void grow(int x,int y,float lenth,float fai)
{
   int x1,y1;
   int nx,ny,count;
   float nlenth;
   x1=x+lenth*cos(fai*PAI/180.0);
   y1=y-lenth*sin(fai*PAI/180.0);
   line(x,y,x1,y1);
   if(lenth<10)return;
   nlenth=lenth;
   nx=x;
   ny=y;
   for(count=0;count<7;count++)
   {
      nx=nx+nlenth*(1-g)*cos(fai*PAI/180.0);
      ny=ny-nlenth*(1-g)*sin(fai*PAI/180.0);
      grow(nx,ny,nlenth*(1-g),fai+thita);
      grow(nx,ny,nlenth*(1-g),fai-thita);
      nlenth*=g;
   }
}

运行结果如下:

------------------------------------------------------------------------------------

2、分形图案2
   此例中也是一个分形图案。给出的方法是:先画一个大三角形,连接三角形的三条边的中点,得到四个较小的三角形,然后将外围的三个小三角形经过与大三角形相同的处理,得到一系列更小的三角形。以此类推,将三角形不断地分割下去,直到最小的三角形的边长小于某个值时停止分割。

/*分形图案 2 QW42.C*/
#include<stdio.h>
#include<graphics.h>
void draw(int x1,int y1,int x2,int y2,int x3,int y3);
void main()
{
   int gm,gd;
   int x1=360,y1=100,x2=260,y2=273,x3=460,y3=273;
   detectgraph(&gd,&gm);
   initgraph(&gd,&gm,"\\tc\\bgi");
   line(x1,y1,x2,y2);
   line(x2,y2,x3,y3);
   line(x3,y3,x1,y1);
   draw(x1,y1,x2,y2,x3,y3);
   getch();
   closegraph();
}
void draw(int x1,int y1,int x2,int y2,int x3,int y3)
{
   int xm1,ym1,xm2,ym2,xm3,ym3,fx,fy;
   xm1=(x1+x2)/2;
   ym1=(y1+y2)/2;
   xm2=(x2+x3)/2;
   ym2=(y2+y3)/2;
   xm3=(x3+x1)/2;
   ym3=(y3+y1)/2;
   line(xm1,ym1,xm2,ym2);
   line(xm2,ym2,xm3,ym3);
   line(xm3,ym3,xm1,ym1);
   fx=xm1-xm2;
   fy=ym1-ym2;
   if((fx*fx+fy*fy)<150) return;
   draw(x1,y1,xm1,ym1,xm3,ym3);
   draw(xm1,ym1,x2,y2,xm2,ym2);
   draw(xm3,ym3,xm2,ym2,x3,y3);
}

程序运行结果如下:




------------------------------------------------------------------------

 


如果您有什么疑问,可以至论坛提出或者解答他人的疑问   返回页面顶部

】【关闭窗口
·上一篇教程:
·下一篇教程:
·导航: 电脑时代在线 · 程序设计 · C语言 · C语言编程实例
相关文章
 
搞笑自拍|图片故事|美女图库|体坛宝贝|明星爆料|世界奇观|风光摄影|历史回忆|大千世界
Photshop超炫图片
advertisement
关于站点 - 广告服务 - 联系我们 - 版权隐私 - 免责声明 - 合作伙伴 - 程序支持 - 网站地图 - 返回顶部  
网站文本地图
  版权所有:电脑时代在线 2005-2007 欢迎各种媒体转载我们的原创作品[转载请注明出处]
copyright © 2005-2007 www.PCvz.com online services. all rights reserved. 蜀ICP备05015578
Template designed by LaoJiang. Optimized for 1024x768 to Firefox,Opera and MS-IE. Site powered by EQL.
红盾
热爱电脑,热爱生活
拥有电脑,拥有生命
让我们享受拥有电脑的时光