当前位置: 首页 > news >正文

GEE学习笔记 六十:GEE中生成GIF动画

生成GIF动画这个是GEE新增加的功能之一,这一篇文章我会简单介绍一下如何使用GEE来制作GIF动画。

相关API如下:

参数含义:

    params:设置GIF动画显示参数,详细的参数可以参考ee.data.getMapId()

    callback:回调函数

其实还有另外的一个方法可以生成GIF动画就是使用缩略图的方式,具体的API如下所示:

如果只是查看API我们发现他并没有说这个可以生成GIF动画,这个是GEE的官方没有及时的更新文档造成的问题。我们在实际使用中会经常直接使用ui.Thumbnail来做相关gif动画输出,如果要使用getVideoThumbURL()也类似。

下面是我做的一个黄河口近三十年的变化动图

下面我会介绍如何做这个动态图。

(1)首先我们选定一个区域作为展示区域,具体区域如下图:

(2)相关生成GIF动画的代码如下:

var roi =/* color: #d63000 *//* displayProperties: [{"type": "rectangle"}] */ee.Geometry.Polygon([[[118.76701352910152, 37.95798438938449],[118.76701352910152, 37.58456192342209],[119.38224790410152, 37.58456192342209],[119.38224790410152, 37.95798438938449]]], null, false),l8_sr = ee.ImageCollection("LANDSAT/LC08/C01/T1_SR");Map.centerObject(roi, 8);Map.addLayer(roi, {color: "red"}, "roi");var sDate = "2013-1-1";var eDate = "2019-1-1";var l8Col = l8_sr.filterDate(sDate, eDate).filterBounds(roi).map(function(image) {var cloudShadowBitMask = 1 << 3;var cloudsBitMask = 1 << 5;var qa = image.select('pixel_qa');var mask = qa.bitwiseAnd(cloudShadowBitMask).eq(0).and(qa.bitwiseAnd(cloudsBitMask).eq(0));return image.updateMask(mask);}).map(function(image) {var time_start = image.get("system:time_start");image = image.multiply(0.0001);image = image.set("system:time_start", time_start);return image;}).select(["B2","B3","B4"], ['blue','green','red']);print(l8Col.limit(1));print(l8Col.size());var yearList = ee.List.sequence(ee.Date(sDate).get("year"), ee.Number(ee.Date(eDate).get("year")).subtract(1));var yearImgList = yearList.map(function(year) {year = ee.Number(year);var _sdate = ee.Date.fromYMD(year, 1, 1);var _edate = ee.Date.fromYMD(year.add(1), 1, 1);var tempCol = l8Col.filterDate(_sdate, _edate);var img = tempCol.median().clip(roi);img = img.set("year", year);img = img.set("system:index", ee.String(year.toInt()));return img;});var imgCol = ee.ImageCollection.fromImages(yearImgList);print("imgCol", imgCol);// 使用缩略图来制作展示var params = {crs: 'EPSG:3857',framesPerSecond: 2,region: roi,min: 0.0,max: 0.3,bands: ["red", "green", "blue"],dimensions: 512,};print(ui.Thumbnail(imgCol, params));print(imgCol.getVideoThumbURL(params))

代码分析:

    需要注意的问题,一是制作GIF图区域不能选择太大;二是区域内包含的像素点不能太多。

运行结果:

来源请引用:地理遥感生态网科学数据注册与出版系统.

 

http://www.lryc.cn/news/15403.html

相关文章:

  • react中的useEffect
  • 故障安全(Crash-Safe) 复制
  • Spring aop之针对注解
  • 【JavaScript速成之路】JavaScript数据类型转换
  • 21-绑定自定义事件
  • 【Mysql】触发器
  • CODESYS开发教程11-库管理器
  • 【UnityAR相关】Unity Vuforia扫图片成模型具体步骤
  • 2023年全国最新保安员精选真题及答案2
  • keil5安装了pack包但是还是不能选择device
  • 秒杀系统设计
  • 全面认识数据指标体系
  • 热榜首推!阿里内部都在用的Java后端面试笔记,主流技术全在里面了!备战2023Java面试,拿理想offer
  • Android架构设计——【 APT技术实现butterknife框架 】
  • 线程的基本概念
  • java面试题中常见名词注解
  • SpringAOP从入门到源码分析大全,学好AOP这一篇就够了(二)
  • 华为OD机试 - 斗地主(C++) | 附带编码思路 【2023】
  • 【存储】etcd的存储是如何实现的(3)-blotdb
  • 基于MATLAB开发AUTOSAR软件应用层模块-part21.SR interface通信介绍(包括isupdated判断通信)
  • Kotlin新手教程八(泛型)
  • 性能测试知多少?怎样开展性能测试
  • code-breaking之javacon
  • Android 字符串替换,去除空格等操作
  • 因“AI”而“深” 第四届OpenI/O 启智开发者大会高校开源专场25日开启!
  • CATCTF wife原型链污染
  • 浅谈Java线程池中的ThreadPoolExecutor工具类
  • 分析过程:服务器被黑安装Linux RootKit木马
  • 运动型蓝牙耳机推荐哪款、最新运动蓝牙耳机推荐
  • Python爬虫(9)selenium爬虫后数据,存入mongodb实现增删改查