Ei kuvausta
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

map_m.htm 7.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. <!doctype html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8" />
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
  6. <link rel="stylesheet" href="__PUBLIC__/plugins/layui/css/layui.css?v={$version}">
  7. <title>地图标注</title>
  8. <style>
  9. #map{width:100%;height:800px;}
  10. .layui-form-item{position:absolute;top:10px;z-index: 999999;}
  11. </style>
  12. </head>
  13. <body>
  14. <div class="layui-form-item">
  15. <div class="layui-inline">
  16. <label class="layui-form-label"></label>
  17. <div class="layui-input-inline" style="width: 220px;">
  18. <input name="keyword" id="keyword" type="text" placeholder="输入地址搜索,可以移动标注点" title="输入地址搜索,可以移动标注点更改位置确定保存" class="layui-input" autocomplete="off" size="25" value="{$field.mapConf.keyword}" />
  19. </div>
  20. <input type="hidden" id="alladdress" value="">
  21. <button class="layui-btn layui-btn-normal" id="search">搜索</button>
  22. <button class="layui-btn layui-btn-danger" id="sure">确定</button>
  23. <form class="form-horizontal" id="post_form" onsubmit="return check_submit();">
  24. <input type="hidden" name="location" id="location" value="{$field.mapConf.lng},{$field.mapConf.lat}">
  25. <input type="hidden" name="zoom" id="zoom" value="{$field.mapConf.zoom|default='13'}">
  26. <input type="hidden" name="id" value="{$field.id|default=''}">
  27. <input type="hidden" name="type" value="{$field.type|default=''}">
  28. <input type="hidden" name="page" value="{$field.page|default=''}">
  29. <input type="hidden" name="v" value="{$v|default='pc'}">
  30. <input type="hidden" name="lang" value="{$field.lang|default='cn'}">
  31. <input type="hidden" name="idcode" value="{$field.idcode|default=''}">
  32. <input type="hidden" name="iframe" value="1">
  33. </form>
  34. </div>
  35. </div>
  36. <div id="map">
  37. </div>
  38. <script src="__PUBLIC__/plugins/layui/layui.js?v={$version}"></script>
  39. <script type="text/javascript" src="//api.map.baidu.com/api?v=2.0&ak={$field.mapConf.ak}"></script>
  40. <script type="text/javascript">
  41. // 百度地图API功能
  42. var lng = "{$field.mapConf.lng}",lat = "{$field.mapConf.lat}",keyword = "{$field.mapConf.keyword}";
  43. var map = new BMap.Map("map",{enableMapClick:false});
  44. // 创建地址解析器实例
  45. var myGeo = new BMap.Geocoder();
  46. if(lng*1 && lat*1)
  47. {
  48. var point = new BMap.Point(lng,lat);
  49. map.centerAndZoom(point, 15);
  50. var marker = new BMap.Marker(point);// 创建标注
  51. map.addOverlay(marker); // 将标注添加到地图中
  52. marker.enableDragging(); // 可拖拽
  53. marker.addEventListener('dragend',getMarkerPoint);
  54. getMarkerPoint(point);
  55. }else{
  56. //new BMap.Point(110.211023,20.007536);
  57. // map.centerAndZoom(keyword,14);
  58. // 将地址解析结果显示在地图上,并调整地图视野
  59. myGeo.getPoint(keyword, function(point){
  60. if (point) {
  61. map.centerAndZoom(point, 15);
  62. var marker = new BMap.Marker(point);
  63. map.addOverlay(marker);
  64. marker.enableDragging(); // 可拖拽
  65. marker.addEventListener('dragend',getMarkerPoint);
  66. getMarkerPoint(point);
  67. }
  68. }, "海口市");
  69. }
  70. map.addControl(new BMap.NavigationControl());
  71. map.enableScrollWheelZoom(true);
  72. map.addEventListener("zoomend", function(e){
  73. var zoom = map.getZoom();
  74. document.getElementById('zoom').value = zoom;
  75. });
  76. window.onload = function(){
  77. var h = document.documentElement.clientHeight - 20;
  78. document.getElementById('map').style.height = h+'px';
  79. };
  80. function getMarkerPoint(e)
  81. {
  82. //通过点击百度地图,可以获取到对应的point, 由point的lng、lat属性就可以获取对应的经度纬度
  83. var pot = '';
  84. if (!e.point) {
  85. pot = e;
  86. } else {
  87. pot = e.point;
  88. }
  89. myGeo.getLocation(pot, function(rs){
  90. //addressComponents对象可以获取到详细的地址信息
  91. var addComp = rs.addressComponents;
  92. var alladdress = addComp.province + addComp.city + addComp.district + addComp.street + addComp.streetNumber;
  93. document.getElementById("alladdress").value = alladdress; //详细地址
  94. document.getElementById("location").value = pot.lng + ',' + pot.lat; // 经度 纬度
  95. });
  96. }
  97. </script>
  98. <script>
  99. layui.use(['layer','jquery'], function(){
  100. var $ = layui.jquery, layer = layui.layer; //独立版的layer无需执行这一句
  101. $(document).keydown(function(event){
  102. if(event.keyCode ==13){
  103. $('#search').trigger("click");
  104. }
  105. });
  106. $("#search").on('click',function(){
  107. var keyword = $("#keyword").val();
  108. var url = "{:url('api/Uiset/mapGetLocationByAddress')}";
  109. var param = {
  110. address : keyword,
  111. _ajax:1,
  112. };
  113. $.get(url,param,function(res){
  114. if(res.code == 1)
  115. {
  116. map.clearOverlays();
  117. var point = new BMap.Point(res.data.lng,res.data.lat);
  118. map.centerAndZoom(point, 15);
  119. var marker = new BMap.Marker(point);// 创建标注
  120. map.addOverlay(marker);
  121. marker.enableDragging();
  122. marker.addEventListener('dragend',getMarkerPoint);
  123. getMarkerPoint(point);
  124. }
  125. });
  126. });
  127. var parentObj = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引
  128. $("#sure").on('click',function(){
  129. if ($('input[name=id]').val() == '' || $('input[name=id]').val() == undefined || $('input[name=type]').val() == '' || $('input[name=page]').val() == '') {
  130. parent.showErrorMsg('缺少系统参数:id、type、page,尝试请求技术支持!');
  131. return false;
  132. }
  133. parent.eyou_layer_loading('正在处理');
  134. var url = "{:url('api/Uiset/submit', ['_ajax'=>1])}";
  135. $.ajax({
  136. url: url,
  137. type: 'POST',
  138. dataType: 'JSON',
  139. data: $('#post_form').serialize(),
  140. success: function(res){
  141. parent.layer.closeAll();
  142. if (res.code == 1) {
  143. $('#workspace', window.parent.document).attr('src', $('#workspace', window.parent.document).attr('src'));
  144. parent.layer.msg(res.msg, {icon: 1, shade: 0.3, time: 1000});
  145. } else {
  146. parent.eyou_showErrorAlert(res.msg);
  147. }
  148. },
  149. error: function(e){
  150. parent.layer.closeAll();
  151. parent.eyou_showErrorAlert(e.responseText);
  152. }
  153. });
  154. });
  155. });
  156. </script>
  157. </body>
  158. </html>