利用CSS3实现动画与过渡效果

发布时间: 2023-12-19 01:00:01 阅读量: 62 订阅数: 40
# 1. CSS3动画与过渡效果的介绍 ## 1.1 CSS3动画的概念及优势 CSS3动画是指利用CSS3技术实现的网页元素动态效果,相比传统的JavaScript实现动画,CSS3动画具有性能优秀、易用性、兼容性好等特点。利用CSS3动画可以实现页面元素的平移、旋转、缩放、渐变等动画效果,极大地丰富了Web页面的交互性和视觉效果。 ```css /* 示例:使用CSS3实现一个平移动画 */ @keyframes slidein { from { transform: translateX(-100%); } to { transform: translateX(0); } } .element { animation: slidein 1s ease forwards; } ``` **代码解释:** - `@keyframes`定义了一个名为`slidein`的关键帧动画,实现元素从左侧划入的效果。 - `animation`属性将`slidein`动画绑定到`.element`元素上,持续1秒,以`ease`的速度曲线播放,并在动画结束后保持最终状态。 **结果说明:** `.element`元素将会在1秒内沿着X轴从左侧划入到页面中。 ## 1.2 CSS3过渡效果的概念及应用场景 CSS3过渡效果指的是元素在不同状态之间的平滑过渡,常用于实现鼠标悬停、点击等交互操作下的状态切换效果。通过设置`transition`属性,可以让元素的属性值在状态变化时平稳过渡,而不是简单地突变。这种过渡效果可以让页面呈现更加柔和、自然的视觉体验。 ```css /* 示例:使用CSS3实现一个按钮的颜色过渡效果 */ .button { background-color: #3498db; transition: background-color 0.3s ease; } .button:hover { background-color: #e74c3c; } ``` **代码解释:** - 初始化`.button`按钮的背景色为蓝色。设置`transition`属性,当背景色发生变化时,持续0.3秒,使用`ease`速度曲线进行过渡效果。 - 当鼠标悬停在按钮上时,背景色过渡到红色。 **结果说明:** 当鼠标悬停在按钮上时,背景色会在0.3秒内平滑过渡到红色,而不是突变变化。 # 2. CSS3动画的基本使用方法 CSS3动画是通过定义关键帧或者过渡效果来实现元素的动态效果。在本章中,我们将介绍CSS3中关键帧动画和过渡效果的基本使用方法,以及动画属性的详细解析。让我们一起来深入了解CSS3动画的基础知识。 ### 2.1 CSS3中的关键帧动画 在CSS3中,可以通过`@keyframes`关键字来定义关键帧动画。下面是一个简单的例子,实现一个元素从左至右平移的动画效果: ```css @keyframes slideIn { from { transform: translateX(-100%); } to { transform: translateX(0); } } .element { animation: slideIn 1s ease-in-out; } ``` 代码解析: - 使用`@keyframes`定义了一个名为`slideIn`的关键帧动画,`from`表示起始状态,`to`表示结束状态。 - `.element`选择器定义了要应用动画的元素,并使用`animation`属性指定了动画名称、持续时间和时间函数。 当应用以上CSS后,`.element`元素将会从左侧滑动进入,持续1秒,过程中使用了easing函数来让动画更加平滑自然。 ### 2.2 CSS3中的过渡效果 除了关键帧动画,CSS3还支持通过`transition`属性实现过渡效果。下面是一个示例,当鼠标悬停在元素上时,实现元素颜色渐变的过渡效果: ```css .element { background-color: #ff0000; transition: background-color 0.3s ease; } .element:hover { background-color: #00ff00; } ``` 代码解析: - 初始状态下,`.element`的背景色为红色。 - 当鼠标悬停在元素上时,背景色将在0.3秒内平滑过渡到绿色,过程中使用了easing函数来使过渡更加柔和。 通过以上示例,我们可知道CSS3的过渡效果可以使元素在不同状态下平滑过渡,而不需要定义复杂的关键帧动画。 ### 2.3 CSS3动画属性的详细解析 在CSS3动画中,有许多属性可以控制动画的表现,如`animation-name`、`animation-duration`、`animation-timing-function`、`animation-delay`和`animation-iteration-count`等。这些属性的详细解析将在接下来的章节中进行讲解。 通过本章的学习,我们对CSS3中关键帧动画和过渡效果有了初步的了解,并对动画属性有了一定的认识。在接下来的章节中,我们将更深入地学习如何利用CSS3实现各种动画效果。 # 3. 使用CSS3实现基本动画效果 ### 3.1 实现元素的平移动画 平移动画可以让元素在页面中水平或垂直方向上进行移动,可以通过CSS3的`transform`属性来实现。 #### 代码示例 ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>CSS3 Animation</title> <style> .box { width: 100px; height: 100px; background-color: red; position: relative; animation-name: translateAnimation; animation-duration: 2s; animation-iteration-count: infinite; animation-direction: alternate; } @keyframes translateAnimation { from { transform: translateX(0); } to { transform: translateX(200px); } } </style> </head> <body> <div class="box"></div> </body> </html> ``` #### CodePen 演示链接 [点击查看演示](https://codepen.io/pen/GRpWxeN) #### 代码解析 - 在HTML文档中,我们创建一个大小为100px * 100px的红色方块,并给它一个类名为"box"。 - 接着,在CSS中,我们使用`@keyframes`来定义一个名为`translateAnimation`的关键帧动画。 - 在关键帧动画中,我们使用`transform`属性来控制元素在X方向上的平移。初始状态为`translateX(0)`,结束状态为`translateX(200px)`,表示元素在X轴上向右平移200像素。 - 接下来,我们给元素添加动画效果,通过`animation-name`属性指定动画名称为`translateAnimation`,`animation-duration`属性指定动画持续时间为2秒,`animation-iteration-count`属性指定动画循环播放次数为无限循环,`animation-direction`属性指定动画在每次循环后反向播放,实现来回平移的效果。 - 最后,在`<body>`标签中插入该元素即可看到平移动画效果。 #### 结果说明 运行代码后,将会看到一个红色方块在页面中水平方向上来回移动。 # 4. 利用CSS3实现高级动画效果 在这一章节中,我们将介绍如何利用CSS3实现一些高级的动画效果。CSS3提供了丰富的属性和方法,使得我们可以实现各种炫酷的动画效果。下面分别介绍几种常见的高级动画效果的实现方法。 #### 4.1 实现元素的渐变动画 CSS3中的渐变效果可以让一个元素的颜色或背景颜色在一定时间内平滑过渡。通过设置`transition`属性和`@keyframes`关键帧动画,我们可以实现元素的渐变动画。 具体步骤如下: 1. 首先,给需要实现渐变动画的元素添加一个类名或选择器,例如`.fade-in`。 2. 接下来,在CSS中使用`@keyframes`关键帧动画定义一个渐变动画的过程。例如: ```css @keyframes gradient-animation { 0% { background-color: red; } 50% { background-color: yellow; } 100% { background-color: blue; } } ``` 这里定义了一个由红色过渡到黄色再过渡到蓝色的渐变动画。 3. 然后,通过设置`transition`属性,将渐变动画应用到元素上。例如: ```css .fade-in { transition: background-color 2s ease-in-out; } ``` 这里设置了一个两秒的动画过程,并应用到了背景颜色上。 4. 最后,在HTML中,为需要实现渐变动画的元素添加相应的类名或选择器。例如: ```html <div class="fade-in">渐变动画效果</div> ``` 代码总结:通过使用`@keyframes`关键帧动画和`transition`属性,我们可以轻松地实现元素的渐变动画。 结果说明:当页面加载完成后,元素将平滑过渡从红色到黄色,最后再过渡到蓝色。 #### 4.2 实现元素的淡入淡出效果 CSS3中的淡入淡出效果可以让元素在一定时间内逐渐出现或消失。通过设置`opacity`属性和`transition`属性,我们可以实现元素的淡入淡出效果。 具体步骤如下: 1. 首先,给需要实现淡入淡出效果的元素添加一个类名或选择器,例如`.fade`。 2. 接下来,在CSS中设置元素的初始状态和结束状态。例如: ```css .fade { opacity: 0; } .fade.show { opacity: 1; } ``` 这里将初始状态的透明度设置为0,结束状态的透明度设置为1。 3. 然后,通过设置`transition`属性,将淡入淡出效果应用到元素上。例如: ```css .fade { transition: opacity 1s ease-in-out; } ``` 这里设置了一个一秒的动画过程,并应用到了透明度上。 4. 最后,在JavaScript中,通过添加或移除类名的方式来控制元素的显示和隐藏。例如: ```javascript // 显示元素 element.classList.add("show"); // 隐藏元素 element.classList.remove("show"); ``` 代码总结:通过设置`opacity`属性和`transition`属性,并通过添加或移除类名的方式来控制元素的显示和隐藏,我们可以实现元素的淡入淡出效果。 结果说明:当添加了`.show`类名时,元素将逐渐从透明到不透明进行淡入;当移除了`.show`类名时,元素将逐渐从不透明到透明进行淡出。 #### 4.3 实现元素的弹跳动画 CSS3中的弹跳动画效果可以让元素在一定时间内模拟弹跳的效果。通过设置`@keyframes`关键帧动画,我们可以实现元素的弹跳动画。 具体步骤如下: 1. 首先,给需要实现弹跳动画的元素添加一个类名或选择器,例如`.bounce`。 2. 接下来,在CSS中使用`@keyframes`关键帧动画定义一个弹跳动画的过程。例如: ```css @keyframes bounce-animation { 0% { transform: translateY(0); } 25% { transform: translateY(-30px); } 50% { transform: translateY(0); } 75% { transform: translateY(-15px); } 100% { transform: translateY(0); } } ``` 这里定义了一个元素在垂直方向上模拟弹跳的动画效果。 3. 然后,通过设置`animation`属性,将弹跳动画应用到元素上。例如: ```css .bounce { animation: bounce-animation 1s ease-in-out infinite; } ``` 这里设置了一个一秒的动画过程,并设置为无限循环。 4. 最后,在HTML中,为需要实现弹跳动画的元素添加相应的类名或选择器。例如: ```html <div class="bounce">弹跳动画效果</div> ``` 代码总结:通过使用`@keyframes`关键帧动画和`animation`属性,我们可以实现元素的弹跳动画。 结果说明:元素将在垂直方向上模拟弹跳的效果,不断重复进行。 # 5. 应用CSS3过渡效果实现页面过渡效果 在本章中,我们将探讨如何利用CSS3过渡效果实现页面过渡效果。页面过渡效果是指在页面加载、元素切换或页面链接跳转时,通过渐变、缩放、旋转等方式让页面呈现出平滑的过渡效果,提升用户体验。 #### 5.1 页面加载过渡效果 页面加载过渡效果可以通过CSS3过渡属性配合关键帧动画实现。我们可以为页面元素设置初始样式,再通过过渡效果逐渐改变样式,实现页面加载时的动画效果。 ```html <!DOCTYPE html> <html> <head> <style> /* 设置初始样式 */ .page { opacity: 0; transform: scale(0.9); transition: opacity 0.5s, transform 0.5s; } /* 过渡效果 */ .page.loaded { opacity: 1; transform: scale(1); } </style> </head> <body> <div class="page" id="content"> <p>页面加载中...</p> </div> <script> // 页面加载完成后添加loaded类名,触发过渡效果 window.onload = function() { document.getElementById('content').classList.add('loaded'); }; </script> </body> </html> ``` **代码说明:** - 通过设置初始样式和过渡效果,实现页面加载时元素的淡入和缩放效果。 - 使用JavaScript在页面加载完成后为元素添加loaded类名,触发过渡效果。 #### 5.2 页面元素切换过渡效果 在网页中,有时需要切换元素时实现平滑过渡效果,可以通过CSS3过渡效果来实现。我们可以为元素设置不同的样式,并通过过渡属性让元素在切换时具有动画效果。 ```html <!DOCTYPE html> <html> <head> <style> /* 初始样式 */ .page { opacity: 1; transition: opacity 0.5s; } .hidden { opacity: 0; } </style> </head> <body> <div class="page" id="content"> <p>页面内容1</p> <button onclick="changeContent()">切换内容</button> </div> <script> function changeContent() { var content = document.getElementById('content'); content.classList.add('hidden'); // 添加隐藏样式 setTimeout(function() { content.innerHTML = '<p>页面内容2</p>'; // 改变内容 content.classList.remove('hidden'); // 移除隐藏样式,添加过渡效果 }, 500); // 等待0.5秒后切换内容 } </script> </body> </html> ``` **代码说明:** - 通过初始样式和过渡效果实现页面内容的切换效果。 - 点击按钮触发JavaScript函数,改变页面内容并添加/移除样式类名,实现切换过渡效果。 #### 5.3 页面链接跳转过渡效果 在页面链接跳转时,我们也可以利用CSS3过渡效果实现页面跳转的平滑动画效果。通过页面跳转前的样式设定和页面跳转后的样式变化,配合过渡效果,让页面在跳转时呈现出过渡效果。 ```html <!DOCTYPE html> <html> <head> <style> /* 初始样式 */ .page { opacity: 1; transition: opacity 0.5s; } .hidden { opacity: 0; } </style> </head> <body> <div class="page" id="content"> <a href="#about" onclick="pageJump()">跳转到关于页面</a> </div> <div id="about" style="display: none;"> <p>关于页面内容</p> </div> <script> function pageJump() { var content = document.getElementById('content'); content.classList.add('hidden'); // 添加隐藏样式 setTimeout(function() { document.getElementById('about').style.display = 'block'; // 显示目标页面内容 content.style.display = 'none'; // 隐藏当前页面内容 content.classList.remove('hidden'); // 移除隐藏样式,添加过渡效果 }, 500); // 等待0.5秒后执行跳转 } </script> </body> </html> ``` **代码说明:** - 通过初始样式、过渡效果和JavaScript函数实现页面链接跳转的平滑过渡动画效果。 - 点击链接触发JavaScript函数,改变页面内容的显示和样式,实现页面的平滑跳转效果。 在本章中,我们详细介绍了如何利用CSS3过渡效果实现页面加载、元素切换和页面链接跳转的平滑动画效果。通过合理运用CSS3过渡效果,可以为页面增添更加优秀的用户体验。 # 6. 优化CSS3动画与过渡效果的性能 在实现CSS3动画与过渡效果时,除了关注效果实现的美观性,也需要注意性能优化,以提升用户体验。本章将介绍几种优化CSS3动画与过渡效果性能的方法。 #### 6.1 使用硬件加速优化性能 在进行动画或过渡效果时,可以使用硬件加速来提高性能。通过将动画或过渡效果应用于CSS属性`transform`和`opacity`上,可以触发浏览器使用硬件加速来处理动画,从而提升性能。 ```css .element { transform: translateZ(0); } /* 或者 */ .element { will-change: transform, opacity; } ``` 在以上代码中,通过设置`translateZ(0)`或者`will-change`属性,可以促使浏览器使用硬件加速处理对应的动画效果。 #### 6.2 使用requestAnimationFrame提升动画流畅度 在JavaScript中,可以使用`requestAnimationFrame`方法来优化动画的流畅度。相较于`setTimeout`或`setInterval`方法,`requestAnimationFrame`能够更好地与浏览器的刷新频率同步,避免造成掉帧现象。 ```javascript function animate() { element.style.transform = 'translateX(100px)'; // other animation code here requestAnimationFrame(animate); } // start the animation animate(); ``` 以上代码中,通过递归调用`requestAnimationFrame`方法,可以实现更加流畅的动画效果。 #### 6.3 合理控制动画的帧率及持续时间 在设计动画效果时,需要考虑动画的帧率和持续时间,合理控制可以更好地平衡性能和视觉效果。 ```css .element { animation: slide 1s ease-in-out infinite; } @keyframes slide { 0% { transform: translateX(0); } 50% { transform: translateX(100px); } 100% { transform: translateX(0); } } ``` 在以上代码中,通过`@keyframes`定义了一个持续1秒的动画,且使用`ease-in-out`的时间函数使动画更加流畅自然。 通过以上优化方法,可以更好地提升CSS3动画与过渡效果的性能,使用户在浏览页面时获得更加流畅和愉悦的体验。
corwn 最低0.47元/天 解锁专栏
买1年送3月
点击查看下一篇
profit 百万级 高质量VIP文章无限畅学
profit 千万级 优质资源任意下载
profit C知道 免费提问 ( 生成式Al产品 )

相关推荐

张诚01

知名公司技术专家
09级浙大计算机硕士,曾在多个知名公司担任技术专家和团队领导,有超过10年的前端和移动开发经验,主导过多个大型项目的开发和优化,精通React、Vue等主流前端框架。
专栏简介
本专栏以CSS3为主题,深入剖析了CSS3在网页设计和布局中的丰富功能与应用。从基础入门到高级技巧,系统性地介绍了CSS3选择器、盒模型、字体排版、背景样式、渐变效果、动画过渡、Flex布局、响应式设计、2D与3D变换、图形绘制、表单表格优化、变量计算函数等多个方面的知识与技巧。文章涵盖了大量实用案例和技术解析,旨在帮助读者全面掌握CSS3的应用技巧,提升页面视觉效果和用户体验。同时,还介绍了网页导航设计、打印优化、性能渲染优化、滚动特效等实用技巧,使读者在网页设计中能够灵活运用CSS3,实现丰富多彩的页面效果。本专栏适合对CSS3前端技术感兴趣的读者,无论是初学者还是有一定经验的开发者,都能从中获得实用而深入的知识。
最低0.47元/天 解锁专栏
买1年送3月
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
C知道 免费提问 ( 生成式Al产品 )

最新推荐

FLUENT VOF调试秘籍:提升仿真性能的5个最佳实践

![FLUENT VOF调试秘籍:提升仿真性能的5个最佳实践](https://www.frontiersin.org/files/Articles/796789/fsens-02-796789-HTML/image_m/fsens-02-796789-g013.jpg) # 摘要 本文系统性地介绍了VOF模型的基础知识、FLUENT中的应用以及仿真性能调试技巧。首先概述了VOF模型在多相流仿真中的基本概念、数学基础和物理假设,并对FLUENT软件中的VOF模型参数配置进行了详细说明。接着,针对VOF仿真过程中可能遇到的性能调试问题,本文提出了一系列优化网格、初始化策略、误差分析以及并行计算

【模拟工具选型指南】:SPECTRE与HSPICE的对决

![【模拟工具选型指南】:SPECTRE与HSPICE的对决](https://semiwiki.com/wp-content/uploads/2021/05/SPICE-spectrum-min.jpg) # 摘要 模拟工具在电子设计领域扮演着关键角色,其中SPECTRE和HSPICE是业界广泛认可的模拟器。本文首先探讨了模拟工具的理论基础,特别是SPECTRE和HSPICE的核心算法及其技术特点。接着,通过功能对比,分析了两者在支持的模拟类型、用户界面易用性以及高级功能和性能方面的差异。文章进一步通过多个实践应用案例,展示了这两种模拟器在信号完整性、射频设计和集成电路设计等领域的实际应用

【DeviceNet网络故障案例集】:10个实战案例的深度解析

![DeviceNet 网络故障诊断指导](https://pulspower.co.za/wp-content/uploads/2017/09/DEVICENET.png) # 摘要 DeviceNet网络技术作为一种开放的、经济高效的网络解决方案,在工业自动化领域得到了广泛应用。本文首先概述了DeviceNet网络的基本组成和工作原理,包括物理层和数据链路层的介绍以及通信协议和网络模型。随后,本文深入探讨了故障诊断的基础知识,涵盖诊断工具的介绍、诊断流程和技巧,以及网络性能分析的基础方法。通过实战案例的深入解析,本研究详细阐述了从物理层到应用层不同层次故障的分析、诊断与解决过程。此外,本

【跨平台C#应用开发】:组态王中的实现技巧

![组态王](http://www.zkview.com/docs/example/synthesis/06.png) # 摘要 随着技术的不断进步,跨平台应用开发已成为软件行业的重要趋势。本文详细探讨了在.NET Core框架下使用C#进行跨平台应用开发的全面过程。首先介绍了.NET Core框架和C#语言的跨平台能力,接着分析了开发工具和环境配置的重要性。文章深入到实战技巧,包括UI框架的选择、数据存储方案以及网络通信。同时,本文还讨论了跨平台应用开发中的高级话题,如测试、调试、性能优化以及安全性最佳实践。最后,通过案例研究,分析了成功的跨平台开发架构和应对常见问题的策略。本文旨在为开发

【CANdelaStudio与AUTOSAR整合攻略】:工具与架构的无缝协作

![【CANdelaStudio与AUTOSAR整合攻略】:工具与架构的无缝协作](https://i-blog.csdnimg.cn/blog_migrate/17dff165091fca03300ef97c456b0507.png) # 摘要 随着汽车电子化和智能化水平的不断提升,AUTOSAR架构已成为车载软件开发的标准之一。本文首先概述了CANdelaStudio与AUTOSAR的基础知识,详细探讨了AUTOSAR的架构原理、工作模式及开发流程。随后,本文介绍了CANdelaStudio的主要功能、诊断能力和项目管理策略,并阐述了将CANdelaStudio与AUTOSAR整合的前提

Oracle FSG报表生成器:掌握其工作原理,让你的报表智能高效

# 摘要 Oracle FSG报表生成器是Oracle财务软件套件中用于创建复杂财务报表的重要工具。本文旨在详细介绍FSG报表生成器的概述、工作原理、配置优化、高级应用技巧以及最佳实践,最后展望了该技术的未来发展与趋势。文章首先概述了Oracle FSG报表生成器的基本概念,然后深入解析了其工作原理,包括数据结构的解析、逻辑计算以及输出展示。进一步地,文章讨论了如何通过环境配置和性能调整、自定义格式和模板设计以及安全性和审计日志管理来优化报表生成器的性能。高级应用技巧部分涵盖了交互式功能实现、报表集成和自动化,以及处理复杂报表需求的方法。在最佳实践章节,文章分析了成功案例并讨论了性能监控与故障

【性能剖析】:如何通过5个步骤优化TI-SN75DPHY440SS的电气特性与应用

![【性能剖析】:如何通过5个步骤优化TI-SN75DPHY440SS的电气特性与应用](https://e2e.ti.com/cfs-file/__key/communityserver-discussions-components-files/138/RS485-to-TTL.PNG) # 摘要 本文深入探讨了TI-SN75DPHY440SS芯片的基础知识、电气特性和性能优化。首先介绍了TI-SN75DPHY440SS的重要性和基础电气特性,随后详细分析了其主要电气特性,包括工作电压、功耗、信号完整性和噪声特性,并探讨了性能测试的准备、步骤以及数据记录与分析技巧。接着,文章基于理论框架,

网络规划设计师考试秘籍:6大高效应对错误代码的技巧

![网络规划设计师考试秘籍:6大高效应对错误代码的技巧](https://cdn.educba.com/academy/wp-content/uploads/2020/01/Logical-Operatorts1.png) # 摘要 本文旨在为网络规划设计师考试提供全面概览,并深入探讨错误代码理论基础及其在网络故障诊断中的应用。文章首先介绍了错误代码的分类、特性以及与网络设备状态的关系,特别关注了在网络安全中的角色与防御策略。随后,文中详述了高效应对网络错误代码的策略,包括预防、监控、诊断和修复流程。实战演练章节通过真实案例分析,展示了错误代码排查与解决的具体步骤和经验总结。最后,探讨了错误

【高效软件开发的秘密】:掌握这五个代码质量提升关键步骤

![【高效软件开发的秘密】:掌握这五个代码质量提升关键步骤](https://dr-kino.github.io/images/posts/00005-E.png) # 摘要 本文探讨了软件开发过程中确保代码质量的重要性,并深入分析了代码质量评估的基础、代码审查与重构技巧、自动化测试与持续集成,以及进阶策略。文章强调了代码质量定义、评估标准及静态代码分析工具的作用,并详细介绍了代码复杂度度量的意义和方法。同时,本文还讨论了代码审查流程、重构的基本原则和实践案例分析,以及单元测试与集成测试的最佳实践和持续集成的设置。最后,文章深入探讨了设计模式、架构层面的代码质量管理,以及开发人员个人能力提升

数据可视化革命:"天擎"平台如何将复杂气象数据简单化

![数据可视化革命:"天擎"平台如何将复杂气象数据简单化](https://news.mit.edu/sites/default/files/styles/news_article__image_gallery/public/images/201812/CliMA-2018.jpg?itok=YLAla3QF) # 摘要 数据可视化在将复杂数据转化为直观图形方面发挥着重要作用,尤其在专业领域如气象学中,可提供深入的分析与预测。本文深入探讨了“天擎”平台的核心技术,涵盖数据处理能力、可视化引擎和高级分析工具,旨在解决数据可视化面临的挑战。通过案例分析,展示了“天擎”在气象数据实时监测、历史数据