html 苹果 地图,iOS谷歌地图全景显示
我通过在Xcode中使用一个html文件进行展示我发现将很多图片进行循环可以展示出3D全景效果接下来我们深入研究一下如何使用html和JS代码将全景地图效果展示出来
1.我们需要在Xcode中创建一个html文件
//写入这句代码使用来声明html文件的
2.
这三句代码就是html文件的标签元素跟我理解的xml文件标签元素是一样的
注意:
Full 360 degree View这句代码设置html文件在预览器中的标题
3.接下来我们需要深一步了解JS代码
首先我们创建JS标签 然后我们将在标签中写入JS用来展示全景效果图此处注意所有JS标签全部被html标签所包含所有JS代码全部被JS标签包含(包含也就是放到标签里面去)
var ctx = null; // 显示证书全局变量2 d上下文
var frame = 1; // 设置位置信息
var width = 0;//宽度
var height = 0;//高度
var started = false;//判断是否开始
var images = new Array();//设置图片数组
var startedX = -1;
//设置函数体
window.onload = function() {
var canvas = document.getElementById("fullview_canvas");
canvas.width = 440;//宽度/帆;
canvas.height = 691;//高度/帆;
width = canvas.width;//设置宽度帆
height = canvas.height;//设置高度帆
//等到元素loadProgressBar
var bar = document.getElementById('loadProgressBar');
//循环图片数组images
for(var i=1; i<24; i++)
{
bar.value = i;
if(i<10)
{
images[i] = new Image();
images[i].src = "0" + i + ".jpg";
}
else
{
images[i] = new Image();
images[i].src = i + ".jpg";
}
ctx = canvas.getContext("2d");//获得2d证书内容
// 通过鼠标滑动网页进行滚动图片操作(必须在图片开启滚动的情况)
canvas.addEventListener("mousedown", doMouseDown, false);
canvas.addEventListener('mousemove', doMouseMove, false);
canvas.addEventListener('mouseup', doMouseUp, false);
// loaded();
// frame = 1
frame = 1;
images[frame].onload = function() {
redraw();
bar.style.display = 'none';
}
}
function doMouseDown(event) {
var x = event.pageX;
var y = event.pageY;
var canvas = event.target;
var loc = getPointOnCanvas(canvas, x, y);
console.log("mouse down at point( x:" + loc.x + ", y:" + loc.y + ")");
startedX = loc.x;
started = true;
}
function doMouseMove(event) {
var x = event.pageX;
var y = event.pageY;
var canvas = event.target;
var loc = getPointOnCanvas(canvas, x, y);
if (started) {
var count = Math.floor(Math.abs((startedX - loc.x)/30));
var frameIndex = Math.floor((startedX - loc.x)/30);
while(count > 0)
{
console.log("frameIndex = " + frameIndex);
count--;
if(frameIndex > 0)
{
frameIndex--;
frame++;
} else if(frameIndex < 0)
{
frameIndex++;
frame--;
}
else if(frameIndex == 0)
{
break;
}
if(frame >= 24)
{
frame = 1;
}
if(frame <= 0)
{
frame = 23;
}
redraw();
}
}
}
function doMouseUp(event) {
console.log("mouse up now");
if (started) {
doMouseMove(event);
startedX = -1;
started = false;
}
}
function getPointOnCanvas(canvas, x, y) {
var bbox = canvas.getBoundingClientRect();
return { x: x - bbox.left * (canvas.width / bbox.width),
y: y - bbox.top * (canvas.height / bbox.height)
};
}
function loaded() {
setTimeout( update, 1000/8);
}
function redraw()
{
// var imageObj = document.createElement("img");
// var imageObj = new Image();
var imageObj = images[frame];
ctx.clearRect(0, 0, width, height)
ctx.drawImage(imageObj, 0, 0, width, height);
}
function update() {
redraw();
frame++;
if (frame >= 23) frame = 1;
setTimeout( update, 1000/8);
}
//设置标签元素进度条最大值为23
//设置函数标签元素
//设置按钮点击函数体和按钮标题
Auto Play
html 苹果 地图,iOS谷歌地图全景显示相关推荐
- iOS 应用内跳转到百度地图、苹果地图、谷歌地图、高德地图等
最近在做导航,所以把自己找到的资料总结一下! 无论是百度地图.高德地图.谷歌地图还是腾讯地图它们都有自己的SDK,我们只需要在自己的工程中导入SDK并查看相应的官方文档,基本上就可以实现导航.但是这样 ...
- uniapp苹果端IOS日期类型显示NAN
把所有用到的日期类型为YYYY-MM-DD的全部改成用'/'即可解决 new Date(date.replace(/-/g, "/"))
- 非官方谷歌地图 iOS 应用遭苹果下架
北京时间10月9日上午消息,在App Store上线两周后,一款名为ClassicMap的非官方iOS谷歌地图应用已被悄然下架. 该应用由开发者Katsumi Kishikawa开发.由于可以使用谷歌 ...
- IOS 地图导航(其中包括苹果地图、百度地图、高德地图、谷歌地图)
前言:地图导航功能如果是导入第三方包来进行开发会增加App的大小,而通过openUrl来直接打开对应App软件显然是一个性价比较高的做法,因为IPhone手机本身就带有地图功能,所有我们并不用担心会出 ...
- iOS 国外地图开发 谷歌地图坐标放到苹果地图上坐标不准确
首先请允许我发一个牢骚.苹果地图这个坑... 一 .我们要开发一个国外定点展示房屋信息的地图应用.效果图如下: . 二.第一反应用苹果原生地图Mapkit做.我们的坐标点都是从谷歌地图上取出来的. 功 ...
- iOS开发那些事-iOS6苹果地图有用开发
在iOS 6之后,不再使用谷歌地图了,而是使用苹果自己的地图,可是API编程接口没有太大的变化.开发者不须要再学习非常多新东西就能开发地图应用,这是负责任的做法.因此本节介绍的内容也相同适用于iOS5 ...
- iOS开发那些事-iOS6苹果地图实用开发
在iOS 6之后,不再使用谷歌地图了,而是使用苹果自己的地图,但是API编程接口没有太大的变化.开发人员不需要再学习很多新东西就能开发地图应用,这是负责任的做法.因此本节介绍的内容也同样适用于iOS5 ...
- iOS 11为苹果地图带来了哪些改进?
在地图 App 上,苹果公司一直都在追击着谷歌,而 iOS 11 也为苹果地图带来了许多改进,不如现在就让我们一起来汇总看看,截止到目前为止,iOS 11 到底为苹果地图带来了哪些不错的改进. Fly ...
- 谷歌地图VS苹果地图:大数据领域竞争
摘要:iOS 6推出之后,争议最大的是什么?苹果地图.苹果地图成为人们抨击iOS 6的首选,而苹果放弃谷歌地图选择自力更生是迫不得已.苹果和谷歌之间的竞争领域可以用三个字来概括:大数据.谷歌拥有大数据 ...
最新文章
- 【转】每天一个linux命令(31): /etc/group文件详解
- Linux安装Hive并测试
- Winupdatelist
- C语言再学习-- readelf、objdump、nm使用详解
- java中的复合数据类型是什么_【填空题】类是Java中的一种重要的复合数据类型,是组成Java程序的基本要素。一个类的实现包括两部分:____和_____....
- 4个不同小球放入4个不同盒子_初婚老公和二婚老公有什么不同?听听这4个再婚女人的真实想法...
- java中compile函数用法_【转】关于java中Pattern.compile函数的相关解释
- java http头 字符串转日期_springboot~DTO字符字段与日期字段的转换问题
- Elasticsearch 技术分析(七): Elasticsearch 的性能优化
- 数据:以太坊2.0合约新增8032 ETH
- 机器学习之支持向量机算法(二)
- python怎么读取excel-python 读取 Excel
- rake matlab,基于MATLABRake接收机仿真及性能分析.doc
- Python Built-in Functions内置函数用法总结(全)
- 线性回归之最小二乘法公式推导和原理介绍
- matlab subs函数
- 稻盛和夫《干法》读后感
- 网络wifi测试软件app,WIFI检测精灵
- python五角星程序显示错误_python画五角星和六角星程序
- PostgreSql 配置文件 postgresql.conf 参数设置