地图相关

来源:互联网 发布:java数字金字塔代码 编辑:程序博客网 时间:2024/05/28 06:04
/** * author: cjbi * date: 2017/5/25 * mail: cjbi@outlook.com *  mui 公共js封装 *///jQuery自定义插件/** *  mui 折叠/展开 内容 */(function ($) {    //设置参数    var setting;    $.fn.muiCollapse = function (opts) {        //继承的默认参数        setting = $.extend({            //折叠时显示的文字            collapseText: '折叠内容',            //展开时显示的文字            expandText: '展开内容',        }, opts || {});        //展开/收起 药店信息        $(this).on('click', function (e) {            $(this).parent('.mui-collapse').addClass("selected");            var $selected = $('.mui-collapse.selected');            $selected.find('.mui-collapse-model').css({                display: function (index, value) {                    var $collapseText = $selected.find('.mui-collapse-text');                    var $collapseIcon = $selected.find('.mui-collapse-icon').find('.mui-icon');                    //如果是展示的就隐藏,否则就展示                    if (value == "block") {                        $collapseText.text(setting.expandText);                        $collapseIcon.removeClass('mui-icon-arrowup');                        $collapseIcon.addClass('mui-icon-arrowdown');                        return "none";                    } else {                        $collapseText.text(setting.collapseText);                        $collapseIcon.removeClass('mui-icon-arrowdown');                        $collapseIcon.addClass('mui-icon-arrowup');                        return "block";                    }                }            });            $(this).parent('.mui-collapse').removeClass("selected");        });    };})(jQuery);/** * dataurl转换成Blob的方法 created by chengjinbao * @param dataurl * @returns {*} */function dataURLtoBlob(dataurl) {    var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],        bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);    while (n--) {        u8arr[n] = bstr.charCodeAt(n);    }    return new Blob([u8arr], {type: mime});}/** * 百度地图选择地址插件,提供搜索功能 * @param callback 回调函数,返回poi地址结果集 */function initMap(callback) {    $('body').append('<div class="bdPoint"></div>');    BDmap(function (rs) {        callback(rs);    });    /**     * 渲染地图     * @param callback 回调函数     * @author 程金宝     */    function BDmap(callback) {        /* $('body').append('<div class="BaiduPoint"></div>');*/        // 百度地图API功能        var map = new BMap.Map('map', {enableMapClick: false});       // new一个百度地图        map.enableScrollWheelZoom();                                  // 启用滚轮放大缩小        map.enableInertialDragging();        map.enableContinuousZoom();        var geolocation = new BMap.Geolocation(); //使用地理位置定位        geolocation.getCurrentPosition(function (r) {            if (this.getStatus() == BMAP_STATUS_SUCCESS) {                //var mk = new BMap.Marker(r.point);                //map.addOverlay(mk);                map.panTo(r.point);  // panTo()方法将让地图平滑移动至新中心点                map.centerAndZoom(r.point, 18);                                 // 定位中心点,放大倍数            }            else {                console.log('failed' + this.getStatus());            }        }, {enableHighAccuracy: true});        //关于状态码        //BMAP_STATUS_SUCCESS   检索成功。对应数值“0”。        //BMAP_STATUS_CITY_LIST 城市列表。对应数值“1”。        //BMAP_STATUS_UNKNOWN_LOCATION  位置结果未知。对应数值“2”。        //BMAP_STATUS_UNKNOWN_ROUTE 导航结果未知。对应数值“3”。        //BMAP_STATUS_INVALID_KEY   非法密钥。对应数值“4”。        //BMAP_STATUS_INVALID_REQUEST   非法请求。对应数值“5”。        //BMAP_STATUS_PERMISSION_DENIED 没有权限。对应数值“6”。(自 1.1 新增)        //BMAP_STATUS_SERVICE_UNAVAILABLE   服务不可用。对应数值“7”。(自 1.1 新增)        //BMAP_STATUS_TIMEOUT   超时。对应数值“8”。(自 1.1 新增)        // 添加带有定位的导航控件        var navigationControl = new BMap.NavigationControl({            // 靠左上角位置            anchor: BMAP_ANCHOR_TOP_LEFT,            // LARGE类型            type: BMAP_NAVIGATION_CONTROL_LARGE,            // 启用显示定位            enableGeolocation: true        });        map.addControl(navigationControl);        // 添加定位控件        var geolocationControl = new BMap.GeolocationControl();        geolocationControl.addEventListener("locationSuccess", function (e) {            // 定位成功事件            var address = '';            address += e.addressComponent.province;            address += e.addressComponent.city;            address += e.addressComponent.district;            address += e.addressComponent.street;            address += e.addressComponent.streetNumber;            console.log("当前定位地址为:" + address);        });        geolocationControl.addEventListener("locationError", function (e) {            // 定位失败事件            console.log(e.message);        });        map.addControl(geolocationControl);        // 添加地图移动事件       /* map.addEventListener('moveend', function () {            checkPoint(map.getCenter());        });*/        //添加地图移动后事件        map.addEventListener("moving", showCurrentPoi);        function showCurrentPoi() {            $('input').blur();            var center = map.getCenter();            var local = new BMap.LocalSearch(map, {                renderOptions: {selectFirstResult: true},                onSearchComplete: function (results) {                    if (local.getStatus() == BMAP_STATUS_SUCCESS) {                        setMarker(results);                        callback(results);                    }                }            });            var myGeo = new BMap.Geocoder();            myGeo.getLocation(center, function (result) {                if (result) {                    // local.search(result.address);                    local.searchNearby('药店', result.point, 1000);                }            });        }        /*  用户坐标转换为具体位置 --start */        function checkPoint(pt) {            var geoc = new BMap.Geocoder();            var point = new BMap.Point(pt.lng, pt.lat);            geoc.getLocation(pt, function (rs) {                var addComp = rs.addressComponents;                 /!* 返回的数据 *!/                 var address = {                 point: pt,                 province: addComp.province,                 city: addComp.city,                 district: addComp.district,                 street: addComp.street,                 streetNumber: addComp.streetNumber,                 addressMsg: addComp.district + "  " + addComp.street + "  " + addComp.streetNumber                 };                /*                 callback(address);*/            })        }        /*  用户坐标转换为具体位置 --end */        //自动完成        var ac = new BMap.Autocomplete(    //建立一个自动完成的对象            {                "input": "search",                "location": map            });        var myValue;        ac.addEventListener("onconfirm", function (e) {    //鼠标点击下拉列表后的事件            var _value = e.item.value;            myValue = _value.province + _value.city + _value.district + _value.street + _value.business;            /*alert("1:"+_value.province+"2:"+_value.city+"3:"+_value.district+"4:"+_value.street+"5:"+_value.business);*/           /* callback(myValue);*/            setPlace();        });        function setMarker(results) {            //清除地图上所有覆盖物            map.clearOverlays();            var url = '';            var myIcon = new BMap.Icon(url, new BMap.Size(36, 42), {                //图标所用的图片的大小,此功能的作用等同于CSS中的background-size属性。可用于实现高清屏的高清效果                imageSize:new BMap.Size(36, 42),            });            for (var i = 0; i < results.getCurrentNumPois(); i++) {                var point = results.getPoi(i).point;                var title = results.getPoi(i).title;                var marker = new BMap.Marker(point, {icon: myIcon});        // 创建标注                map.addOverlay(marker);                     // 将标注添加到地图中                var label = new BMap.Label(title, { offset: new window.BMap.Size(20, -10) });                label.setStyle({border: "1px solid rgb(223, 223, 223)" });                marker.setLabel(label);                // marker.addEventListener("click", function(e){                //     console.log(e);                //     console.log(this);                // });            }        }        function setPlace() {            function myFun() {                var pp = local.getResults().getPoi(0).point;    //获取第一个智能搜索的结果                //直接返回结果                callback(local.getResults());                // setMarker(local.getResults())  //添加标注                map.centerAndZoom(pp, 18);                setTimeout(function () {                    checkPoint(map.getCenter());                    $('input').blur();                }, 100);            }            var local = new BMap.LocalSearch(map, { //智能搜索                onSearchComplete: myFun            });            local.search(myValue);        }    }}
原创粉丝点击