GEE用特定的方式加载指定的图片和素材

举报
此星光明 发表于 2022/10/04 16:28:31 2022/10/04
【摘要】 ​今天分享一个非常有趣的GEE加载图片的功能,但是值得注意的是,这里的图片都智能来源于特定的网站(https://fonts.google.com/icons)这个网站的主要内容:材料符号是我们最新的图标,在一个单一的字体文件中整合了超过2500个字形,具有广泛的设计变体。符号有三种风格和四种可调整的可变字体风格(填充、重量、等级和光学尺寸)。进入网站后选择我们所需的标签,然后再顶部选择链接...

今天分享一个非常有趣的GEE加载图片的功能,但是值得注意的是,这里的图片都智能来源于特定的网站(https://fonts.google.com/icons

这个网站的主要内容:材料符号是我们最新的图标,在一个单一的字体文件中整合了超过2500个字形,具有广泛的设计变体。符号有三种风格和四种可调整的可变字体风格(填充、重量、等级和光学尺寸)。

进入网站后选择我们所需的标签,然后再顶部选择链接分享的图表,就会跳出来一个链接,我们直接copy link即可:

 ​​​​​

具体的操作流程:

// 你可以包括从https://fonts.google.com 提供的材料图标。
// 1.进入https://fonts.google.com/icons
// 2、找到并选择你喜欢的图标。
// 3.在右下角,右击SVG按钮并复制URL。
// 4.将URL粘贴为imageUrl参数。

同样也可以从https://www.gstatic.com获取图片:

// 你也可以包括从https://www.gstatic.com 提供的图片。这些都是谷歌托管的图片。
//主要用于品牌宣传。这里显示的是地球引擎的标志。你可以用gstatic这个选项做的事情并不多。
// 选项,你能做的并不多。

第三种方式:

// 1.用一些数据URI制作一个JSON文件(使用Python的base64包进行编码)。
// 2.将JSON文件上传到云存储桶中
// 3.在EE中把JSON文件作为blob加载,并处理成字典。
// 4.从字典中获取图像数据URI

代码:

//  __  __    __    ____  ____  ____  ____    __    __        ____   ___  _____  _  _  ___ 
// (  \/  )  /__\  (_  _)( ___)(  _ \(_  _)  /__\  (  )      (_  _) / __)(  _  )( \( )/ __)
//  )    (  /(  )\   )(   )__)  )   / _)(_  /(  )\  )(__      _)(_ ( (__  )(_)(  )  ( \__ \
// (_/\/\_)(__)(__) (__) (____)(_)\_)(____)(__)(__)(____)    (____) \___)(_____)(_)\_)(___/


print(ui.Label({imageUrl: 'https://fonts.gstatic.com/s/i/materialiconsoutlined/rocket_launch/v1/24px.svg'}));
print(ui.Label({imageUrl: 'https://fonts.gstatic.com/s/i/materialiconstwotone/satellite_alt/v1/20px.svg'}));
print(ui.Label({imageUrl: 'https://fonts.gstatic.com/s/i/materialicons/location_on/v15/24px.svg'}));
print(ui.Label({imageUrl: 'https://fonts.gstatic.com/s/i/materialiconsround/park/v10/24px.svg'}));
print(ui.Label({imageUrl: 'https://fonts.gstatic.com/s/i/materialiconsoutlined/pedal_bike/v14/24px.svg'}));



//   ___  ___  ____    __    ____  ____   ___ 
//  / __)/ __)(_  _)  /__\  (_  _)(_  _) / __)
// ( (_-.\__ \  )(   /(  )\   )(   _)(_ ( (__ 
//  \___/(___/ (__) (__)(__) (__) (____) \___)

// 你也可以包括从https://www.gstatic.com 提供的图片。这些都是谷歌托管的图片。
//主要用于品牌宣传。这里显示的是地球引擎的标志。你可以用gstatic这个选项做的事情并不多。
// 选项,你能做的并不多。
print(ui.Label({imageUrl: 'https://www.gstatic.com/images/icons/product/earth_engine-128.png'}));
// Earth Engine logo



//   ___  __    _____  __  __  ____       ___  ____  _____  ____    __     ___  ____ 
//  / __)(  )  (  _  )(  )(  )(  _ \     / __)(_  _)(  _  )(  _ \  /__\   / __)( ___)
// ( (__  )(__  )(_)(  )(__)(  )(_) )    \__ \  )(   )(_)(  )   / /(  )\ ( (_-. )__) 
//  \___)(____)(_____)(______)(____/     (___/ (__) (_____)(_)\_)(__)(__) \___/(____)

// 1.用一些数据URI制作一个JSON文件(使用Python的base64包进行编码)。
// 2.将JSON文件上传到云存储桶中
// 3.在EE中把JSON文件作为blob加载,并处理成字典。
// 4.从字典中获取图像数据URI
var eeDict = ee.Blob('gs://ee-blob-test/blog.json').string().decodeJSON();
eeDict.evaluate(function(eeDict) {
  print(ui.Label({imageUrl: eeDict.img1}));
});
// Banana man


// JSON文件中的URI看起来是这样的(一个加载旋钮) ↓
var spinnerUri = '';

// 找到了一个 GIF 微调器,调整它的大小,然后上传到 https://www.base64-image.de/
// 复制 HTML <img> 的结果数据 URI 并粘贴到代码编辑器中或添加到 JSON 对象,如上所示。您还可以使用 base64 库在 Python 中创建 URI。
print(ui.Label({imageUrl: spinnerUri}));
// Loading spinner
本文所需用到的函数:

ee.Blob(url)

Loads a Blob from a Google Cloud Storage URL.

Arguments:

url (String):

The Blob's Google Cloud Storage URL.

Returns: Blob

ee.Blob(url)
从谷歌云存储的URL中加载一个Blob。

参数:
url (String):
Blob的谷歌云存储URL。

返回。Blob

ui.Label(value, style, targetUrl, imageUrl)
一个文本标签。

参数。
value(字符串,可选)。
要显示的文本。默认为空字符串。

style (Object, optional):
一个允许的CSS样式的对象,其值将被设置为这个小组件。参见style()文档。

targetUrl(字符串,可选)。
要链接的URL。默认为空字符串。

imageUrl(字符串,可选)。
可选的图片地址。如果提供,标签将被渲染成图片,鼠标悬停时将显示数值文本。只允许使用数据:从gstatic.com加载的url和图标。

返回:ui.Label


加载后的结果:

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。