花样贝塞尔曲线(C#)

border="0" name="sina_roll" marginwidth="0" marginheight="0" src="http://news.sina.com.cn/o/allnews/input/index.html" frameborder="No" width="100%" scrolling="no" height="15">

                  花样贝塞尔曲线(C#)

                                                        作者 jlgzw

贝塞尔是一名法国工程师。他发明的贝塞尔曲线可以说是一种奇妙的曲线,用它可以创造出很美的图像。一条贝塞尔曲线由4个点唯一定义,包括“起点”,“终点”和“控制点”。其中“控制点”的位置决定着曲线的形状。
 下面是我模仿 Windows自带的屏幕保护“贝塞尔曲线”写的一个小程序。它也可以设置贝塞尔曲线的个数和环数,只需修改iCount和iNumber这两个变量。
//----------------------------------------------
// RandomBezier.cs @2007 by jl gzw
//----------------------------------------------
using System;
using System.Drawing;
using System.Windows.Forms;
class RandomBezier: Form
{
    //变量iCount表示贝塞尔曲线的个数
    const int iCount = 2;
    //变量iNumber表示环的个数
    const int iNumber = 3;    
     private Point[] ptArr = new Point[4 * iCount - (iCount - 1)];
     public static void Main()
     {
          Application.Run(new RandomBezier());
     }
     public RandomBezier()
     {
          Text = "花样贝塞尔曲线";
          this.BackColor = Color.Black;
         
          Timer timer    = new Timer();
          timer.Interval = 100;
          timer.Tick    += new EventHandler(TimerOnTick);
          timer.Start();
     }
     void TimerOnTick(object obj, EventArgs ea)
     { 
          Random rand = new Random();
          Graphics grfx = CreateGraphics();
          //擦除旧的贝塞尔曲线。
          for (int j = 0; j < iNumber; j++)
          {
              for (int i = 0; i < 4 * iCount - (iCount - 1); i++)
              {
                  ptArr[i].X += 5;
                  ptArr[i].Y += 5;
              }
              grfx.DrawBeziers(new Pen(Color.Black, 1), ptArr);
          }
          Point ptBeg = new Point(0,0);
          //获得新贝塞尔曲线的坐标。
          for(int i = 0; i < 4 * iCount - (iCount - 1); i++)
          {
              ptArr[i] = new Point(rand.Next(Math.Min(ClientSize.Width, ClientSize.Height)),
                  rand.Next(Math.Min(ClientSize.Width, ClientSize.Height)));
            
             ptBeg = ptArr[0];
          }
          ptArr[4 * iCount - (iCount - 1) - 1] = ptBeg;
    
          Color color = Color.FromArgb(rand.Next(256),rand.Next(256), rand.Next(256));
          //画新的贝塞尔曲线。外层循环控制环的个数。
          for (int j = 0; j < iNumber; j++)
          {
              grfx.DrawBeziers(new Pen(color, 1), ptArr);
              for (int i = 0; i < 4 * iCount - (iCount - 1); i++)
              {
                  ptArr[i].X -= 5;
                  ptArr[i].Y -= 5;
              }             
          }
          grfx.Dispose();
     }
}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值