迪卡尔曲线

  1. /* 
  2. 非常有名的笛卡儿曲线数学公式:(x*x+y*y-2ax)2=4a*a(x*x+y*y) 
  3. 是一个圆在同样半径的圆周上滚动,在滚动过程中一定会形成轨迹曲线!!! 
  4. 它的数学议程为: x=(2cos(t)-cos(2t));  y=a(2sin(t)-sin(2t));  r=2a(1+cos(@)). 
  5.  
  6. 算法实现: r=Math.PI/45* i *(1-Math.sina(Math.PI/45*j))*18; 
  7.           x=r*Math.cos(Math.PI/45*j)*Math.sina(Math.PI/45*i)+AppletWidth/2; 
  8.           y=r*Math.sin(Math.PI/45*j)+AppletHeight/4. 
  9.  
  10. */  
  11. import java.applet.Applet;  
  12. import java.awt.Color;  
  13. import java.awt.Graphics;  
  14. import java.awt.Image;  
  15.   
  16. public class CartesianCurve  extends Applet{  
  17.     int width,height;  
  18.     Image image;               // 声明图像变量    
  19.     Graphics draw_Curve;       //声明图形绘制变量   
  20.       
  21.     public void init(){  
  22.         setBackground(Color.black);  
  23.         this.setSize(420,380);  
  24.         width=getSize().width;  
  25.         height=getSize().height;  
  26.         image=createImage(width,height);  
  27.         draw_Curve=image.getGraphics();  
  28.     }  
  29.       
  30.     public void paint(Graphics g){  
  31.         draw_Curve.clearRect(00, width, height);//用红色来填充清除指定的矩形   
  32.         draw_Curve.setColor(Color.red);  
  33.         int i,j;  
  34.         double x,y,r;  
  35.           
  36.         for(i=0;i<=90;i++){                      //笛卡尔数学公式:(x*x+y*y-2ax)2=4a*a(x*x+y*y)   
  37.             for(j=0;j<=90;j++){  
  38.                 r=Math.PI/45*i*(1-Math.sin(Math.PI/45*j))*18;  
  39.                 x=r*Math.cos(Math.PI/45*j)*Math.sin(Math.PI/45*i)+width/2;  
  40.                 y=-r*Math.sin(Math.PI/45*j)+height/4;  
  41.                 draw_Curve.fillOval((int)x, (int)y, 22);  
  42.             }  
  43.         }  
  44.         g.drawImage(image, 00this);  
  45.           
  46.     }  
  47. }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值