使用leaflet库加载服务器离线地图瓦片(这边以本地nginx服务器为例)

1,下载nginx并配置nginx配置文件(nginx.conf中配置跨域和本地服务图片地址)

javascript 复制代码
#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       1995;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            #root   html;
            root   D:/gmaps; #瓦片地址
            add_header 'Access-Control-Allow-Origin' '*';
            index  index.html index.htm;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }


    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       8000;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}


    # HTTPS server
    #
    #server {
    #    listen       443 ssl;
    #    server_name  localhost;

    #    ssl_certificate      cert.pem;
    #    ssl_certificate_key  cert.key;

    #    ssl_session_cache    shared:SSL:1m;
    #    ssl_session_timeout  5m;

    #    ssl_ciphers  HIGH:!aNULL:!MD5;
    #    ssl_prefer_server_ciphers  on;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}

}

2,leaflet中使用

html 复制代码
<!DOCTYPE html>
<html>
<head>
  <title>本地显示谷歌地图瓦片</title>
  <meta charset="utf-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">

  <link rel="stylesheet" href="leaflet.css" />
   
  <script src="leaflet.js"></script>

  <link rel="stylesheet" href="L.Control.Zoominfo.css" />
  <script src="L.Control.Zoominfo.js" ></script>
<link rel="stylesheet" href="https://unpkg.com/leaflet/dist/leaflet.css" />
<script src="https://unpkg.com/leaflet/dist/leaflet.js"></script>
  <script src="leaflet-tilelayer-colorizr.js"></script>
<script src="https://unpkg.com/proj4leaflet@1.4.2/lib/proj4js-compressed.js"></script>
<script src="https://unpkg.com/proj4leaflet@1.4.2/lib/proj4leaflet-compressed.js"></script>
<script src="https://unpkg.com/leaflet-google-layer/dist/leaflet-google-layer.js"></script>

  <style>
    body {
      padding: 0;
      margin: 0;
    }

    html, body, #map {
      height: 100%;
    }
#map {


  
}
#mapp{
  webkit-filter: invert(1) saturate(0.4) brightness(1.6)!important;
    -moz-filter: invert(1) saturate(0.4) brightness(1.6)!important;
    filter: invert(1) saturate(1) brightness(0.6)!important; 
     filter: invert(90%) hue-rotate(180deg);
  filter: brightness(0.6)contrast(1.2)grayscale(0.3);
              -webkit-filter: invert(50%) grayscale(0) saturate(0.5) brightness(1.6) opacity(1) hue-rotate(334deg) sepia(10%) !important;
            -ms-filter: invert(1) grayscale(0) saturate(0.5) brightness(1.6) opacity(1) hue-rotate(334deg) sepia(10%) !important;
            -moz-filter: invert(1) grayscale(0) saturate(0.5) brightness(1.6) opacity(1) hue-rotate(334deg) sepia(10%) !important;
            filter: invert(1) grayscale(0) saturate(0.5) brightness(1.6) opacity(1) hue-rotate(334deg) sepia(1%) !important;
}
.leaflet-zoom-animated img {

          } 

  </style>
</head>
<body>
  <div id="map"></div>
  
  <script>
    var map = L.map('map', {
      zoominfoControl: true,
      zoomControl: false,
      zoom: 5, 
      //center: [31.22, 121.48], 
      attributionControl: true 
    }).setView([23.3725, 116.4238], 5);
    //var map = L.map('map').setView([23.1291, 113.2644], 13);
   /*L.tileLayer('gmaps/{z}/{x}/{y}.png', {

      maxZoom: 15,
 
      attribution: 'Map data &copy; GoogleMap,Support by <a href="http://rovertang.com/">RoverTang</a>'
    }).addTo(map);*/

L.tileLayer.colorizr('http://192.168.2.25:1995/{z}/{x}/{y}.png', {

      maxZoom: 6,
      crossOrigin: "Anonymous",
      attribution: 'Map data &copy; GoogleMap,Support by <a href="http://rovertang.com/">RoverTang</a>',
      colorize: function (pixel) {
            // 这个方法用来调整所有的图片上的rgb值,pixel是图片原有的rgb值
           pixel.r += 24;
           pixel.g += 24;
           pixel.b += 24;
           // pixel.a+=0.1;
           return pixel;
       }
    }).addTo(map);

     var marker = L.marker([22.7457, 113.9454]).addTo(map)
    .bindPopup("这是一个标注点")
    .openPopup();
    var marker = L.marker([35.86, 99.66]).addTo(map)
    .bindPopup("这是二个标注点")
    .openPopup();
      var marker = L.marker([23.6673527777777, 104.385552777777]).addTo(map)
    .bindPopup("这是二个标注点")
    .openPopup();
 
  </script>
</body>
</html>
相关推荐
Fcy6488 小时前
Linux下 进程(一)(冯诺依曼体系、操作系统、进程基本概念与基本操作)
linux·运维·服务器·进程
袁袁袁袁满8 小时前
Linux怎么查看最新下载的文件
linux·运维·服务器
代码游侠8 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法
主机哥哥8 小时前
阿里云OpenClaw部署全攻略,五种方案助你快速部署!
服务器·阿里云·负载均衡
Harvey9038 小时前
通过 Helm 部署 Nginx 应用的完整标准化步骤
linux·运维·nginx·k8s
珠海西格电力科技10 小时前
微电网能量平衡理论的实现条件在不同场景下有哪些差异?
运维·服务器·网络·人工智能·云计算·智慧城市
释怀不想释怀10 小时前
Linux环境变量
linux·运维·服务器
zzzsde10 小时前
【Linux】进程(4):进程优先级&&调度队列
linux·运维·服务器
qq_2975746711 小时前
Linux 服务器 Java 开发环境搭建保姆级教程
java·linux·服务器
聆风吟º12 小时前
CANN开源项目实战指南:使用oam-tools构建自动化故障诊断与运维可观测性体系
运维·开源·自动化·cann