Browse Source

doc: 更新文档&版本

master
Cmen 3 years ago
parent
commit
a068a572b1
  1. 2
      README.md
  2. 5
      docs/changelog.md
  3. 18
      docs/start.md
  4. 1
      index.html
  5. 2
      package.json
  6. BIN
      public/images/favicon.png
  7. 1
      src/map/MapEditor.ts
  8. 17
      src/store/utils/getGeoJSON.ts
  9. 27
      src/store/utils/getMapOptions.ts

2
README.md

@ -30,7 +30,7 @@
- [x] 创建多边形
- [x] 创建多段线
- [x] 创建圆形
- [ ] 创建标记点
- [x] 创建标记点
- [x] 辅助工具
- [x] 搜索定位工具
- [ ] 选择工具

5
docs/changelog.md

@ -1,5 +1,10 @@
# 更新日志
## 0.2.1
- [特性] 新增标记点工具
- [修复] 修复圆形导出geojson后尺寸不对问题
- [修复] 修复导出geojson在三维城市中使用墙面朝内问题
## 0.2.0(:tada:预览版:tada:)
- [特性] 文件菜单
- [特性] 编辑菜单

18
docs/start.md

@ -38,18 +38,30 @@ Fine-GeoJSON-Editor是一款云端GeoJSON编辑器, 其界面设计参考了诸
### 创建覆盖物
在编辑区域的左上角, 有一横排的按钮集合, 用于创建不同的覆盖物, 如下图.
![创建工具](./public/edit.png)
目前支持创建4种覆盖物, 矩形, 多边形, 多段线和圆形.
目前支持创建4种覆盖物, 矩形, 多边形, 多段线, 圆形和标记点.
:::tip
直接使用鼠标点击对应创建按钮(也可以使用快捷键 `alt + 1|2|3|4`),
直接使用鼠标点击对应创建按钮(也可以使用快捷键 `alt + 1|2|3|4|5`),
点击后按钮变蓝, 表示创建工具被激活. 此时鼠标在地图底图上点击, 即可创建对应类型的覆盖物.
对于形状类覆盖物(前四个), 点击创建工具后按钮变蓝, 表示创建工具被激活.
此时鼠标在地图底图上点击, 即可创建对应类型的覆盖物.
默认创建成功后覆盖物为编辑状态. 可以通过鼠标拖拽操作点对覆盖物进行修改
`空格键` 可以完成创建.
:::
:::tip
创建多边形覆盖物时, 鼠标移动左键单击即可添加关键点, 鼠标右击确认进入调整状态.
调整状态下, 白色的点为路径点, 可以自由拖拽.
单击白色的点, 可以删除它.
边中间的蓝色点, 拖拽后可以生成新的路径点.
:::
### 辅助工具

1
index.html

@ -5,6 +5,7 @@
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Fine-GeoJSONEditor, 好用的在线GeoJSON编辑工具</title>
<link rel="icon" type="image/png" href="">
</head>
<body>
<div id="app"></div>

2
package.json

@ -1,6 +1,6 @@
{
"name": "fine-geojson-editor",
"version": "0.0.1",
"version": "0.2.1",
"scripts": {
"dev": "vite",
"build": "vite build",

BIN
public/images/favicon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

1
src/map/MapEditor.ts

@ -257,7 +257,6 @@ export class MapEditor extends Emitter implements IMapEditor {
const marker = new AMap.Marker({
icon: "/images/marker.png",
position: position as [number, number],
anchor: "bottom-center",
offset: new AMap.Pixel(-13, -30),
});
marker.setMap(this.map);

17
src/store/utils/getGeoJSON.ts

@ -93,6 +93,23 @@ export function getGeoJSON(state: IMapOptions): GeoJSON.FeatureCollection {
addPolygonFeature([path], circle, { center, radius });
});
overlays
.filter((overlay) => overlay.type === OverlayTypes.Point)
.forEach((point) => {
// const { lngLat } = point;
const position = convertPosition(point.lngLat!);
features.push({
type: "Feature",
geometry: {
type: "Point",
coordinates: position,
},
properties: {
name: point.name,
},
});
});
convertFeatures(features);
return {

27
src/store/utils/getMapOptions.ts

@ -72,11 +72,26 @@ export function getMapOptions(geojson: GeoJSON.FeatureCollection) {
updateBounds(coordinates);
};
const addPoint = (feature: GeoJSON.Feature) => {
const { geometry, properties } = feature;
const { name } = properties as any;
const { coordinates } = geometry as GeoJSON.Point;
mapOptions.overlays.push({
id: getUID(),
name,
type: OverlayTypes.Point,
lngLat: convertPosition(coordinates),
});
updateBounds([coordinates]);
};
features.forEach((feature) => {
const { geometry } = feature;
const { type } = geometry;
if (type === "Polygon") {
addPolygon(feature);
} else if (type === "Point") {
addPoint(feature);
} else {
addPolyline(feature);
}
@ -90,9 +105,11 @@ export function getMapOptions(geojson: GeoJSON.FeatureCollection) {
}
function convertPath(path: GeoJSON.Position[]) {
return path.map((pos) => {
let [lng, lat] = pos;
({ lng, lat } = gps84_To_gcj02(lng, lat));
return [lng, lat];
});
return path.map(convertPosition);
}
function convertPosition(position: GeoJSON.Position) {
let [lng, lat] = position;
({ lng, lat } = gps84_To_gcj02(lng, lat));
return [lng, lat];
}

Loading…
Cancel
Save