在GE的图层中有一个照片图层,在浏览时可以看到各地的一些图片,我们称之为热点信息,如下图所示:

再来看下本文的实现效果:

效果是不是很像呢,其实实现这个很简单,参照examples中的Balloons就可以很容易的实现,这里我自己封装了BalloonUtil类便于复用,代码很简单都加了注释就不再一一展开了,直接附上源代码,有看不明白的地方可以留言交流哈。

  1. /**
  2. * @Copyright 2014-2020 @��˶
  3. **/
  4. package edu.whu.vge.util;
  5. import gov.nasa.worldwind.avlist.AVKey;
  6. import gov.nasa.worldwind.awt.WorldWindowGLCanvas;
  7. import gov.nasa.worldwind.geom.Position;
  8. import gov.nasa.worldwind.layers.RenderableLayer;
  9. import gov.nasa.worldwind.render.AbstractBrowserBalloon;
  10. import gov.nasa.worldwind.render.BalloonAttributes;
  11. import gov.nasa.worldwind.render.BasicBalloonAttributes;
  12. import gov.nasa.worldwind.render.GlobeBrowserBalloon;
  13. import gov.nasa.worldwind.render.PointPlacemark;
  14. import gov.nasa.worldwind.render.Size;
  15. import gov.nasa.worldwind.util.Logging;
  16. import gov.nasa.worldwind.util.WWIO;
  17. import gov.nasa.worldwindx.examples.util.BalloonController;
  18. import gov.nasa.worldwindx.examples.util.HotSpotController;
  19. import java.io.InputStream;
  20. /**
  21. *
  22. * @项目名称:SMartScope
  23. * @类名称:BalloonsUtil
  24. * @类描述:
  25. * @创建人:刘硕
  26. * @创建时间:2015年2月3日 下午4:56:26
  27. * @修改备注:
  28. * @版本:
  29. */
  30. public class BalloonsUtil
  31. {
  32. private double balloonLat; // 气球纬度
  33. private double balloonLon; // 气球经度
  34. private String balloonContentPath; // html文件路径
  35. private String balloonName; // 气球名称
  36. protected HotSpotController hotSpotController;
  37. protected BalloonController balloonController;
  38. /**
  39. *
  40. * 创建一个新的实例 BalloonsUtil.
  41. *
  42. * @param balloonLat
  43. * @param balloonLon
  44. * @param balloonContentPath
  45. * @param balloonName
  46. */
  47. public BalloonsUtil(double balloonLat, double balloonLon,
  48. String balloonContentPath, String balloonName)
  49. {
  50. super();
  51. this.balloonLat = balloonLat;
  52. this.balloonLon = balloonLon;
  53. this.balloonContentPath = balloonContentPath;
  54. this.balloonName = balloonName;
  55. }
  56. /**
  57. * s
  58. *
  59. * @方法名称: makeBrowserBalloon ;
  60. * @方法描述: 生成Balloon标记图层 ;
  61. * @参数 :@param windowGLCanvas
  62. * @参数 :@return
  63. * @返回类型: RenderableLayer ;
  64. * @创建人:刘硕;
  65. * @创建时间:2015年2月3日 下午5:01:03;
  66. * @throws
  67. */
  68. public RenderableLayer makeBrowserBalloon(WorldWindowGLCanvas windowGLCanvas)
  69. {
  70. // ע��balloonController
  71. this.hotSpotController = new HotSpotController(windowGLCanvas);
  72. this.balloonController = new BalloonController(windowGLCanvas);
  73. RenderableLayer layer = new RenderableLayer();
  74. layer.setName(balloonName);
  75. String htmlString = null;
  76. InputStream contentStream = null;
  77. try
  78. {
  79. // 读取html文件内容
  80. contentStream = WWIO.openFileOrResourceStream(balloonContentPath,
  81. null);
  82. htmlString = WWIO.readStreamToString(contentStream, null);
  83. }
  84. catch (Exception e)
  85. {
  86. e.printStackTrace();
  87. }
  88. finally
  89. {
  90. WWIO.closeStream(contentStream, balloonContentPath);
  91. }
  92. if (htmlString == null) htmlString = Logging.getMessage(
  93. "generic.ExceptionAttemptingToReadFile", balloonContentPath);
  94. // 创建一个GlobeBrowserBalloon
  95. Position balloonPosition = Position.fromDegrees(balloonLat, balloonLon);
  96. AbstractBrowserBalloon balloon = new GlobeBrowserBalloon(htmlString,
  97. balloonPosition);
  98. // 设置GlobeBrowserBalloon属性
  99. BalloonAttributes attrs = new BasicBalloonAttributes();
  100. attrs.setSize(new Size(Size.NATIVE_DIMENSION, 0d, null,
  101. Size.NATIVE_DIMENSION, 0d, null));
  102. balloon.setAttributes(attrs);
  103. // 将GlobeBrowserBalloon与PointPlacemark关联起来
  104. PointPlacemark placemark = new PointPlacemark(balloonPosition);
  105. placemark.setLabelText(balloonName);
  106. placemark.setValue(AVKey.BALLOON, balloon);
  107. layer.addRenderable(balloon);
  108. layer.addRenderable(placemark);
  109. return layer;
  110. }
  111. public double getBalloonLat()
  112. {
  113. return balloonLat;
  114. }
  115. public void setBalloonLat(double balloonLat)
  116. {
  117. this.balloonLat = balloonLat;
  118. }
  119. public double getBalloonLon()
  120. {
  121. return balloonLon;
  122. }
  123. public void setBalloonLon(double balloonLon)
  124. {
  125. this.balloonLon = balloonLon;
  126. }
  127. public String getBalloonContentPath()
  128. {
  129. return balloonContentPath;
  130. }
  131. public void setBalloonContentPath(String balloonContentPath)
  132. {
  133. this.balloonContentPath = balloonContentPath;
  134. }
  135. public String getBalloonName()
  136. {
  137. return balloonName;
  138. }
  139. public void setBalloonName(String balloonName)
  140. {
  141. this.balloonName = balloonName;
  142. }
  143. }

调用的时候,只需键入以下代码即可:

  1. String htmlPath = System.getProperty("user.dir")
  2. + "\\src\\edu\\whu\\vge\\data\\whu.html";
  3. BalloonsUtil balloonsUtil = new BalloonsUtil(30.5271,
  4. 114.3604, htmlPath, "我在这里");
  5. wwPanel.getWorldWindowGLCanvas()
  6. .getModel()
  7. .getLayers()
  8. .add(balloonsUtil.makeBrowserBalloon(wwPanel
  9. .getWorldWindowGLCanvas()));

另外,附上whu.html网页的代码以供大家参考。

    1. <html>
    2. <head>
    3. <style type='text/css'>
    4. html, body {
    5. margin: 0 0;
    6. width: 100%;
    7. height: 100%;
    8. overflow: hidden
    9. }
    10. a:link {
    11. color: #0000CD;
    12. text-decoration: underline
    13. }
    14. table {
    15. font-family: verdana, 黑体, sans-serif;
    16. font-size: 12px;
    17. color: #4169E1;
    18. border-width: 1px;
    19. border-color: #a9c6c9;
    20. border-collapse: collapse
    21. }
    22. th {
    23. background-color: #4169E1;
    24. color: #fff
    25. }
    26. tr {
    27. background-color: #d4e3e5
    28. }
    29. td {
    30. border-width: 1px;
    31. border-style: solid;
    32. border-color: #a9c6c9
    33. }
    34. </style>
    35. <title></title>
    36. </head>
    37. <body>
    38. <table border='0'>
    39. <tr>
    40. <th align='center' colspan='2'>武汉大学</th>
    41. </tr>
    42. <tr>
    43. <td rowspan='7'><a href="http://www.whu.edu.cn/index.htm"> <img
    44. border='0' alt='' width='300px' height='225px'
    45. src='http://news.whu.edu.cn/_mediafile/whu_news/2015/02/02/1eq0euop1q.jpg'>
    46. </a></td>
    47. </tr>
    48. </table>
    49. </body>
    50. </html>

World Wind Java开发之十一——加载热点信息(仿Google Earth)(转)的更多相关文章

  1. World Wind Java开发之十三——加载Geoserver发布的WMS服务(转)

    这篇是转载的平常心博客,原地址见:http://www.v5cn.cn/?p=171 1.WMSTiledImageLayer类说明 一个WMSTiledImageLayer类对象只能对应一个WMS发 ...

  2. World Wind Java开发之六——解析shape文件(转)

    http://blog.csdn.net/giser_whu/article/details/41647117 最近一直忙于导师项目的事情了,几天没更新了,昨天和今天研究了下WWJ解析shp文件的源代 ...

  3. [转]World Wind Java开发之四——搭建本地WMS服务器

    在提供地理信息系统客户端时,NASA还为用户提供了开源的WMS Server 服务器应用:World Wind WMS Server.利用这个应用,我们可以架设自己的WMS服务并使用自己的数据(也支持 ...

  4. java在windows下加载dll

    java在类中加载动态链接库文件. 类文件中: static { System.loadLibrary("dll文件"); } dll文件在工程的包路径下.例如:pro/bin/h ...

  5. 混合开发(一)——WebView开发高级技巧之加载网页以及JavaScript,加载进度条

    混合开发(一)--WebView开发高级技巧之加载网页以及JavaScript,加载进度条 现在关于混合开发也越来越多了,很多人喜欢跟随,比如HB,比如RN,其实这东西很早就有这么一个概念了,而且说实 ...

  6. Java类编译、加载、和执行机制

    Java类编译.加载.和执行机制 标签: java 类加载 类编译 类执行 机制 0.前言 个人认为,对于JVM的理解,主要是两大方面内容: Java类的编译.加载和执行. JVM的内存管理和垃圾回收 ...

  7. 【记录】尝试用QEMU模拟ARM开发板去加载并运行Uboot,kernel,rootfs【转】

    转自:https://www.crifan.com/try_use_qemu_emulate_arm_board_to_load_and_run_uboot_kernel_rootfs/ [背景] 手 ...

  8. 微信小程序开发动感十足的加载动画--都在这里!

    代码地址如下:http://www.demodashi.com/demo/14242.html 一.前期准备工作 软件环境:微信开发者工具 官方下载地址:https://mp.weixin.qq.co ...

  9. java——Class、动态加载

    Class和Object混淆了? Object: 任何类都是Object类的子类 Class: 任何类都是Class的实例对象 Class可以说是一种特殊的类,它表示的是类类型,Object仍然是Cl ...

随机推荐

  1. JSONCPP开发环境搭建

    环境设置 项目地址 https://github.com/open-source-parsers/jsoncpp.git 操作系统 64位 Fedora 24 安装jsoncpp $ git clon ...

  2. 洛谷P2380 狗哥采矿

    P2380 狗哥采矿 题目背景 又是一节平静的语文课 狗哥闲来无事,出来了这么一道题 题目描述 一个n*m的矩阵中,每个格子内有两种矿yeyenum和bloggium,并且知道它们在每个格子内的数量是 ...

  3. win10移动热点问题

    1.问题(win10移动热点相关) 具体描述: win10通过网线连接上网,打开移动热点后手机无法连接. 如下图所示,win10打开热,然后进入设置界面设置wlan名称和密码,手机填好密码,连接热点发 ...

  4. linux网络配置详解

    一:相关网络配置的文件 1.网卡名配置相关文件 网卡名命名规则文件: /etc/udev/rules.d/70-persistent-net.rules # PCI device 0x8086:0x1 ...

  5. React中的高阶组件

    高阶组件(HOC, High-Order Component)是React中用于重组组件逻辑的高级技术,是一种编程模式而不是React的api. 直观来讲,高阶组件是以某一组件作为参数返回一个新组件的 ...

  6. thinkphp5实现文章上一篇,下一篇

    写在控制器 //列表是按照根据id降序排列的,所以上一篇 $prv=Db::table('qy_article')->where('at_id','>',$at_id)->where ...

  7. props简单小栗子

    props简单小栗子 可以直接copy查看结果 <!DOCTYPE html> <html lang="en"> <head> <meta ...

  8. Phpstorm Git 操作

    一.前提: 1.下载并安装好 Phpstorm 2.下载并安装好 Git 3.熟悉 Git 相关命令行操作 二.Git pull & commit(add): 下面简单说一下相关操作: Php ...

  9. HDU 5763 Another Meaning dp+字符串hash || DP+KMP

    题意:给定一个句子str,和一个单词sub,这个单词sub可以翻译成两种不同的意思,问这个句子一共能翻译成多少种不能的意思 例如:str:hehehe   sub:hehe 那么,有**he.he** ...

  10. 爱上MVC~业务层刻意抛出异常,全局异常的捕获它并按格式返回

    回到目录 对于业务层的程序的致命错误,我们一直的做法就是直接抛出指定的异常,让程序去终断,这种做法是对的,因为如果一个业务出现了致命的阻塞的问题,就没有必要再向上一层一层的返回了,但这时有个问题,直接 ...