实例介绍
【实例简介】
实现功能:在线瓦片地图(Google、百度、高德、天地图)、离线瓦片地图(MBTile数据库、百度瓦片缓存、Arcgis瓦片)、本地瓦片缓存服务(支持4-14级缩放)、地图测距、地图面积测量、矩形选择、圆形选择、自定义点对象标注点、标注点事件、标图绘制(折线、多边型绘制、圆等)、最大化窗口、鹰眼图
【实例截图】
【核心代码】
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//获取浏览器传递参数值
String tile_column = request.getParameter("X");
String tile_row = request.getParameter("Y");
String zoom_level = request.getParameter("L");
String mapname = request.getParameter("T");
if(Integer.parseInt(zoom_level)>18){
zoom_level="18";
}
if(Integer.parseInt(zoom_level)<4){
zoom_level="4";
}
//判断sqlite连接引擎是否存在
try {
Class.forName("org.sqlite.JDBC");
} catch (ClassNotFoundException e) {
// e.printStackTrace();
System.out.println("数据库驱动未找到!");
}
Connection conn;
try {
//conurl:获取mbtiles文件地址
//String conurl = "jdbc:sqlite:i:\\MBTiles" mapname "\\" zoom_level ".mbtiles";
String conurl = "jdbc:sqlite:i:\\MBTiles\\" zoom_level ".mbtiles";
//String conurl = "jdbc:sqlite:f:\\Gis\\" "4-10.mbtiles";
conn = DriverManager.getConnection(conurl, null, null);
// 设置自动提交为false
conn.setAutoCommit(false);
Statement stmt = conn.createStatement();
//判断表是否存在
ResultSet rsTables = conn.getMetaData().getTables(null, null, "tiles", null);
if(!rsTables.next()){
System.out.println("表不存在");
}
// 得到结果集
String sql = "SELECT * FROM tiles WHERE zoom_level = " zoom_level
" AND tile_column = " tile_column
" AND tile_row = " tile_row;
ResultSet rs = stmt.executeQuery(sql);
if(rs.next()) {
byte[] imgByte = (byte[]) rs.getObject("tile_data");
InputStream is = new ByteArrayInputStream(imgByte);
OutputStream os = response.getOutputStream();
try {
int count = 0;
byte[] buffer = new byte[256 * 256];
while ((count = is.read(buffer)) != -1) {
os.write(buffer, 0, count);
}
os.flush();
} catch (IOException e) {
e.printStackTrace();
} finally {
os.close();
is.close();
}
}
else{
System.out.println(sql);
System.out.println("未找到图片!");
}
rs.close();
conn.close();
} catch (SQLException ex) {
System.out.println("SQL异常!");
Logger.getLogger(MBTilesServlet.class.getName()).log(Level.SEVERE, null, ex);
}
}
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论