svg/多媒体/地理定位

内联svg

定义

  • svg 指可伸缩矢量图
  • svg 用于定义用于网络的基于矢量的图形
  • svg 使用XML格式定义图形
  • 图像在放大或改变尺寸的情况下其图形质量不会有损失
  • 是万维网联盟的标准

svg与canvas的区别

  • svg是一种使用XML描述的2D图形的语言。canvas通过JavaScript来绘制2D图形。
  • svg是基于XML,这意味着svg,dom中的每个元素都是可用的,您可以为某个元素附加 JavaScript 事件处理器。canvas不加事件处理器。
  • 在 SVG 中,每个被绘制的图形均被视为对象。如果 SVG 对象的属性发生变化,那么浏览器能够自动重现图形。(svg不依赖分辨率,canvas依赖分辨率)
  • Canvas 是逐像素进行渲染的。在 canvas 中,一旦图形被绘制完成,它就不会继续得到浏览器的关注。
    如果其位置发生变化,那么整个场景也需要重新绘制,包括任何或许已被图形覆盖的对象。
  • canvas适合图像密集的游戏开发,svg不适合游戏开发
  • canvas弱的文本渲染能力,svg适合带有大型渲染区域的应用程序

地理定位

  • navigator.geolocation

    • getCurrentPosition(callback,errorcallback,options) //获取当前位置
    • watchPosition(callback,error,options) //开始监控当前位置
    • clearWatch() //停止监控当前位置
  • Position对象 ,成功回调返回的对象

    • coords对象 :
      • latitude 纬度
      • longitude 经度
      • altitude 海拔
      • accuracy 坐标精度
      • heading 行进方向
      • speed 行进速度 米/秒
    • timestamp 时间
  • errorPosition对象 ,错误回调函数的参数

    • code 错误代码
      • 用户未授权
      • 不能确定位置
      • 超时
    • message 错误信息
  • 选项

    • enableHighAccuracy 是否希望得到最佳 布尔值
    • timeout 超时时间
    • maximumAge 是否接受的缓存时间
  • 应用 ,百度地图

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>地图</title>
    <style>
        #mymap{
            width:600px;
            height:600px;
            border:1px solid #ccc;
        }
    </style>
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=B8cfd1501ae7f7c55dc3793ee989c354"></script>
</head>
<body>
    <h1>地图演示</h1>
    <hr>
    <div id="mymap"></div>

    <script>

        //获取地理定位
        navigator.geolocation.getCurrentPosition(
            function(position){
                createMap(position.coords.longitude, position.coords.latitude, 15);
            },
            function(){
                alert("获取地理位置失败");
                createMap(116.404, 39.915, 11)
            },
            {
                timeout:3000
            }
        );
        /**
         * 生成地图
         * @param number longitude 维度
         * @param number latitude 经度
         * @param number zoom
        */
        function createMap(longitude, latitude, zoom){
            var zoom = zoom || 11;  //设置默认值

            // 百度地图API功能
            var map = new BMap.Map("mymap");    // 创建Map实例

            map.centerAndZoom(new BMap.Point(longitude, latitude), zoom);  // 初始化地图,设置中心点坐标和地图级别

            map.addControl(new BMap.MapTypeControl());   //添加地图类型控件
            //map.setCurrentCity("北京");          // 设置地图显示的城市 此项是必须设置的
            map.enableScrollWheelZoom(true);     //开启鼠标滚轮缩放
        }
    </script>
</body>
</html>

多媒体

  • 多媒体元素标签
    • <audio > 标签定义声音
    • 属性
      • autoplay 如果出现该属性,则音频在就绪后马上播放。
      • controls 如果出现该属性,则向用户显示控件,比如播放按钮。
      • loop 如果出现该属性,则每当音频结束时重新开始播放。
      • muted 规定视频输出应该被静音。
      • preload 如果出现该属性,则音频在页面加载时进行加载,并预备播放。
        如果使用 "autoplay",则忽略该属性。
      • url 要播放的音频的 URL。
    • <vidio>标签定义视频
    • 属性
      • autoplay 如果出现该属性,则音频在就绪后马上播放。
      • controls 如果出现该属性,则向用户显示控件,比如播放按钮。
      • loop 如果出现该属性,则每当音频结束时重新开始播放。
      • muted 规定视频输出应该被静音。
      • preload 如果出现该属性,则音频在页面加载时进行加载,并预备播放。
        如果使用 "autoplay",则忽略该属性。
      • url 要播放的音频的 URL。
      • width height 设置视频播放器的宽高 。
      • poster URL 规定视频下载时显示的图像,或者在用户点击播放按钮前显示的图像。
    • <source> 标签为媒介元素(比如 <video> 和 <audio>)定义媒介资源。
      <source> 标签允许您规定可替换的视频/音频文件供浏览器根据它对媒体类型或者编解码器的支持进行选择。
    • <track> 标签为诸如 video 元素之类的媒介规定外部文本轨道。
      用于规定字幕文件或其他包含文本的文件,当媒介播放时,这些文件是可见的。
    • 事件
      • onbort 在退出时运行的脚本
      • onplaying 当媒介已经开始播放时运行的脚本
      • onpause 当媒介被用户暂停或程序暂停时运行的脚本
      • onended 当媒介已经到达结尾时运行的脚本(可发送类似“感谢观看”之类的消息)。
    • 拖放
      • ondrag 该事件在元素正在拖拽时触发,绑定给被拖动的元素
      • ondragstart 开始拖拽元素时触发,绑定给被拖动的元素
      • ondragenter 拖拽元素进入放置目标时触发
      • ondragover 拖拽元素在放置目标上时触发,绑定给目标元素,需组织默认事件 e.preventDefault()
      • ondragleave 拖拽元素离开放置目标时触发
      • ondragend 完成元素的拖动时触发,绑定给被拖动的元素
      • ondrop 在拖动元素放置在目标区域时触发
    • 相关属性
      • draggable 设置元素可拖放true/false
        *DragEvent
      • dataTransfer :setData(),getData()
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容