Bridegroom777
Bridegroom777
  • 发布:2018-05-16 13:15
  • 更新:2018-05-16 13:16
  • 阅读:992

nativeobj.view绘制地图安卓有问题

分类:Native.js

<!DOCTYPE HTML>
<html>

<head>  
	<meta charset="utf-8" />  
	<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />  

	<link href="css/mui.min.css" rel="stylesheet" />  
	<link rel="stylesheet" type="text/css" href="css/common.css" />  
	<link rel="stylesheet" href="css/SakuraLegend.css" />  
	<link rel="stylesheet" href="css/mui.picker.min.css" />  
	<link rel="stylesheet" href="css/mui.poppicker.css" />  

	<title>Hello H5+</title>  

	<style type="text/css">  
		#map {  
			width: 100%;  
			position: fixed;  
			top:90px;  
			bottom: 0px;  
			line-height: 200px;  
			text-align: center;  
			background: #FFFFFF;  
		}  
		  
		.ipos {  
			background: no-repeat center center url();  
			background-size: 50px 44px;  
		}  
		  
		.map_footerdiv {  
			display: block;  
			position: fixed;  
			top: 44px;  
			left: 0;  
			width: 100%;  
			padding: 2.5vw;  
			background-color: #fff;  
			z-index: 8888;  
			padding-bottom: 0;  
			padding-top: 3vw;  
		}  
		.map_footerdiv input{  
			margin: 0;  
		}  
		  
		.map_footerdiv ul {  
			display: -webkit-box;  
			position: relative;  
		}  
		  
		.map_footerdiv ul li {  
			-webkit-box-flex: 1;  
			text-align: center;  
			padding: 2.5vw 0;  
		}  
		  
		.li_mapbottomi {  
			display: inline-block;  
			position: relative;  
			width: 1.4em;  
			height: 1.4em;  
		}  
		  
		.hg_input {  
			color: #2a2a2a;  
			width: 100% !important;  
			display: block;  
			/* margin-bottom: 0 !important; */  
			padding: 0 !important;  
			/* border: none !important; */  
			font-size: .24rem;  
			height: .6rem !important;  
		}  
	</style>  
</head>  

<body>  
	<div class="sl_commonheader">  
		<div class="sl_commonheader_in">  
			<a class=" fl  " id="back" style="width:1rem;text-align:left;position: absolute;left: 0;top: 0;"><i class="sl_commonleft"></i></a>  
			<div class="sl_commonheader_middle">  
				<div class="sl_common_middlediv">  
					<span class="sl_common_middlespan c_ba f18" style="margin-top: 0;">地图选址</span>  
				</div>  
			</div>  
			<div class="sl_com_localred fr c_re f16 " id='saveAddress'>  
				确定  
			</div>  
		</div>  
	</div>  
	<div style="height:4em"></div>  
	<div id="map">地图加载中...</div>  
	<div class="map_footerdiv">  
		<input type="text" name="" id="detail_address" class="hg_input" placeholder="请输入详细地址" />  
	</div>  

</body>  
<!--<script type="text/javascript" src="../js/immersed.js" ></script>-->  
<script src="js/mui.min.js"></script>  
<script src="js/rem.js"></script>  
<script src="js/app.js"></script>  
<script src="js/myPlus.js"></script>  
<script src="js/md5.js"></script>  
<script src="js/function.js"></script>  
<script src="js/jquery-2.1.0.js"></script>  
<script type="text/javascript">  
	(function($$, doc) {  
		var myPlus = Object.create(MyPlus);  
		var address = '';  
		var lon = '';  
		var lat = '';  
		var currentLon = '';  
		var currentLat = ''  
		var old_back;  
		var view  
		var map  
		var return_back;  
		document.getElementById("back").addEventListener('tap', function() {  
			mui.back()  
		})  
		/*通过用户输入详细地址进行搜索*/  
		/*document.getElementById("detail_address").addEventListener('change',function(){  
			console.log(7777)  
		})*/  
		$('.map_footerdiv').on('keyup','#detail_address',function(){  
			if(event.keyCode == 13){  
				console.log('进来了')  
			  
			/*获取用户输入的详细地址*/  
			var address=$('#detail_address').val()  
			/*用户输入地址为空时返回*/  
			if(address == ''){  
				return  
			}  
			/*通过翻译接口将地址翻译成日文*/  
			myPlus.ajax('/api/v1/trans', {  
					data: {  
						q: address,  
						to: 'jp',  
						from:'zh'  
					},  
					success: function(resp) {  
						address=resp[0].dst  
					},  
					fail: function(info) {  
						$.toast(info);  
					}  
				})  
			/*截取6个字进行检索*/  
			var search_address=address.substring(0,6)  
			mui.ajax('http://nominatim.openstreetmap.org/search', {  
						data: {  
							q:search_address,  
							format:'json'   
						},  
						type: 'get',  
						dataType: 'json',  
						success:function(data){  
							console.log(4444)  
							//服务器返回响应,根据响应结果,分析是否登录成功;  
							var once = data[0];  
							if(once == ' '|| once == undefined || once.lon == undefined){  
								mui.toast('暂时没搜索到您输入的地址,请核对后再搜索哦!')  
								mui.back = function() {  
									old_back();  
								}  
								return false;  
							}  
							currentLon = once.lon   
							currentLat = once.lat  
							lat=currentLat  
							lon=currentLon  
							address=once.display_name  
							//$('#detail_address').val(address)  
							view.close()  

// view.close()
/调用地图方法对地图重新构建/
// location2()
//plus.webview.currentWebview().reload()
location()
},
error:function(xhr,type,errorThrown){
//异常处理;
console.log(type);
}
});
}
})
/构建地图方法/
function location() {
view = view || null
if(view != null){
view.close()
}
view = new plus.nativeObj.View('marker', {
top: '46%',
left: '45%',
height: '5%',
width: '10%'
}, [{
tag: 'img',
id: 'img',
src: 'http://yinghua.buy23.cn/map.png',
position: {
top: '0',
left: '0',
width: '100%',
height: '100%'
}
}]);
view.show();

			map = map || null  
			if(map != null){  
				map.close()  
			}  
			map = new plus.maps.Map("map", {  
				zoomControls: true, // 缩放  
				position: 'absolute', // 地图固定  
				traffic: true  
			});  
			//map.setMapType( plus.maps.MapType.MAPTYPE_NORMAL );  
			/*设置中心点*/  
			var center = new plus.maps.Point(currentLon, currentLat);  
			map.setCenter(center)  
			/*监听地图拖动事件*/  

// map.onstatuschanged = function(event) {
// console.log(JSON.stringify(event));
// var center = event.center;
//
// var centerPoint = new plus.maps.Point(center.longitude, center.latitude);
// plus.maps.Map.reverseGeocode(centerPoint, {},
// function(event) {
// console.log(JSON.stringify(event));
//
// address = event.address;
// lat = event.coord.latitude;
// lon = event.coord.longitude;
// $('#detail_address').val(address)
// },
// function(event) {
// console.log(JSON.stringify(event))
// })
// }
}
/保存地址返回上一级页面/
document.getElementById('saveAddress').addEventListener('tap', function() {
console.log(lat, lon, address)
address=$('#detail_address').val()
if(lat == 0 || lon == 0) {
$$.toast('请拖动地图选址!');
return false;
};
if(address == '') {
$$.toast('地址不存在,请重新拖动地图!');
return false;
}
view.hide();
view.close()

			var wvList = plus.webview.all();  
			$$.fire(wvList[wvList.length - 2], 'location', {  
				'lon': lon,  
				'lat': lat,  
				'address': address,  
			});  
			  
			mui.back();  
			plus.webview.currentWebview().close()  
		})  

		var app = Application.createNew($$, {  
			init: function() {  
				myPlus.initPage(function(self) {  

					$$.init({  
						swipeBack: false  
					})  
					 old_back = mui.back;  
					return_back = mui.back;  
					mui.back = function() {  
						view.close();  
						old_back();  
					}  
					var wv = plus.webview.currentWebview();  
					// 关闭侧滑返回功能  
					wv.setStyle({  
						'popGesture': 'none'  
					});  
					if(self.address != '' && self.address != undefined){  
						var one=self.address.split(',')  
						var search_address=one[0]  
						$('#detail_address').val(self.address)  
						mui.ajax('http://nominatim.openstreetmap.org/search', {  
						data: {  
							q:search_address,  
							format:'json'   
						},  
						type: 'get',  
						dataType: 'json',  
						success:function(data){  
							//服务器返回响应,根据响应结果,分析是否登录成功;  
							var once = data[0];  
							console.log('地址:'+JSON.stringify(data))  
							if(once == ' '|| once == undefined || once.lon == undefined){  
								mui.toast('暂时没搜索到您输入的地址,请核对后再搜索哦!')  
								mui.back = function() {  
									old_back();  
								}  
								return false;  
							}  
							currentLon = once.lon   
							currentLat = once.lat  
							lat=currentLat  
							lon=currentLon  
							address=once.display_name  
							location()  
						},  
						error:function(xhr,type,errorThrown){  
							//异常处理;  
							console.log(type);  
						}  
					});  
					}else{  
						plus.geolocation.getCurrentPosition(function(position){  
	    				currentLon=position.coords.longitude  
						currentLat=position.coords.latitude  
	    				location()  
					},function(e){  
						console.log(JSON.stringify(e))  
			             currentLon=139.767701  
						currentLat=35.667505     
						location()  
			        });  
					}  

					//						var point = new plus.maps.Point(138.793868,36.848619);  
					//						plus.maps.Map.reverseGeocode(point,{coordType: 'bd09ll'},function(event){  
					//							var address = event.address;  // 转换后的地理位置  
					//							var point = event.coord;  // 转换后的坐标信息  
					//							var coordType = event.coordType;	// 转换后的坐标系类型  
					//							console.log(point.longitude, point.latitude)  
					//							currentLon = point.longitude  
					//							currentLat = point.latitude  
					//							console.log(JSON.stringify(event))   
					////							alert("Address:"+address);  
					//						},function(e){  
					//							alert("Failed:"+JSON.stringify(e));  
					//						});  
					//						plus.maps.Map.geocode("名古屋", {city: '日本'},function(event){  
					//							console.log(JSON.stringify(event))  
					//							var address = event.address;  // 转换后的地理位置  
					//							var point = event.coord;  // 转换后的坐标信息  
					//							var coordType = event.coordType;	// 转换后的坐标系类型  
					//							console.log(JSON.stringify(point))  
					//							currentLon=point.longitude;  
					//							currentLat=point.latitude;  
					//							location()  
					////							alert("Coord:"+JSON.stringify(point));  
					//						},function(e){  
					//							alert("Failed:"+JSON.stringify(e));  
					//						});  

				})  
			}  
		});  
		doc.addEventListener('plusready', function() {  

			app.init();  
		})  

		  
	})(mui, document)  
</script>  

</html>

在苹果上输入位置后能够重新绘制地图,但是安卓上,键盘会挤压页面导致地图没有铺满,并且地图也不会重新绘制

2018-05-16 13:15 负责人:无 分享
已邀请:
Bridegroom777

Bridegroom777 (作者) - emmm

<!DOCTYPE HTML>  
<html>  
  
	<head>  
		<meta charset="utf-8" />  
		<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />  
  
		<link href="css/mui.min.css" rel="stylesheet" />  
		<link rel="stylesheet" type="text/css" href="css/common.css" />  
		<link rel="stylesheet" href="css/SakuraLegend.css" />  
		<link rel="stylesheet" href="css/mui.picker.min.css" />  
		<link rel="stylesheet" href="css/mui.poppicker.css" />  
  
		<title>Hello H5+</title>  
  
		<style type="text/css">  
			#map {  
				width: 100%;  
				position: fixed;  
				top:90px;  
				bottom: 0px;  
				line-height: 200px;  
				text-align: center;  
				background: #FFFFFF;  
			}  
			  
			.ipos {  
				background: no-repeat center center url();  
				background-size: 50px 44px;  
			}  
			  
			.map_footerdiv {  
				display: block;  
				position: fixed;  
				top: 44px;  
				left: 0;  
				width: 100%;  
				padding: 2.5vw;  
				background-color: #fff;  
				z-index: 8888;  
				padding-bottom: 0;  
				padding-top: 3vw;  
			}  
			.map_footerdiv input{  
				margin: 0;  
			}  
			  
			.map_footerdiv ul {  
				display: -webkit-box;  
				position: relative;  
			}  
			  
			.map_footerdiv ul li {  
				-webkit-box-flex: 1;  
				text-align: center;  
				padding: 2.5vw 0;  
			}  
			  
			.li_mapbottomi {  
				display: inline-block;  
				position: relative;  
				width: 1.4em;  
				height: 1.4em;  
			}  
			  
			.hg_input {  
				color: #2a2a2a;  
				width: 100% !important;  
				display: block;  
				/* margin-bottom: 0 !important; */  
				padding: 0 !important;  
				/* border: none !important; */  
				font-size: .24rem;  
				height: .6rem !important;  
			}  
		</style>  
	</head>  
  
	<body>  
		<div class="sl_commonheader">  
			<div class="sl_commonheader_in">  
				<a class=" fl  " id="back" style="width:1rem;text-align:left;position: absolute;left: 0;top: 0;"><i class="sl_commonleft"></i></a>  
				<div class="sl_commonheader_middle">  
					<div class="sl_common_middlediv">  
						<span class="sl_common_middlespan c_ba f18" style="margin-top: 0;">地图选址</span>  
					</div>  
				</div>  
				<div class="sl_com_localred fr c_re f16 " id='saveAddress'>  
					确定  
				</div>  
			</div>  
		</div>  
		<div style="height:4em"></div>  
		<div id="map">地图加载中...</div>  
		<div class="map_footerdiv">  
			<input type="text" name="" id="detail_address" class="hg_input" placeholder="请输入详细地址" />  
		</div>  
  
	</body>  
	<!--<script type="text/javascript" src="../js/immersed.js" ></script>-->  
	<script src="js/mui.min.js"></script>  
	<script src="js/rem.js"></script>  
	<script src="js/app.js"></script>  
	<script src="js/myPlus.js"></script>  
	<script src="js/md5.js"></script>  
	<script src="js/function.js"></script>  
	<script src="js/jquery-2.1.0.js"></script>  
	<script type="text/javascript">  
		(function($$, doc) {  
			var myPlus = Object.create(MyPlus);  
			var address = '';  
			var lon = '';  
			var lat = '';  
			var currentLon = '';  
			var currentLat = ''  
			var old_back;  
			var view  
			var map  
			var return_back;  
			document.getElementById("back").addEventListener('tap', function() {  
				mui.back()  
			})  
			/*通过用户输入详细地址进行搜索*/  
			/*document.getElementById("detail_address").addEventListener('change',function(){  
				console.log(7777)  
			})*/  
			$('.map_footerdiv').on('keyup','#detail_address',function(){  
				if(event.keyCode == 13){  
					console.log('进来了')  
				  
				/*获取用户输入的详细地址*/  
				var address=$('#detail_address').val()  
				/*用户输入地址为空时返回*/  
				if(address == ''){  
					return  
				}  
				/*通过翻译接口将地址翻译成日文*/  
				myPlus.ajax('/api/v1/trans', {  
						data: {  
							q: address,  
							to: 'jp',  
							from:'zh'  
						},  
						success: function(resp) {  
							address=resp[0].dst  
						},  
						fail: function(info) {  
							$.toast(info);  
						}  
					})  
				/*截取6个字进行检索*/  
				var search_address=address.substring(0,6)  
				mui.ajax('http://nominatim.openstreetmap.org/search', {  
							data: {  
								q:search_address,  
								format:'json'   
							},  
							type: 'get',  
							dataType: 'json',  
							success:function(data){  
								console.log(4444)  
								//服务器返回响应,根据响应结果,分析是否登录成功;  
								var once = data[0];  
								if(once == ' '|| once == undefined || once.lon == undefined){  
									mui.toast('暂时没搜索到您输入的地址,请核对后再搜索哦!')  
									mui.back = function() {  
										old_back();  
									}  
									return false;  
								}  
								currentLon = once.lon   
								currentLat = once.lat  
								lat=currentLat  
								lon=currentLon  
								address=once.display_name  
								//$('#detail_address').val(address)  
								view.close()  
//								view.close()  
								/*调用地图方法对地图重新构建*/  
//								location2()  
								//plus.webview.currentWebview().reload()  
								location()  
							},  
							error:function(xhr,type,errorThrown){  
								//异常处理;  
								console.log(type);  
							}  
						});  
					}  
			})  
			/*构建地图方法*/  
			function location() {  
				view = view || null  
				if(view != null){  
					view.close()  
				}  
				view = new plus.nativeObj.View('marker', {  
					top: '46%',  
					left: '45%',  
					height: '5%',  
					width: '10%'  
				}, [{  
					tag: 'img',  
					id: 'img',  
					src: 'http://yinghua.buy23.cn/map.png',  
					position: {  
						top: '0',  
						left: '0',  
						width: '100%',  
						height: '100%'  
					}  
				}]);  
				view.show();  
  
				map = map || null  
				if(map != null){  
					map.close()  
				}  
				map = new plus.maps.Map("map", {  
					zoomControls: true, // 缩放  
					position: 'absolute', // 地图固定  
					traffic: true  
				});  
				//map.setMapType( plus.maps.MapType.MAPTYPE_NORMAL );  
				/*设置中心点*/  
				var center = new plus.maps.Point(currentLon, currentLat);  
				map.setCenter(center)  
				/*监听地图拖动事件*/  
//				map.onstatuschanged = function(event) {  
//					console.log(JSON.stringify(event));  
//					var center = event.center;  
//  
//					var centerPoint = new plus.maps.Point(center.longitude, center.latitude);  
//					plus.maps.Map.reverseGeocode(centerPoint, {},  
//						function(event) {  
//							console.log(JSON.stringify(event));  
//  
//							address = event.address;  
//							lat = event.coord.latitude;  
//							lon = event.coord.longitude;  
//							$('#detail_address').val(address)  
//						},  
//						function(event) {  
//							console.log(JSON.stringify(event))  
//						})  
//				}  
			}  
			/*保存地址返回上一级页面*/  
			document.getElementById('saveAddress').addEventListener('tap', function() {  
				console.log(lat, lon, address)  
				address=$('#detail_address').val()  
				if(lat == 0 || lon == 0) {  
					$$.toast('请拖动地图选址!');  
					return false;  
				};  
				if(address == '') {  
					$$.toast('地址不存在,请重新拖动地图!');  
					return false;  
				}  
				view.hide();  
				view.close()  
  
				var wvList = plus.webview.all();  
				$$.fire(wvList[wvList.length - 2], 'location', {  
					'lon': lon,  
					'lat': lat,  
					'address': address,  
				});  
				  
				mui.back();  
				plus.webview.currentWebview().close()  
			})  
  
			var app = Application.createNew($$, {  
				init: function() {  
					myPlus.initPage(function(self) {  
  
						$$.init({  
							swipeBack: false  
						})  
						 old_back = mui.back;  
						return_back = mui.back;  
						mui.back = function() {  
							view.close();  
							old_back();  
						}  
						var wv = plus.webview.currentWebview();  
						// 关闭侧滑返回功能  
						wv.setStyle({  
							'popGesture': 'none'  
						});  
						if(self.address != '' && self.address != undefined){  
							var one=self.address.split(',')  
							var search_address=one[0]  
							$('#detail_address').val(self.address)  
							mui.ajax('http://nominatim.openstreetmap.org/search', {  
							data: {  
								q:search_address,  
								format:'json'   
							},  
							type: 'get',  
							dataType: 'json',  
							success:function(data){  
								//服务器返回响应,根据响应结果,分析是否登录成功;  
								var once = data[0];  
								console.log('地址:'+JSON.stringify(data))  
								if(once == ' '|| once == undefined || once.lon == undefined){  
									mui.toast('暂时没搜索到您输入的地址,请核对后再搜索哦!')  
									mui.back = function() {  
										old_back();  
									}  
									return false;  
								}  
								currentLon = once.lon   
								currentLat = once.lat  
								lat=currentLat  
								lon=currentLon  
								address=once.display_name  
								location()  
							},  
							error:function(xhr,type,errorThrown){  
								//异常处理;  
								console.log(type);  
							}  
						});  
						}else{  
							plus.geolocation.getCurrentPosition(function(position){  
		    				currentLon=position.coords.longitude  
							currentLat=position.coords.latitude  
		    				location()  
						},function(e){  
							console.log(JSON.stringify(e))  
				             currentLon=139.767701  
							currentLat=35.667505     
							location()  
				        });  
						}  
  
						//						var point = new plus.maps.Point(138.793868,36.848619);  
						//						plus.maps.Map.reverseGeocode(point,{coordType: 'bd09ll'},function(event){  
						//							var address = event.address;  // 转换后的地理位置  
						//							var point = event.coord;  // 转换后的坐标信息  
						//							var coordType = event.coordType;	// 转换后的坐标系类型  
						//							console.log(point.longitude, point.latitude)  
						//							currentLon = point.longitude  
						//							currentLat = point.latitude  
						//							console.log(JSON.stringify(event))   
						////							alert("Address:"+address);  
						//						},function(e){  
						//							alert("Failed:"+JSON.stringify(e));  
						//						});  
						//						plus.maps.Map.geocode("名古屋", {city: '日本'},function(event){  
						//							console.log(JSON.stringify(event))  
						//							var address = event.address;  // 转换后的地理位置  
						//							var point = event.coord;  // 转换后的坐标信息  
						//							var coordType = event.coordType;	// 转换后的坐标系类型  
						//							console.log(JSON.stringify(point))  
						//							currentLon=point.longitude;  
						//							currentLat=point.latitude;  
						//							location()  
						////							alert("Coord:"+JSON.stringify(point));  
						//						},function(e){  
						//							alert("Failed:"+JSON.stringify(e));  
						//						});  
  
					})  
				}  
			});  
			doc.addEventListener('plusready', function() {  
  
				app.init();  
			})  
  
			  
		})(mui, document)  
	</script>  
  
</html>  

该问题目前已经被锁定, 无法添加新回复