winform 实现太阳,地球,月球 运作规律https://www.cnblogs.com/axing/p/18762710

最近我太太在考公学习,给我出了两道高中地理知识的题目,把我问的一头雾水,题目是这样的
第一题
第二题
看到这两道题,当时大脑飞速运转,差点整个身体都在自转了,所以产生了个偷懒的方法,用程序代替冥想,所以就有了这个小玩意的诞生.
Linux 的创始人 Linus Torvalds 在 2000-08-25 给linux-kernel 邮件列表的一封邮件提到的:
能说算不上什么,有本事就把你的代码给我看看。
1. 创建基本类
首先,我们创建一些基本的类来表示天体(如太阳、地球和月球)以及它们的运动。
public class CelestialBody
{
public string Name { get; set; }
public int Radius { get; set; } // 半径
public Color Color { get; set; } // 颜色
public double DistanceFromSun { get; set; } // 距离太阳的距离
public double OrbitalPeriod { get; set; } // 轨道周期(天)
public double RotationPeriod { get; set; } // 自转周期(天)
public double CurrentAngle { get; set; } // 当前角度(弧度) public CelestialBody(string name, int radius, Color color, double distanceFromSun, double orbitalPeriod, double rotationPeriod)
{
Name = name;
Radius = radius;
Color = color;
DistanceFromSun = distanceFromSun;
OrbitalPeriod = orbitalPeriod;
RotationPeriod = rotationPeriod;
CurrentAngle = 0;
} public void UpdatePosition(double timeStep)
{
// 计算角速度(弧度/天)
double angularVelocity = 2 * Math.PI / OrbitalPeriod; // 更新当前角度
CurrentAngle += angularVelocity * timeStep; // 确保角度在0到2π之间
CurrentAngle %= 2 * Math.PI;
} public (double X, double Y) GetPosition()
{
// 计算当前天体的位置
double x = DistanceFromSun * Math.Cos(CurrentAngle);
double y = DistanceFromSun * Math.Sin(CurrentAngle);
return (x, y);
}
}
2. 创建太阳、地球和月球
接下来,我们创建太阳、地球和月球的实例,并设置它们的属性。
// 初始化天体
sun = new CelestialBody("Sun", 50, Color.Yellow, 0, 0, 0); // 太阳静止不动
earth = new CelestialBody("Earth", 10, Color.Blue, 150, 365.25, 1); // 地球
moon = new CelestialBody("Moon", 5, Color.Gray, 30, 27.32, 27.32); // 月球
并且初始化一个定时器,用于刷新三个球体的运行状态
private void Timer_Tick(object sender, EventArgs e)
{
// 更新天体的位置
earth.UpdatePosition(0.1); // 时间步长为0.1天
moon.UpdatePosition(0.1); // 重绘窗体
this.Invalidate();
}
开始绘制太阳,地球和月亮
// 获取绘图对象
graphics = e.Graphics;
graphics.Clear(Color.Black); // 绘制太阳
DrawCelestialBody(sun, 400, 400); // 绘制地球
var earthPosition = earth.GetPosition();
DrawCelestialBody(earth, 400 + (int)earthPosition.X, 400 + (int)earthPosition.Y); // 绘制月球
var moonPosition = moon.GetPosition();
DrawCelestialBody(moon, 400 + (int)earthPosition.X + (int)moonPosition.X, 400 + (int)earthPosition.Y + (int)moonPosition.Y);
3. 运行模拟
运行上述代码,你将看到地球和月球在100天内的位置变化。这个模拟是一个非常简化的模型,假设地球和月球的轨道是完美的圆形,并且忽略了其他天体的引力影响。
看上去有点丑,我们添加写素材,去掉已知的轨迹边框,并且找些素材美化他们
并且标识出赤道和经线,以及南北半球
// 绘制南北半球标识
graphics.DrawLine(Pens.Red, x - radius, y, x + radius, y); // 赤道
graphics.DrawLine(Pens.Yellow, x, y - radius, x, y + radius); // 经线 // 绘制北极和南极
graphics.FillEllipse(Brushes.White, x - 3, y - radius - 3, 6, 6); // 北极
graphics.FillEllipse(Brushes.Green, x - 3, y + radius - 3, 6, 6); // 南极
如上我们绘制一条红线标识赤道,黄线标识经线,白色圆点表示北极,绿色圆点表示南极,这样方便我们根据不同象限,在脑海里面构思具体经纬度
4. 最终效果
图片素材 https://polyhaven.com/textures
4. 解题思路
四季变化的总结
根本原因:地球自转轴的倾斜(约 23.5 度)。
直接原因:地球在公转过程中,太阳直射点在南北回归线之间移动。
结果:不同时间段,地球表面接收到的太阳辐射量不同,从而导致温度变化和四季交替。
四季变化的原理
由于地球自转轴的倾斜,地球在公转过程中,不同时间段的太阳直射点会发生变化,从而导致四季变化。具体过程如下:
(1)春分和秋分
当地球公转到春分(约 3 月 21 日)和秋分(约 9 月 23 日)时,太阳直射点位于赤道。
此时,全球昼夜几乎等长。
北半球和南半球的季节相反(例如,北半球是春季,南半球是秋季)。
(2)夏至
当地球公转到夏至(约 6 月 21 日)时,太阳直射点位于北回归线(北纬 23.5 度)。
此时,北半球白天最长,夜晚最短,进入夏季;南半球则相反,进入冬季。
(3)冬至
当地球公转到冬至(约 12 月 22 日)时,太阳直射点位于南回归线(南纬 23.5 度)。
此时,北半球白天最短,夜晚最长,进入冬季;南半球则相反,进入夏季。
有了如图展示发现:
第一题,在四大卫星发射中心中,不仅仅文昌卫星发射中心位于低纬度,其他选项ABC都正确,D错误。
第二题,A,D两项都是错误的!:春分(3.21前后),秋分(9.23前后)太阳直射在赤道上,惊蛰(3.5)在春分之前,因此这一天太阳直射点仍在南半球,切太阳直射点在向北移动。BC两项:惊蛰(3.5)在春分前,此时太阳直射点仍在南半球,南半球昼长夜短,北半球昼短夜长,且北极圈内部分地区存在极夜现象,B错误,所以选C
5. 结束语
最后,预祝各位考公学子,榜上有名!成功上岸!
感谢各位耐心查阅! 由于系统引用文件较多,压缩后源码文件仍然很大,如果有需要源码的朋友,可以微信公众号联系博主,源码可以免费赠予~!如果觉得本篇博文对您或者身边朋友有帮助的,麻烦点个关注!赠人玫瑰,手留余香,您的支持就是我写作最大的动力,感谢您的关注,期待和您一起探讨!再会!
winform 实现太阳,地球,月球 运作规律https://www.cnblogs.com/axing/p/18762710的更多相关文章
- https://www.cnblogs.com/soundcode/p/4174410.html
https://www.cnblogs.com/soundcode/p/4174410.html 1.首先要在服务器端新建一个网站axpx页 然后再网站的后台写代码获取winform传过来的文件名. ...
- 转发自:一像素 十大经典排序算法(动图演示)原链接:https://www.cnblogs.com/onepixel/articles/7674659.html 个人收藏所用 侵删
原链接:https://www.cnblogs.com/onepixel/articles/7674659.html 个人收藏所用 侵删 0.算法概述 0.1 算法分类 十种常见排序算法可 ...
- @无痕客 https://www.cnblogs.com/wuhenke/archive/2012/12/24/2830530.html 通篇引用
无痕客 https://www.cnblogs.com/wuhenke/archive/2012/12/24/2830530.html 关于Async与Await的FAQ 关于Async与Await的 ...
- 访问路径:https://i.cnblogs.com/posts?categoryid=925678
https://i.cnblogs.com/posts?categoryid=925678
- URL https://i.cnblogs.com/EditPosts.aspx?opt=1
URL url = new URL("https://i.cnblogs.com");URL url1 = new URL(url, "EditPosts.aspx?op ...
- 随笔二-https://www.cnblogs.com/shang1680/p/9657994.html
作业要求来自https://edu.cnblogs.com/campus/gzcc/GZCC-16SE2/homework/2097 GitHub远程仓库的地址:https://github.com/ ...
- 211806189杨昊辰 https://www.cnblogs.com/honey1433223/
211806189杨昊辰 https://www.cnblogs.com/honey1433223/
- https://www.cnblogs.com/h2zZhou/p/5440271.html
https://www.cnblogs.com/h2zZhou/p/5440271.html
- https://www.cnblogs.com/yudanqu/p/9467803.html
https://www.cnblogs.com/yudanqu/p/9467803.html
- 211806385 黄存慧 https://www.cnblogs.com/huangch/ https://github.com/HuangCh327
211806385 黄存慧 https://www.cnblogs.com/huangch/ https://github.com/HuangCh327
随机推荐
- Qt编写的项目作品4-输入法V2019
一.功能特点 未采用Qt系统层输入法框架,独创输入切换机制. 纯QWidget编写,支持任何目标平台(亲测windows.linux.嵌入式linux等),支持任意Qt版本(亲测Qt4.6.0到Qt5 ...
- Python设计模式(第2版)中文的pdf电子书
Python设计模式(第2版)中文的pdf电子书下载地址:百度云盘,提取码:dmem
- 即时通讯技术文集(第24期):音视频WebRTC好文合集 [共20篇]
为了更好地分类阅读 52im.net 总计1000多篇精编文章,我将在每周三推送新的一期技术文集,本次是第 24 期. [- 1 -] 开源实时音视频技术WebRTC的现状 [链接] http://w ...
- JS端实现图片、视频时直接下载而不是打开预览
项目中的附件列表,通常情况都需要提供下载.删除的功能,功能本身没有什么要说的,都是基本功能,使用浏览器的的下载功能,也都是用window.open(url),或者window.location.hre ...
- 【BUG排查记】HttpUtil和SpringSecurity结合的坑
一.背景 最近为了做微服务高可用和优化上线流程,我参与了一个微服务的改造开发. 主要包括redis切换哨兵模式.接入高可用xxljob集群.配置和升级脚本优化. 二.问题描述 项目改造提测后,测试 ...
- 一种调试 线段树 / Treap / Splay / 左偏树 / LCT 等树形结构的技巧
前言 如果我们需要观察程序运行过程中,某一个变量.某一个序列的变化情况,你可以在修改的地方打断点 debug,或者直接在需要的地方输出就行了. 但是对于一些树形结构,我们不好将其直观地呈现出来,常常只 ...
- dubbo源码解析目录-总结列表
一.dubbo架构设计 1.十层架构第一层:service层,接口层,给服务提供者和消费者来实现的.第二层:config层,配置层,主要是对dubbo进行各种配置的.第三层:proxy层,服务代理层, ...
- RocketMQ的架构设计、关键特性、与应用场景详解
内容大纲: 1.RocketMQ的简介与演进 2. RocketMQ的架构设计 3.RocketMQ的关键特性 4.RocketMQ的应用场景 RocketMQ的简介 RocketMQ一个纯java. ...
- sqlserver grouping函数和with rollup的使用
--使用WITH ROLLUP 生成的结果集显示所选列中值的某一层次结构的聚合,GROUPING()函数判断是否根据当前字段进行了求和的行SELECT sjxm, (CASE WHEN GROUPIN ...
- 回顾我的软件开发经历:开发DAB
背景介绍 DAB(Device Automation Bus)是一种基于 MQTT 通信的轻量级协议,主要用于连接客厅中的消费电子产品(如智能电视和游戏机),并实现自动化测试.由于设备认证需要支持 D ...