在好例子网,分享、交流、成长!
您当前所在位置:首页Java 开发实例Android平台开发 → phonegap 指南针实例源码下载

phonegap 指南针实例源码下载

Android平台开发

下载此实例
  • 开发语言:Java
  • 实例大小:0.63M
  • 下载次数:17
  • 浏览次数:409
  • 发布时间:2015-01-16
  • 实例类别:Android平台开发
  • 发 布 人:crazycode
  • 文件格式:.zip
  • 所需积分:2
 相关标签: PhoneGap

实例介绍

【实例简介】

【实例截图】

【核心代码】

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>

<title>指南针</title>
<meta http-equiv="Content-Type" content="text/html; charset=GBK" />
<link href="css/css.css" rel="stylesheet" type="text/css" />
	
<script type="text/javascript" charset="utf-8" src="phonegap.js"></script>
<script type="text/javascript" charset="utf-8">

	var b=10,c=100,d=20,t=0,ang=0;drgNum=0;
	var cv, ctx,prevAng = 0,currAng = 0;

	var img = new Image();	
	img.src = "images/znz_04.png";
	
	// watchID是当前 “watchHeading” 的引用
	var watchID = null;
		
	document.addEventListener("backbutton", onBackKeyDown, false);
	// 等待加载PhoneGap
	document.addEventListener("deviceready", onDeviceReady, false);
	//
    function onDeviceReady() {
   		//startWatch();
        // Register the event listener
        document.addEventListener("backbutton", onBackKeyDown, false);
    }
	// 开始监视罗盘
	function startWatch() {
	
		// 每隔3秒钟更新一次罗盘数据
		var options = { frequency: 10 };
	
		watchID = navigator.compass.watchHeading(onSuccess, onError, options);
	}
	
	// 停止监视罗盘
	function stopWatch() {
		if (watchID) {
			navigator.compass.clearWatch(watchID);
			watchID = null;
		}
		var element = document.getElementById('heading');
		element.innerHTML = '停止'   drgNum '°';
	}
	
	// onSuccess: 返回罗盘的当前朝向
	function onSuccess(heading) {
		var fangweiStr = "";
		var element = document.getElementById('heading');
		element.innerHTML = getPositonStr(360-heading) ''   Math.round(heading) '°';
		setRotationFun((360-heading)*Math.PI/180);
		drgNum = heading;
	}
	
	// onError: 获取罗盘朝向失败
	function onError() {
		alert('onError!获取罗盘朝向失败');
		stopWatch();
	}

	function getPositonStr(d){
		var str = "北";
		if(d>=340 && d<20 ){
			str="北";
		}
		if(d<=340 && d>290){
			str="东北";
		}
		if(d<=290 && d>250){
			str="东";
		}
		if(d<=250 && d>200){
			str="东南";
		}
		if(d<=250 && d>200){
			str="东南";
		}
		if(d<=200 && d>160){
			str="南";
		}
		if(d<=160 && d>110){
			str="西南";
		}
		if(d<=110 && d>70){
			str="西";
		}
		if(d<=70 && d>20){
			str="西北";
		}
		return str;
	}

	function setRotationFun(ang){
		  //setRotationFun(ang*Math.PI/180); 
		  cv = document.getElementById("compassImgDiv");
		  ctx = cv.getContext("2d");
		  cv.width = 355;
		  cv.height = 355;
		  ctx.save();
		  ctx.translate(cv.width/2, cv.height/2);
		  ctx.scale(1, 1);
		  ctx.rotate(ang);
		  ctx.drawImage(img, -355/2, -355/2);
		  ctx.restore();
	}
	//格式化数字,保留num位小数
	function formatNum(str,num){
		var s = parseFloat(str);
		if(!num) num=4;
		if(isNaN(s)){
			return;
		}
		s = s.toFixed(num);
		if(s=="" || s<0) s=0;
		return s;
	}
	
    

    // Handle the back button
    //
    function onBackKeyDown() {
    	// 显示确认对话框
		navigator.notification.confirm(
			'是否要退出罗盘程序',  // 显示信息
			onConfirm,              // 按下按钮后触发的回调函数,返回按下按钮的索引
			'退出程序',            // 标题
			'确认,取消'          // 按钮标签
		);
    	
    }
    
	// 处理确认对话框返回的结果
	function onConfirm(button) {
		if(button == 1){
			navigator.app.exitApp();
		}
	}
	
</script>
</head>
<body>
<div class="all">
	<div id="heading" class="top">点击开始</div>
	<div class="middle">
		<canvas id="compassImgDiv" class="dial"></canvas>
	</div>
	<div class="bottom">
		<div class="start"><img src="images/tm.gif" width="198px" height="79" border="0"  onclick="startWatch();"></div>
		<div class="kong"></div>
		<div class="stop"><img src="images/tm.gif" width="198px" height="79" border="0" onclick="stopWatch();"></div>
	</div>

</div>
</body>
</html>

标签: PhoneGap

实例下载地址

phonegap 指南针实例源码下载

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

第 1 楼 安全 发表于: 2019-03-24 09:20 45
你这个指南针显示不准啊是为什么

支持(0) 盖楼(回复)

第 2 楼 安全 发表于: 2019-03-24 09:20 48
你这个指南针显示不准啊是为什么

支持(0) 盖楼(回复)

发表评论

(您的评论需要经过审核才能显示)

查看所有2条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警