按照一定的比例随机生成地图和子地图;
水平填充子地图:
垂直填充子地图:
随机填充子地图:
npm install js-map-generator
import { MainMap } from "js-map-generator";
// render部分
<MainMap
mapData={realData}
callback={(info) => {
this.setState({
selectMapInfo: info,
});
}}
/>;
[
{
"name": "区域1",
"color": "rgb(0,139,139)",
"value": 240, // 占据的格子数量
"children": [
{
"name": "子区域1",
"value": 100
},
{
"name": "子区域2",
"value": 50
},
{
"name": "子区域3",
"value": 30
},
{
"name": "子区域4",
"value": 60
}
]
},
{
"name": "区域2",
"color": "rgb(30,144,255)",
"value": 180,
"direction":3, // 0,1,2,3,4,5,6,7 分包代表上,右上,右,右下,下,左下,左,左上
"children": [
{
"name": "子区域1-1",
"value": 40
},
{
"name": "子区域2-1",
"value": 50
},
{
"name": "子区域3-1",
"value": 30
},
{
"name": "子区域4-1",
"value": 60
}
]
}
]
{
mapData: ItemMapData[]; // 数据源
callback?: (info: MapItemInfoType) => void; // 地图点击事件回调
// 地图相关
mapWidth: number; // 地图宽度
mapHeight: number; // 地图高度
gridSize: number; // 网格宽高,不建议太小
mapColorRandom?: boolean; // 是否随机生成地图颜色
showLine?: boolean; // 是否显示辅助线;暂不支持动态
// 标签相关
showLabel?: boolean; // 是否展示地图标签;暂不支持动态
label?: {
// 标签信息
color: string; // 标签颜色
fontSize: number; // 标签字体
fontWeight: "bold" | number;
fontFamily: string; // 字体
labelDirection:'verticel' | 'horizontal' // 标签渲染方向
};
lifeCycler:{ // 等待事件循环完成之后调用
beforeMounted:() => void; // 开始渲染钱
mounted: (maps:MapItemInfoType[]) => void; // 地图已经渲染完成
}
}
import DetailMap from "js-map-generator";
<DetailMap
{...selectMapInfo}
showLine={true}
showType={"random-fill"}
datas={selectMapInfo.datas || []}
/>;
{
// 数据相关
center: PointType; // 地图中心点
name: string; // 地图名称
id: string; // 地图id
color: string; // 地图颜色
positions: {
// 占用地图的map
[key: string]: boolean;
};
index: number; // 数据层的index
textColor: string;
datas?: ItemMapData[]; // 子地图的数据
// 点击事件
callback:(info)=>void;
// 子地图展示类型
showType: "parent" | "average" | "average-vertical" | "random-fill"; // 分别代表:只展示父地图,横向按比例展示子地图,总线按比例展示子地图,随机占比展示子地图
// 地图相关
mapWidth: number; // 地图宽度
mapHeight: number; // 地图高度
gridSize: number; // 网格宽高
mapColorRandom?: boolean; // 是否随机生成地图颜色
showLine?: boolean; // 是否显示辅助线
// 标签相关
showLabel?: boolean; // 是否展示地图标签
label?: {
// 标签信息
color: string; // 标签颜色
fontSize: number; // 标签字体
fontWeight: "bold" | number;
fontFamily: string; // 字体
labelDirection:'verticel' | 'horizontal' // 标签渲染方向
};
lifeCycler:{ // 等待事件循环完成之后调用
beforeMounted:() => void; // 开始渲染钱
mounted: (maps:MapItemInfoType[]) => void; // 地图已经渲染完成
}
}