我通过在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谷歌地图全景显示相关推荐

  1. iOS 应用内跳转到百度地图、苹果地图、谷歌地图、高德地图等

    最近在做导航,所以把自己找到的资料总结一下! 无论是百度地图.高德地图.谷歌地图还是腾讯地图它们都有自己的SDK,我们只需要在自己的工程中导入SDK并查看相应的官方文档,基本上就可以实现导航.但是这样 ...

  2. uniapp苹果端IOS日期类型显示NAN

    把所有用到的日期类型为YYYY-MM-DD的全部改成用'/'即可解决 new Date(date.replace(/-/g, "/"))

  3. 非官方谷歌地图 iOS 应用遭苹果下架

    北京时间10月9日上午消息,在App Store上线两周后,一款名为ClassicMap的非官方iOS谷歌地图应用已被悄然下架. 该应用由开发者Katsumi Kishikawa开发.由于可以使用谷歌 ...

  4. IOS 地图导航(其中包括苹果地图、百度地图、高德地图、谷歌地图)

    前言:地图导航功能如果是导入第三方包来进行开发会增加App的大小,而通过openUrl来直接打开对应App软件显然是一个性价比较高的做法,因为IPhone手机本身就带有地图功能,所有我们并不用担心会出 ...

  5. iOS 国外地图开发 谷歌地图坐标放到苹果地图上坐标不准确

    首先请允许我发一个牢骚.苹果地图这个坑... 一 .我们要开发一个国外定点展示房屋信息的地图应用.效果图如下: . 二.第一反应用苹果原生地图Mapkit做.我们的坐标点都是从谷歌地图上取出来的. 功 ...

  6. iOS开发那些事-iOS6苹果地图有用开发

    在iOS 6之后,不再使用谷歌地图了,而是使用苹果自己的地图,可是API编程接口没有太大的变化.开发者不须要再学习非常多新东西就能开发地图应用,这是负责任的做法.因此本节介绍的内容也相同适用于iOS5 ...

  7. iOS开发那些事-iOS6苹果地图实用开发

    在iOS 6之后,不再使用谷歌地图了,而是使用苹果自己的地图,但是API编程接口没有太大的变化.开发人员不需要再学习很多新东西就能开发地图应用,这是负责任的做法.因此本节介绍的内容也同样适用于iOS5 ...

  8. iOS 11为苹果地图带来了哪些改进?

    在地图 App 上,苹果公司一直都在追击着谷歌,而 iOS 11 也为苹果地图带来了许多改进,不如现在就让我们一起来汇总看看,截止到目前为止,iOS 11 到底为苹果地图带来了哪些不错的改进. Fly ...

  9. 谷歌地图VS苹果地图:大数据领域竞争

    摘要:iOS 6推出之后,争议最大的是什么?苹果地图.苹果地图成为人们抨击iOS 6的首选,而苹果放弃谷歌地图选择自力更生是迫不得已.苹果和谷歌之间的竞争领域可以用三个字来概括:大数据.谷歌拥有大数据 ...

最新文章

  1. 【转】每天一个linux命令(31): /etc/group文件详解
  2. Linux安装Hive并测试
  3. Winupdatelist
  4. C语言再学习-- readelf、objdump、nm使用详解
  5. java中的复合数据类型是什么_【填空题】类是Java中的一种重要的复合数据类型,是组成Java程序的基本要素。一个类的实现包括两部分:____和_____....
  6. 4个不同小球放入4个不同盒子_初婚老公和二婚老公有什么不同?听听这4个再婚女人的真实想法...
  7. java中compile函数用法_【转】关于java中Pattern.compile函数的相关解释
  8. java http头 字符串转日期_springboot~DTO字符字段与日期字段的转换问题
  9. Elasticsearch 技术分析(七): Elasticsearch 的性能优化
  10. 数据:以太坊2.0合约新增8032 ETH
  11. 机器学习之支持向量机算法(二)
  12. python怎么读取excel-python 读取 Excel
  13. rake matlab,基于MATLABRake接收机仿真及性能分析.doc
  14. Python Built-in Functions内置函数用法总结(全)
  15. 线性回归之最小二乘法公式推导和原理介绍
  16. matlab subs函数
  17. 稻盛和夫《干法》读后感
  18. 网络wifi测试软件app,WIFI检测精灵
  19. python五角星程序显示错误_python画五角星和六角星程序
  20. PostgreSql 配置文件 postgresql.conf 参数设置

热门文章

  1. 微软Live Mail包含重大Bug,可导致用户无法登录,我已经一个多月无法登录自己的邮箱了。...
  2. 睡觉也在爬虫之二(爬一组图片)
  3. 通过MCU实现Altera FPGA在线升级
  4. 零基础学习java(你真的热爱编程吗?)
  5. XP系统下安装SQL Server2000标准版/企业版
  6. 真实生活的记录:我三年的外企生涯(1)出处:天涯虚拟社区
  7. 据采集的三种方式-如何获取数据
  8. 饮用水铁离子超标,各种溶液铁离子超标去除工艺
  9. 转:拥抱挣扎:创造组织的同时,也创造了崭新的自我
  10. 如何设置Windows XP自动登录