C#太阳系,行星轨道数学问题

时间:2018-03-14 11:58:39

标签: c# animation matrix graphics simulation

我正在写一个太阳系模拟程序;我只是一个使用C#的初学者。

我在自定义控件上使用OnPaint在表单上绘制图形。我对动画有问题,因为它不是让行星围绕太阳旋转(控制中心的一个固定点),而是围绕行星所在的点旋转。但是,这一点仍然围绕控制中心旋转。

我已在自定义控件的顶部声明了这些变量:

private color col1;
private float angle;
private double r1, r2, ex, why;

以下是OnPaint中的代码:

protected override void OnPaint(PaintEventArgs pe)
{
        this.DoubleBuffered = true;
        base.OnPaint(pe);
        Graphics g = pe.Graphics;

        AnimationControl anim = new AnimationControl(); 

        Planet sun = new Planet(50, 60);
        sun.drawSun(pe);

        angle += 0.01f;
        if (angle > 359)
        {
            angle = 0; 
        }
        Matrix matrix = new Matrix();
        matrix.Rotate(angle, MatrixOrder.Append);
        matrix.Translate(SandboxForm.ActiveForm.Width / 2,
            SandboxForm.ActiveForm.Height / 2, MatrixOrder.Append);
        g.Transform = matrix;

        r1 = 200; 
        r2 = 100; 
        double diameter = 40; 
        col1 = Color.Red;
        SolidBrush bru2 = new SolidBrush(col1); 
        ex = ((SandboxForm.ActiveForm.Width / 2) - diameter - (sun.getSunRadius())) + (r1 * (Math.Cos(angle))); /
        why = ((SandboxForm.ActiveForm.Height / 2) - diameter - (sun.getSunRadius())) + (r2 * (Math.Sin(angle))); 
        g.FillEllipse(bru2, (float)ex, (float)why, (float)diameter, (float)diameter); 
        Invalidate();
}

1 个答案:

答案 0 :(得分:1)

我必须简化你的代码,因为缺少类等。但是在这里你可以看到它现在可以做你想要的。

如果您尝试使用此代码,您会发现旋转和翻译的顺序很重要,但是当您尝试我的建议时它没有任何效果,因为您在申请之前进行了绘画改造。

另请注意,我的矩阵周围有using,因为您在完成它时应该将其丢弃。

    protected override void OnPaint(PaintEventArgs pe)
    {
        this.DoubleBuffered = true;
        base.OnPaint(pe);
        Graphics g = pe.Graphics;


        angle += 0.2f;
        if (angle > 359)
        {
            angle = 0;
        }
        using (Matrix matrix = new Matrix())
        {
            matrix.Rotate(angle, MatrixOrder.Append);
            matrix.Translate(300, 200, MatrixOrder.Append);

            g.Transform = matrix;
            pe.Graphics.DrawEllipse(Pens.Red, new Rectangle(50, 60, 50, 50));
        }


        Invalidate();
    }