zoukankan      html  css  js  c++  java
  • C# Rotating Oval

    This program is used to show how to generate an oval.

    The moon's orbit around the sun is an oval two.

    锘縰sing System;
    using System.Windows.Forms;
    using System.Drawing;
    using System.Collections.Generic;
    class Haha : Form
    {
        Haha()
        {
            WindowState = FormWindowState.Maximized;
            Paint += draw;
            Timer t = new Timer();
            t.Tick += delegate
            {
                Invalidate();
            };
            init();
            t.Interval = 200; 
            t.Start();
            Activated += delegate
            {
                t.Start();
            };
            SizeChanged += delegate
            {
                if (WindowState == FormWindowState.Minimized) t.Stop();
            };
        }
        const int period=100; 
        int now=0;
        Bitmap[] bit=new Bitmap[period];
        void init()
        {
            double the=Math.PI*2/period;
            LinkedList<Point> mark = new LinkedList<Point>();
            var p = new Pen(new SolidBrush(Color.Tomato), 1);
            for (int i = 0; i < bit.Length; i++)
            {
                bit[i] = new Bitmap(200,200);
                var g = Graphics.FromImage(bit[i]);
                int R = Math.Min(bit[i].Width, bit[i].Height) >> 1;
                int x = bit[i].Width >> 1;
                int y = bit[i].Height >> 1;
                g.DrawEllipse(p, x - R, y - R, R << 1, R << 1);
                int RR = R >> 1;
                double xx = x + RR * Math.Cos(the * i);
                double yy = y + RR * Math.Sin(the * i);
                g.DrawEllipse(p, (float)(xx - RR), (float)(yy - RR), RR << 1, RR << 1);
                double r = RR * 0.5;
                double xxx = xx + r * Math.Cos(-the * i);
                double yyy = yy + r * Math.Sin(-the * i);
                mark.AddLast(new Point((int)xxx, (int)yyy));
                g.DrawEllipse(p, (float)(xxx - r), (float)(yyy - r), (float)r * 2, (float)r * 2);
                foreach (var point in mark)
                {
                    g.FillEllipse(new SolidBrush(Color.Tomato), point.X, point.Y, 2, 2);
                }
                g.DrawLine(p, (float)xxx, (float)yyy, (float)xx, (float)yy);
                g.DrawLine(p, (float)xx, (float)yy, (float)x, (float)y); 
            }
        }
        void draw(object o,PaintEventArgs e)
        {
            now = (now + 1) % period;
            int w = Math.Min(ClientSize.Width, ClientSize.Height);
            e.Graphics.DrawImage(bit[now],0,0,w,w); 
        }
        static void Main()
        {
            Application.Run(new Haha());
        }
    }
    

     The oval rotates around its own corner.

     1 using System;
     2 using System.Windows.Forms;
     3 using System.Drawing;
     4 class Haha : Form
     5 {
     6     Haha()
     7     {
     8         Text = "椭圆焦点极坐标方程:顺时针旋转减去旋转角,逆时针旋转加上旋转角";
     9         Paint += draw;
    10         WindowState = FormWindowState.Maximized; 
    11     }
    12     double a, b, w, h;
    13     double c, e, k;
    14     double fx(double the, double phi)
    15     {
    16         return k / (1 + e * Math.Cos(the - phi)) * Math.Cos(the);
    17     }
    18     double fy(double the, double phi)
    19     {
    20         return k / (1 + e * Math.Cos(the - phi)) * Math.Sin(the);
    21     }
    22     Point mix, miy, corner;
    23     double minX(double phi)
    24     {
    25         double l = Math.PI / 2, r = Math.PI / 2 * 3;
    26         while (r - l > 1e-8)
    27         {
    28             double d = (r - l) / 3;
    29             double lm = l + d;
    30             double rm = r - d;
    31             if (fx(lm, phi) > fx(rm, phi)) l = lm;
    32             else r = rm;
    33         }
    34         mix.X = (int)fx(l, phi);
    35         miy.Y = (int)fy(l, phi);
    36         return fx(l, phi);
    37     }
    38     double minY(double phi)
    39     {
    40         double l = -Math.PI, r = 0;
    41         while (r - l > 1e-8)
    42         {
    43             double d = (r - l) / 3;
    44             double lm = l + d;
    45             double rm = r - d;
    46             if (fy(lm, phi) > fy(rm, phi)) l = lm;
    47             else r = rm;
    48         }
    49         miy.X = (int)fx(l, phi);
    50         miy.Y = (int)fy(l, phi);
    51         return fy(l, phi);
    52     }
    53     void draw(object o, PaintEventArgs pe)
    54     { 
    55         double phi = Math.PI*44/180;
    56         Text = "" + phi / Math.PI * 180;
    57         pe.Graphics.Clear(Color.Wheat);
    58         var pen = new Pen(new SolidBrush(Color.Aqua), 3);
    59         double the = 2 * Math.PI / 5000;
    60         a=Math.Min(ClientSize.Width,ClientSize.Height)>>2;
    61         b=0.618*a;
    62         k=b*b/a;
    63         c=Math.Sqrt(a*a-b*b);
    64         e=c/a;
    65         int centerX = ClientSize.Width >> 1;
    66         int centerY = ClientSize.Height >> 1;
    67         for (double i = 0; i< 2 * Math.PI; i += the)
    68         {
    69             double x=k/(1+e*Math.Cos(i-phi))*Math.Cos(i);
    70             double y = k / (1 + e * Math.Cos(i-phi)) * Math.Sin(i);
    71             pe.Graphics.FillEllipse(new SolidBrush(Color.Tomato),(int)(x+centerX),(int)(y+centerY),2,2);
    72         }
    73         pe.Graphics.FillEllipse(new SolidBrush(Color.Tomato), centerX, centerY,8,8);
    74         minX(phi);
    75         minY(phi);
    76         corner.X=mix.X;
    77         corner.Y=miy.Y;
    78         mix.X += centerX;
    79         mix.Y += centerY;
    80         miy.X += centerX;
    81         miy.Y += centerY;
    82         corner.X += centerX;
    83         corner.Y += centerY;
    84         pen.Color = Color.Black;
    85         pe.Graphics.DrawLine(pen, mix, corner);
    86         pen.Color = Color.Blue;
    87         pe.Graphics.DrawLine(pen, miy, corner);
    88         pe.Graphics.FillEllipse(new SolidBrush(Color.Blue), miy.X, miy.Y, 8, 8);
    89     }
    90     static void Main()
    91     {
    92         Application.Run(new Haha());
    93     }
    94 }
  • 相关阅读:
    【ZOJ3195】Design the City-LCA算法
    【ZOJ3195】Design the City-LCA算法
    【POJ1330】Nearest Common Ancestors-LCA算法
    【POJ1330】Nearest Common Ancestors-LCA算法
    【POJ3237】Tree-树链剖分
    【POJ3237】Tree-树链剖分
    【SPOJ375】Query on a tree-树链剖分
    perl 回调必须是函数引用
    运行复制的ZooKeeper 部署
    运行复制的ZooKeeper 部署
  • 原文地址:https://www.cnblogs.com/weiyinfu/p/4936356.html
Copyright © 2011-2022 走看看