GIS小技巧——一文教会你安装BlenderGIS插件

Blender是一款不错的三维渲染软件,用它来做三维地形图,能够更好地把地形纹理显现出来。不过,原始的Blender是没有地图底图的,要结合三维影像制作三维地形图,需要结合其他的软件,比如ArcGIS Pro,小编之前也曾经介绍过如何结合ArcGIS和Blender开展3D地图绘制,那么是否能够不借助其他的软件,直接在Blender上使用地图呢?今天我们的GIS小技巧来关注这个问题。

一、软件准备

首先,我们需要准备一款Blender软件。Blender是一款免费软件,大家进入Blender官网下载即可,这里推荐最好使用Edge浏览器和谷歌浏览器打开网站哈。如果你进去下载时显示要付费,说明你进入不是官网。这里贴出官网:blender.org - Home of the Blender project - Free and Open 3D Creation Software

软件版本的下载看个人喜好,建议下载3.6以上的版本。如果不想去官网下载,欢迎关注小编的公众号“梧桐GIS”,我们同步了两个版本的Blender软件资源,更新在公众号,按照关键词回复即可免费获取。

二、BlenderGIS插件

解决完了软件问题,接下来,要想在Blender中加载地理底图,多亏一些大佬努力,我们只需要安装一个小插件,即BlenderGIS,就可以实现底图的加载。打开GitCode官网或者是GitHub官网,搜索BlenderGIS插件,将安装包下载下来即可。

还是那句话,如果不想去官网下载,那就欢迎关注一下小编的公众号吧,我们也将安装包的下载链接放在里面了,保证免费,需要的友友下载即可。 

三、插件安装

当第一步和第二步你都准备好了之后,我们就可以开始第三步的安装了。注意!注意!下载的BlenderGIS插件里头的文件不要解压哈。

打开blender软件,从编辑选项卡中选择“偏好设置”。

在打开的窗口中选择“获取扩展”,在最右侧的下角标符号中点击“从磁盘安装”,打开我们下载的BlenderGIS插件安装包所在的磁盘文件夹。这一步不同的版本略有不同,在更低的版本中,在该模块下会直接出现“安装”的小按钮,点击即可。

这里,我们选择文件夹里面的zip压缩文件,点击从磁盘安装按钮。

完成安装后,我们在插件位置搜索BlenderGIS,会出现相关插件,点击勾选,确认启用。取消仅已启用的勾选框,在搜索框输入node,完成勾选。

 一切都完成了之后,我们发现Blender顶部出现了一个新的东西,那就是GIS。让我们点击,选择“Web geodata”,选择“Basemap”,打开我们心心念念的底图。

可是啊,我们发现,它报错了,显示的是没有影像,说明我们并没有正确安装影像的ID链接。也许是你的电脑安全程度比较高,把里面一个很重要的小程序删掉了。这怎么办?

没关系,跟着我继续来。让我们找到C盘下面的Blender文件夹,主要是C盘文件夹哈,不是你的安装路径的文件夹。按照:C:\Users\用户名\AppData\Roaming\Blender Foundation\Blender\4.2\scripts\addons\domlysz-BlenderGIS-7acdaae\core\lib\imageio\resources打开路径。新建一个文件夹,命名为“freeImage”.

回到我们前面下载的BlenderGIS插件安装包。把该文件复制一下,粘贴到我们刚刚在C盘建好的文件夹下面。一定要放回刚刚建好的文件夹哈

关闭文件夹和Blender软件,并再次打开,让我们按照此前的步骤,点击GIS内部的底图,成功加载,让我们将底图换成Esri的(谷歌图源用不了呜呜呜~),点击确定打开。

兄弟们,让我们欢呼啊啊啊,加载完毕了,看看这地形纹理,不错。

好了,BlenderGIS插件加载完毕了,大家快试试做做属于你的三维地形图吧!什么,你不会,没关系,快去小编的B站账号,我们有视频讲解哦。

好啦,今天的分享到这里就结束了,希望对大家有帮助。我们是一群致力于分享GIS优质教程的地理人,走进梧桐GIS,一起洞察地理之美!

 

### 回答1: 以下是一个示例,演示如何在Spring Boot和Freemarker中自定义标签以实现带网页标签的列表循环: 1. 创建自定义标签类 ```java import java.io.IOException; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.stereotype.Component; import freemarker.core.Environment; import freemarker.template.TemplateDirectiveBody; import freemarker.template.TemplateDirectiveModel; import freemarker.template.TemplateException; import freemarker.template.TemplateModel; import freemarker.template.TemplateModelException; @Component public class MyListDirective implements TemplateDirectiveModel { @Override public void execute(Environment env, Map params, TemplateModel[] loopVars, TemplateDirectiveBody body) throws TemplateException, IOException { if (params.isEmpty()) { throw new TemplateModelException("This directive requires parameters."); } HttpServletRequest request = (HttpServletRequest) env.getCustomAttribute("request"); HttpServletResponse response = (HttpServletResponse) env.getCustomAttribute("response"); String tag = params.get("tag").toString(); int count = Integer.parseInt(params.get("count").toString()); StringBuilder sb = new StringBuilder(); for (int i = 0; i < count; i++) { sb.append("<").append(tag).append(">"); if (body != null) { body.render(sb); } sb.append("</").append(tag).append(">"); } response.getWriter().write(sb.toString()); } } ``` 2. 在Freemarker模板中使用自定义标签 ```html <!DOCTYPE html> <html> <head> <title>My Page</title> </head> <body> <@myList tag="li" count="5"> <a href="#">Link</a> </@myList> </body> </html> ``` 在以上示例中,我们创建了一个自定义标签类`MyListDirective`,并使用`@Component`注解将其注册为Spring Bean。 该自定义标签接收两个参数:`tag`和`count`。`tag`指定要使用的网页标签,`count`指定要生成的标签数量。标签体中的内容将被重复生成指定的次数,并且每个标签都将包含相同的内容。 在Freemarker模板中,我们使用`<@myList>`标签来调用自定义标签。我们传递了`tag`和`count`参数,并在标签体中包含了一个链接。这将导致自定义标签生成五个`<li>`标签,每个标签都包含一个链接。 最终生成的HTML将如下所示: ```html <!DOCTYPE html> <html> <head> <title>My Page</title> </head> <body> <li><a href="#">Link</a></li> <li><a href="#">Link</a></li> <li><a href="#">Link</a></li> <li><a href="#">Link</a></li> <li><a href="#">Link</a></li> </body> </html> ``` ### 回答2: 在Spring Boot中使用Freemarker模板引擎,我们可以自定义列表循环标签来优化模板代码的复用性和可读性。下面是一个带网页标签的示例: 首先,我们需要创建一个自定义的列表循环标签。在Spring Boot项目中,可以通过创建一个类来实现自定义标签,例如`CustomLoopDirective`。在该类中,我们需要继承`freemarker.template.TemplateDirectiveModel`接口,并实现其中的`execute`方法。 ```java public class CustomLoopDirective implements TemplateDirectiveModel { @Override public void execute(Environment env, Map params, TemplateModel[] loopVars, TemplateDirectiveBody body) throws TemplateException, IOException { // 解析参数 SimpleNumber indexParam = (SimpleNumber) params.get("index"); // 获取循环次数 int count = indexParam.getAsNumber().intValue(); // 执行循环体 for (int i = 0; i < count; i++) { // 设置循环变量 env.setVariable("index", new SimpleNumber(i)); // 执行循环体 body.render(env.getOut()); } } } ``` 接下来,我们需要在Spring Boot配置文件中注册自定义标签,以便在模板中使用。在`application.properties`文件中添加以下配置: ``` spring.freemarker.settings.sharedVariable.customLoop=com.example.CustomLoopDirective ``` 最后,我们可以在Freemarker模板中使用自定义的列表循环标签,同时配合网页标签的示例代码如下: ```html <#-- 导入自定义标签 --> <#import "/spring.ftl" as spring> <!DOCTYPE html> <html> <head> <title>自定义列表循环标签示例</title> </head> <body> <h1>自定义列表循环标签示例</h1> <ul> <@spring.customLoop index=5> <li>第${index + 1}项</li> </@spring.customLoop> </ul> </body> </html> ``` 在上述示例中,我们导入了`spring.ftl`模板文件,并在`<ul>`标签中使用了自定义的列表循环标签。通过这个例子,我们可以看到循环了5次,并输出了每次循环的索引值。 以上就是一个使用Spring Boot和Freemarker自定义列表循环标签的示例,同时在模板中带有网页标签的代码。这个示例可以帮助我们在Spring Boot项目中更好地利用Freemarker模板引擎来实现页面渲染。 ### 回答3: Spring Boot是一个用于简化Java开发的框架,其中之一的模板引擎是FreeMarker。FreeMarker是一种基于模板输出的开源模板引擎,它支持自定义列表循环标签,可以方便地实现对列表数据的遍历和展示。 下面是一个带网页标签的自定义列表循环标签示例: 首先,在Spring Boot项目中的`resources/templates`目录下创建名为`custom_tags.ftl`的模板文件。在该模板文件中,我们将定义一个自定义的列表循环标签,并使用HTML标签进行展示,如下所示: ```html <#assign customTags = [ {"name": "Tag1", "link": "http://www.tag1.com"}, {"name": "Tag2", "link": "http://www.tag2.com"}, {"name": "Tag3", "link": "http://www.tag3.com"} ]> <#macro customList> <#list customTags as tag> <a href="${tag.link}">${tag.name}</a><br/> </#list> </#macro> ``` 在上面的示例中,我们定义了一个名为`customTags`的变量,其中包含了三个标签的名称和链接。接着,我们使用`<#macro>`标签定义了一个名为`customList`的自定义宏,其中使用`<#list>`标签遍历`customTags`列表,并将每个标签的名称和链接使用`<a>`标签展示出来。 在另一个模板文件中,我们可以引入`custom_tags.ftl`文件,并调用`customList`宏来展示自定义的标签列表。例如,假设我们在`resources/templates/index.ftl`中需要展示标签列表,可以按照以下方式引入和调用: ```html <#include "custom_tags.ftl"> <!DOCTYPE html> <html> <head> <title>Custom Tags Example</title> </head> <body> <h1>Custom Tags Example</h1> <p>Below are the custom tags:</p> <@customList/> </body> </html> ``` 在上面的示例中,我们首先使用`<#include>`标签引入了`custom_tags.ftl`文件。然后,在`<body>`标签中使用`<@customList/>`调用了`customList`宏,从而展示出了自定义的标签列表。 通过以上示例,我们可以看到Spring Boot和FreeMarker结合使用,可以很方便地实现自定义列表循环标签,并且配合HTML标签进行内容展示。这样可以有效地简化开发工作,提高工作效率。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梧桐GIS

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值