superMap简单地图

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body {
            margin: 0;
            overflow: hidden;
            background: #fff;
            width: 100%;
            height: 100%;
            position: absolute;
            top: 0;
        }

        #map {
            margin: 0 auto;
            width: 100%;
            height: 100%;
        }

        #btn_box {
            position: absolute;
            left: 100px;
            top: 10px;
            text-align: center;
            z-index: 999999
        }
    </style>
</head>

<body>
    <div id="map">

    </div>
</body>
<script type="text/javascript" src="https://iclient.supermap.io/web/libs/iclient8c/libs/SuperMap.Include.js"></script>
<script type="text/javascript" src="https://mapv.baidu.com/build/mapv.js"></script>
<script type="text/javascript" src="https://iclient.supermap.io/dist/classic/iclient-classic.js"></script>
<script type="text/javascript">
    //              undefiend           true            false
    var host = window.isLocal ? window.server : "https://iserver.supermap.io"
    // 挂载地图
    var map,

        baseLayer,

        mapvLayer,
        // 路径
        url = host + "/iserver/services/map-china400/rest/maps/China_4326"
    init()
    function init() {
        // 检测是否存在绘图环境
        if (!document.createElement('canvas').getContext) {
            widgets.alert.showAlert(resources.msg_supportCanvas, false);
            return;
        }
        map = new SuperMap.Map("map", {
            // 添加控件  每一个显示控件都会以div的形式渲染在DOM中
            controls: [
                // 归因属性
                new SuperMap.Control.Attribution(),
                // 比例尺控制。默认情况下,它绘制在地图的左下角。
                new SuperMap.Control.ScaleLine(),
                // 缩放控件
                new SuperMap.Control.Zoom(),
                new SuperMap.Control.Navigation({
                    dragPanOptions: {
                        enableKinetic: true
                    }
                })
            ]
        })
        baseLayer = new SuperMap.Layer.TiledDynamicRESTLayer(
            "China",
            url,
            {
                transparent: true,
                cacheEnabled: true
            },
            {
                maxResolution: 'auto'
            }
        )
        // 图层渲染到页面
        baseLayer.events.on({
            layerInitialized: addLayer
        })
    }
    function addLayer() {
        // 在地图中添加多个指定层  
        map.addLayers([baseLayer])
        // 设置地图中心  new SuperMap.LonLat这个类用来表示经度和纬度对。   2表示缩放级别
        map.setCenter(new SuperMap.LonLat(116.4, 39.9), 2)
        createMapVLayer()
    }
    function createMapVLayer() {
        var randomCOunt = 1000
        var data = []
        var citys = [
            '北京',
            '天津',
            '上海',
            '重庆',
            '石家庄',
            '太原',
            '呼和浩特',
            '哈尔滨',
            '长春',
            '沈阳',
            '济南',
            '南京',
            '合肥',
            '杭州',
            '南昌',
            '福州',
            '郑州',
            '武汉',
            '长沙',
            '广州',
            '南宁',
            '西安',
            '银川',
            '兰州',
            '西宁',
            '乌鲁木齐',
            '成都',
            '贵阳',
            '昆明',
            '拉萨',
            '海口'
        ]
        // 循环1000遍随机数据出来
        while (randomCOunt--) {
            var cityCenter = mapv.utilCityCenter.getCenterByCityName(
                citys[parseInt(Math.random() * citys.length)]
            );
            data.push({
                geometry: {
                    type: "Point",
                    coordinates: [
                        cityCenter.lng - 2 + Math.random() * 4,
                        cityCenter.lat - 2 + Math.random() * 4
                    ]
                },
                count: 30 * Math.random()
            })
        }
        // 获取数据
        var dataSet = new mapv.DataSet(data)
        // 样式
        var options = {
            fillStyle: 'rgba(55, 50, 250, 0.8)',
            // 方块颜色
            shadowColor: 'rgba(250, 250, 250, 1)',
            // 边框
            shadowBlur: 20,
            max: 100,
            // 方块大小
            size: 50,
            unit: 'px',
            // 字体颜色 字体是否显示
            label: {
                show: true,
                fillStyle: 'white'
            },
            // 方块对比度
            globalAlpha: 0.5,
            // ???
            gradient: {
                0.25: 'rgb(0,0,255)',
                0.55: 'rgb(0,255,0)',
                0.85: 'yellow',
                1.0: 'rgb(255,0,0)'
            },
            draw: 'honeycomb'
        }
        // 把数据添加到一个对象上 然后添加单个图层到地图上
        mapvLayer = new SuperMap.Layer.MapVLayer('mapv', {
            // 数据源
            dataSet: dataSet,
            // 数据样式
            options: options
        });
        map.addLayer(mapvLayer);
    }


</script>

</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
(function(a){a.N={VERSION:"4.1.0",ROOT_URL:a.L_ROOT_URL||function(){var a=document.getElementsByTagName("script"),b=/\/?newmap[\-\._]?([\w\-\._]*)\.js\??/,c,d,e,f;for(c=0,d=a.length;c<d;c++){e=a[c].src,f=e.match(b);if(f)return f[1]==="include"?"../../dist/":e.replace(b,"")+"/"}return""}(),noConflict:function(){return a.N=this._original,this},_original:a.N}})(this),NUtil={extend:function(a){var b=Array.prototype.slice.call(arguments,1);for(var c=0,d=b.length,e;c2?Array.prototype.slice.call(arguments,2):null;return function(){return a.apply(b,c||arguments)}},tryFuncs:function(){var a=null;for(var b=0,c=arguments.length;b<c;b++){var d=arguments[b];try{a=d();break}catch(e){}}return a},getParameterString:function(a){var b=[];for(var c in a){var d=a[c];if(d!=null&&typeof d!="function"){var e;if(typeof d=="object"&&d.constructor==Array){var f=[],g;for(var h=0,i=d.length;h<i;h++)g=d[h],f.push(encodeURIComponent(g===null||g===undefined?"":g));e=f.join(",")}else e=encodeURIComponent(d);b.push(encodeURIComponent(c)+"="+e)}}return b.join("&")},containsStr:function(a,b){return a.indexOf(b)!=-1},getParameters:function(a){a=a===null||a===undefined?window.location.href:a;var b="";if(NUtil.containsStr(a,"?")){var c=a.indexOf("?")+1,d=NUtil.containsStr(a,"#")?a.indexOf("#"):a.length;b=a.substring(c,d)}var e={},f=b.split(/[&;]/);for(var g=0,h=f.length;g<h;++g){var i=f[g].split("=");if(i[0]){var j=i[0];try{j=decodeURIComponent(j)}catch(k){j=unescape(j)}var l=(i[1]||"").replace(/\+/g," ");try{l=decodeURIComponent(l)}catch(k){l=unescape(l)}l=l.split(","),l.length==1&&(l=l[0]),e[j]=l}}return e},urlAppend:function(a,b){var c=a;if(b){var d=(a+" ").split(/[?&]/);c+=d.pop()===" "?b:d.length?"&"+b:"?"+b}return c},upperCaseObject:function(a){var b={};for(var c in a)b[c.toUpperCase()]=a[c];return b},createUrlObject:function(a,b){b=b||{};if(!/^\w+:\/\//.test(a)){var c=window.location,d=c.port?":"+c.port:"",e=c.protocol+"//"+c.host.split(":").shift()+d;if(a.indexOf("/")===0)a=e+a;else{var f=c.pathname.split("/");f.pop(),a=e+f.join("/")+"/"+a}}b.ignoreCase&&(a=a.toLowerCase());var g=document.createElement("a");g.href=a;var h={};h.host=g.host.split(":").shift(),h.protocol=g.protocol,b.ignorePort80?h.port=g.port=="80"||g.port=="0"?"":g.port:h.port=g.port==""||g.port=="0"?"80":g.port,h.hash=b.ignoreHash||g.hash==="#"?"":g.hash;var i=g.search;if(!i){var j=a.indexOf("?");i=j!=-1?a.substr(j):""}return h.args=NUtil.getParameters(i),h.pathname=g.pathname.charAt(0)=="/"?g.pathname:"/"+g.pathname,h},stamp:function(){var a=0,b="_newmap_id";return function(c){return c[b]=c[b]||"_newmap_id_"+ ++a,c[b]}}(),requestAnimFrame:function(){function a(a){window.setTimeout(a,1e3/60)}var b=window.requestAnimationFrame||

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值