ww可以根据DLG图批量生成假三维模型,这对于小区等特征相似的建筑物模型的构建是非常有用的。下面来看如何一步步实现假三维模型的加载:

1、Shp文件的制作

首先在arcmap下数字化几个建筑物,并新建height字段存储建筑物的高度。

2、代码实现

  1. /**
  2. *
  3. * @方法名称: init3DModel ;
  4. * @方法描述: 导入简易三维模型 ;
  5. * @参数 :@param filePath :shp文件路径
  6. * @返回类型: void ;
  7. * @创建人:bluce;
  8. * @创建时间:2015年2月3日 下午6:10:22;
  9. * @throws
  10. */
  11. private void init3DModel(String filePath)
  12. {
  13. Shapefile shapefile = new Shapefile(filePath);
  14. RenderableLayer layer = new RenderableLayer();
  15. layer.setName("简易三维模型");
  16. layer.setPickEnabled(true);
  17. try
  18. {
  19. while (shapefile.hasNext())
  20. {
  21. ShapefileRecord record = shapefile.nextRecord();
  22. layer.addRenderable(makeShape(record));
  23. }
  24. wwPanel.getWorldWindowGLCanvas().getModel().getLayers()
  25. .add(layer);
  26. }
  27. finally
  28. {
  29. shapefile.close();
  30. }
  31. }
  32. /**
  33. *
  34. * @方法名称: makeShape ;
  35. * @方法描述:  根据shp文件每条记录创建模型 ;
  36. * @参数 :@param record
  37. * @参数 :@return
  38. * @返回类型: ExtrudedPolygon ;
  39. * @创建人:bluce;
  40. * @创建时间:2015年2月3日 下午6:11:08;
  41. * @throws
  42. */
  43. private ExtrudedPolygon makeShape(ShapefileRecord record)
  44. {
  45. String IMAGE_PATH = "F:\\data\\wwj\\build123sm.jpg";
  46. Double height = null;
  47. String[] heightKeys = new String[]
  48. { "height", "Height", "HEIGHT" };
  49. for (String key : heightKeys)
  50. {
  51. Object o = record.getAttributes().getValue(key);
  52. if (o != null)
  53. {
  54. height = Double.parseDouble(o.toString());
  55. }
  56. }
  57. // 顶部属性
  58. ShapeAttributes capAttrs = new BasicShapeAttributes();
  59. capAttrs.setOutlineMaterial(Material.GRAY);
  60. capAttrs.setInteriorMaterial(Material.CYAN);
  61. // 边属性
  62. ShapeAttributes sideAttributes = new BasicShapeAttributes();
  63. sideAttributes.setInteriorMaterial(Material.LIGHT_GRAY);
  64. sideAttributes.setOutlineMaterial(Material.DARK_GRAY);
  65. sideAttributes.setImageSource(IMAGE_PATH);
  66. // 创建拉伸多边形
  67. VecBuffer vb = record.getPointBuffer(0);
  68. Polygon pgonAirspace = new Polygon(vb.getLocations()); // 根据点串构建多边形
  69. //纹理
  70. ArrayList<String> textures = new ArrayList<String>();
  71. for (int i = 0; i < pgonAirspace.getLocations().size(); i++)
  72. {
  73. textures.add(IMAGE_PATH);
  74. }
  75. ExtrudedPolygon polygon = new ExtrudedPolygon(
  76. pgonAirspace.getLocations(), height, textures);
  77. polygon.setCapAttributes(capAttrs);
  78. polygon.setSideAttributes(sideAttributes);
  79. polygon.setAltitudeMode(WorldWind.CLAMP_TO_GROUND);
  80. return polygon;
  81. }

效果如下图所示:

3、问题

发现模型加载不了纹理啊,查了几遍不知道问题出在哪里,希望懂的朋友看到留言给指点下啊,不胜感激。
----------------------------------------------2015年7月26日----------------------------------------------
感谢Q_H_Wang提供的解决方案: 加载不上纹理的是因为 pgonAirspace.getLocations().获取的坐标集合第一个元素与最后一个一样造成的,除掉最后一个元素即可加载。所以只需在添加纹理的地方加个减一即可:
  1. ArrayList<String> textures = new ArrayList<String>();
  2. for (int i = 0; i < pgonAirspace.getLocations().size() - 1; i++)
  3. {
  4. textures.add(IMAGE_PATH);
  5. }

World Wind Java开发之十二——加载粗制三维模型(ExtrudedPolygon)(转)的更多相关文章

  1. World Wind Java开发之十五——加载三维模型(转)

    之前的一篇博客是关于加载粗三维模型的,见http://blog.csdn.net/giser_whu/article/details/43452703,这个地方还存在着不能加载纹理的问题,一直没呢解决 ...

  2. World Wind Java开发之十四——添加WMS地图服务资源(转)

    数据是GIS的核心,没有数据一切无从谈起,Internet上有很多在线WMS地图服务资源,我们可以好好利用这些数据资源,比如天地图.必应地图.NASA.OGC数据服务等等. 在我们国家常用的还是天地图 ...

  3. Java开发学习(十二)----基于注解开发依赖注入

    Spring为了使用注解简化开发,并没有提供构造函数注入.setter注入对应的注解,只提供了自动装配的注解实现. 1.环境准备 首先准备环境: 创建一个Maven项目 pom.xml添加Spring ...

  4. World Wind Java开发之十五——载入三维模型

    之前的一篇博客是关于载入粗三维模型的,见http://blog.csdn.net/giser_whu/article/details/43452703,这个地方还存在着不能载入纹理的问题,一直没呢解决 ...

  5. World Wind Java开发之十——AnalyticSurface栅格渲染(转)

    http://blog.csdn.net/giser_whu/article/details/43017881 1.AnalyticSurfaceDemo ArcGIS下对栅格的各种分级渲染效果是非常 ...

  6. Java进阶(三十二) HttpClient使用详解

    Java进阶(三十二) HttpClient使用详解 Http协议的重要性相信不用我多说了,HttpClient相比传统JDK自带的URLConnection,增加了易用性和灵活性(具体区别,日后我们 ...

  7. 201871010106-丁宣元 《面向对象程序设计(java)》第十二周学习总结

    201871010106-丁宣元 <面向对象程序设计(java)>第十二周学习总结 正文开头: 项目 内容 这个作业属于哪个课程 https://home.cnblogs.com/u/nw ...

  8. Java进阶(五十二)利用LOG4J生成服务日志

    Java进阶(五十二)利用LOG4J生成服务日志 前言 由于论文写作需求,需要进行流程挖掘.前提是需要有真实的事件日志数据.真实的事件日志数据可以用来发现.监控和提升业务流程. 为了获得真实的事件日志 ...

  9. 分享:Java 开发精美艺术二维码

    博客地址:https://ainyi.com/58 Java 开发精美艺术二维码 看到网络上各种各样的二维码层出不穷,好像很炫酷的样子,一时兴起,我也要制作这种炫酷二维码效果 例如: 根据以往例子 根 ...

随机推荐

  1. 网络请求返回HTTP状态码(404,400,500)

    HTTP状态码(HTTP Status Code) 一些常见的状态码为: - 服务器成功返回网页 - 请求的网页不存在 - 服务不可用 所有状态解释: 1xx(临时响应) 表示临时响应并需要请求者继续 ...

  2. vue -- 异常处理集合

    1.npm run dev 运行出错,报错如下: > webpack-dev-server --inline --progress --config build/webpack.dev.conf ...

  3. matplotlib.pyplot import报错: ValueError: _getfullpathname: embedded null character in path

    Environment: Windows 10, Anaconda 3.6 matplotlib 2.0 import matplotlib.pyplot 报错: ValueError: _getfu ...

  4. 洛谷P2534 [AHOI2012]铁盘整理

    P2534 [AHOI2012]铁盘整理 题目描述 输入输出格式 输入格式: 共两行.第一行为铁盘个数N(1<=N<=50),第二行为N个不同的正整数,分别为从上到下的铁盘的半径R.(1& ...

  5. Objective-C对象的申请空间与初始化

    对象分配空间与初始化 对象分配空间与初始化 使用Objective-C语言创建一个对象有两个步骤,你必须: 为新对象动态分配内存空间 初始化新分配的内存,并赋初值 不经过如上两步,一个对象就没有完全功 ...

  6. 《SQL 进阶教程》 自连接排序

    子查询所做的,是计算出价格比自己高的记录的条数并将其作为自己的位次 -- 自连接实现排序功能SELECT P1.name,P1.price,(SELECT COUNT(P2.price)FROM Pr ...

  7. pytho虚拟环境

    pip install virtualenv 进入项目目录 virtualenv venv 激活venv source venv/bin/activate  

  8. 原生Ajax实现

    发现一件可怕的事情,前端学不完了,春招要开始了.唉,人生苦短.

  9. 6、python数据类型之元组(dict)

    字典字典的每个元素就是一个键值对,格式如下key:value{key1:value1,key2:value2,......} 1.创建 dict_eg = { "name":&qu ...

  10. 强制更新客户端Silverlight XAP 文件

    在发布小程序更新的时候访问的总是原来的程序,猜想应该是缓存的原因.在网上查找方法 <div id="silverlightControlHost"> <objec ...