利用C#实现绘制出地球旋转效果

 更新时间:2023年02月28日 16:05:17   作者:微小冷  
这篇文章主要为大家详细介绍了如何利用C#语言实现绘制出地球旋转的效果,文中的示例代码讲解详细,具有一定的参考价值,需要的可以了解一下

将方形的图像映射到正方形上似乎并没有什么难度,所以接下来要做的是把图像映射到球面上。

而球的参数方程为

x​=rcosϕcosθ

y=rcosϕsinθ

z=rsinϕ​

由于r的值是恒定的,所以生成球的关键参数就是θ, φ而把地图贴在球上就相当于把图像坐标(x,y)映射到坐标θ,φ上。

其中地图为

private MeshGeometry3D SetEarth(int numx, int numz, double r=3)
{
    MeshGeometry3D mesh = new MeshGeometry3D();

    double dTh = 2 * Math.PI / numx;
    double dPhi = Math.PI / numz;

    double X(double th, double phi) => r * Math.Sin(phi) * Math.Cos(th);
    double Y(double th, double phi) => r * Math.Sin(phi) * Math.Sin(th);
    double Z(double phi) => r * Math.Cos(phi);

    // Make the points.
    for (int i = 0; i <= numx; i++)
        for (int j = 0; j <= numz; j++)
        {
            var th = i * dTh;
            var phi = j * dPhi;
            mesh.Positions.Add(new Point3D(X(th, phi), Y(th, phi), Z(phi)));
            mesh.TextureCoordinates.Add(new Point(th, phi));
        }

    // 生成三角形
    for (int i = 0; i < numx; i++)
        for (int j = 0; j < numz; j++)
        {
            int i1 = i * (numz + 1) + j;
            int i2 = i1 + 1;
            int i3 = i2 + (numz + 1);
            int i4 = i3 - 1;
            mesh.TriangleIndices.Add(i1);
            mesh.TriangleIndices.Add(i2);
            mesh.TriangleIndices.Add(i3);

            mesh.TriangleIndices.Add(i1);
            mesh.TriangleIndices.Add(i3);
            mesh.TriangleIndices.Add(i4);
        }
    return mesh;
}

生成的地球为

如果生成之后地球躺平了,可以调整一下LookDirection。

如果仅仅是这样,那显然是不行的,因为只看到一个二维的圆形,无法让人觉得这是个地球,接下来就要让这个球转起来。

方法是新建一个Timer,

public MainWindow()
{
    InitializeComponent();
    initialize3D();
    timer.Interval = TimeSpan.FromMilliseconds(5);
    timer.Tick += Timer_Tick;
    timer.Start();
}

然后随着时间而旋转

double thAngle = 0;
private void Timer_Tick(object? sender, EventArgs e)
{
    thAngle = thAngle > Math.PI ? 0 : thAngle + 0.1;
    Rotation3D rotation = new AxisAngleRotation3D(new Vector3D(0,0,1), thAngle);
    var rot = new RotateTransform3D(rotation, new Point3D(0,0,0));
    Point3D[] pts = mesh.Positions.ToArray();
    rot.Transform(pts);
    mesh.Positions = new Point3DCollection(pts);
}

结果为

到此这篇关于利用C#实现绘制出地球旋转效果的文章就介绍到这了,更多相关C#地球旋转内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C#泛型方法在lua中表示的一种设计详解

    C#泛型方法在lua中表示的一种设计详解

    这篇文章主要给大家介绍了关于C#泛型方法在lua中表示的一种设计的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • C#获取文件MD5值的实现示例

    C#获取文件MD5值的实现示例

    文件的md5值,即文件签名,为了验证文件的正确性,是否被恶意篡改等。每个文件有一个唯一的md5。下面这篇文中就给大家介绍了如何利用C#获取文件MD5值,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-12-12
  • C#中Linq查询基本操作使用实例

    C#中Linq查询基本操作使用实例

    这篇文章主要介绍了C#中Linq查询基本操作使用实例,有需要的朋友可以参考一下
    2013-12-12
  • 深入多线程之:深入分析Interlocked

    深入多线程之:深入分析Interlocked

    本篇文章是对Interlocked进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C#连接MySQL数据库的方法步骤

    C#连接MySQL数据库的方法步骤

    最近两天在解决C#连接MySql数据库的问题,通过不同的从网上学习,最终找到了解决的办法,下面这篇文章主要给大家介绍了关于C#连接MySQL数据库的方法步骤,需要的朋友可以参考下
    2023-01-01
  • C#实现设置电脑显示器参数

    C#实现设置电脑显示器参数

    这篇文章主要为大家详细介绍了如何利用C#实现设置电脑显示器参数,文中的示例代码讲解详细,对我们学习C#有一定的帮助,感兴趣的小伙伴可以跟随小编一起了解一下
    2022-12-12
  • C#求数组中元素全排列的方法

    C#求数组中元素全排列的方法

    这篇文章主要介绍了C#求数组中元素全排列的方法,较为详细的分析了数组全排列算法的原理与实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • C# 16进制与字符串、字节数组之间的转换

    C# 16进制与字符串、字节数组之间的转换

    在串口通讯过程中,经常要用到 16进制与字符串、字节数组之间的转换
    2009-05-05
  • 使用C#编写两个漂亮时钟的示例代码

    使用C#编写两个漂亮时钟的示例代码

    这篇文章主要为大家分享了两个使用C#编写的两个漂亮时钟的示例代码,文中的示例代码讲解详细,具有一定的参考价值,感兴趣的可以了解一下
    2023-07-07
  • 分析C# Dictionary的实现原理

    分析C# Dictionary的实现原理

    对于C#中的Dictionary类相信大家都不陌生,这是一个Collection(集合)类型,可以通过Key/Value(键值对的形式来存放数据;该类最大的优点就是它查找元素的时间复杂度接近O(1)。那么什么样的设计能使得Dictionary类实现O(1)的时间复杂度呢
    2021-06-06

最新评论