用过mapboxGL的都知道里面有个叫做sprite
的配置,它的主要用途就是地图上渲染图标的,但是大多数情况下我们需要自定义图标的,我们该怎么办呢,莫着急,牛老师有招,本文告诉你如何通过几行简单的java代码实现,用引用到我们的地图中。
生成的json文件如下:
{
"zgyh": {
"visible": "true",
"pixelRatio": 1,
"x": 0,
"width": 32,
"y": 105,
"height": 32
},
"jsyh": {
"visible": "true",
"pixelRatio": 1,
"x": 0,
"width": 32,
"y": 35,
"height": 32
},
"nyyh": {
"visible": "true",
"pixelRatio": 1,
"x": 0,
"width": 32,
"y": 70,
"height": 32
},
"gsyh": {
"visible": "true",
"pixelRatio": 1,
"x": 0,
"width": 32,
"y": 0,
"height": 32
}
}
为了简单测试效果,本文的图标都是从iconfont下载的,同时为了方便,图标大小统一为32px。
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.*;
import com.amazonaws.util.json.JSONObject;
import javax.imageio.ImageIO;
public class MergeImg {
public static File[] getFiles(String path) {
File file = new File(path);
if(file.isDirectory()) {
File[] files = file.listFiles();
return files;
} else {
return null;
}
}
public static void append2File(String file, String content) {
try {
File f = new File(file);
FileWriter fw = new FileWriter(f, true);
PrintWriter pw = new PrintWriter(fw);
pw.println(content);
pw.flush();
fw.flush();
pw.close();
fw.close();
}
catch (IOException e) {
e.printStackTrace();
}
}
public static void main(String[] args) throws Exception {
String path = "D:\\lzugis\\code\\lzugis\\out";
File[] files = getFiles(path + "\\img");
int width = 32;
int height = 35 * files.length;
BufferedImage bufferedImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
Graphics2D graphics2D = (Graphics2D) bufferedImage.getGraphics();
bufferedImage = graphics2D.getDeviceConfiguration().createCompatibleImage(width, height, Transparency.TRANSLUCENT);
graphics2D.dispose();
graphics2D = bufferedImage.createGraphics();
JSONObject jsonObject = new JSONObject();
for (int i = 0; i < files.length; i++) {
File file = files[i];
if(!file.isDirectory()) {
String name = file.getName();
name = name.substring(0, name.lastIndexOf("."));
BufferedImage bi = ImageIO.read(file);
int x = 0;
int y = 35 * i;
int h = bi.getHeight();
int w = bi.getWidth();
graphics2D.drawImage(bi, x, y, w, h, null);
JSONObject js = new JSONObject();
js.put("x", x);
js.put("y", y);
js.put("width", w);
js.put("height", h);
js.put("pixelRatio", 1);
js.put("visible", "true");
jsonObject.put(name, js);
}
}
graphics2D.dispose();
FileOutputStream out = new FileOutputStream(path +"\\merge.png");
ImageIO.write(bufferedImage, "PNG", out);
append2File(path +"\\merge.json", jsonObject.toString());
}
}
地图调用的方式如下:
initMap: function() {
var rootPath = 'http://localhost:63342/learn-demo/mapbox/lib/';
var mapStyle = {
"version": 8,
"name": "Dark",
"sources": {
"XYZTile": {
"type": "raster",
"tiles": ['http://webrd01.is.autonavi.com/appmaptile?x={x}&y={y}&z={z}&lang=zh_cn&size=1&scale=1&style=8'],
"tileSize": 256,
}
},
"sprite": rootPath + "merge",
"layers": [{
"id": "background",
"type": "background",
"paint": {
"background-color": "#111"
}
},
{
"id": "XYZTile",
"type": "raster",
"source": "XYZTile",
"minzoom": 0,
"maxzoom": 22
}
]
};
map = new mapboxgl.Map({
container: 'map',
maxZoom: 18,
minZoom: 0,
zoom: 3,
center: [109.1699, 45.9719],
style: mapStyle,
attributionControl: false
});
map.on('load', function() {
that.addMarkers();
});
},
addMarkers() {
$.get('../data/capital.json', res => {
var geojson = {
'type': 'FeatureCollection',
'features': []
};
for (var i = 0; i < res.length; i++) {
const r = res[i];
geojson.features.push({
type: 'Feature',
geometry: {
type: 'Point',
coordinates: [r.lon, r.lat]
},
properties: r
});
}
that.addGeojson(geojson);
})
},
addGeojson(geojson) {
map.addSource('points', {
type: 'geojson',
data: geojson
});
map.addLayer({
'id': 'points',
'type': 'symbol',
'source': 'points',
'layout': {
'icon-image': 'jsyh',
'icon-size': [
'interpolate',
['linear'],
['zoom'],
4, 0.6,
8, 0.9,
12, 1.2
]
}
});
}