UNPKG

cve-connector

Version:
736 lines (580 loc) 29.8 kB
CVE Controllers 插件提供各类 Controller,其中封装了最常使用的 UE 交互指令。 - 每个 Controller 都是一个指令集,包含若干操作指令 - 每个指令都返回一个 Promise,用于异步编程 - 对于不想使用 Promise 的开发者,每个指令最后一个参数均为回调函数 **只执行指令** ```ts import { SystemController } from 'cve-connector' SystemController.restartLevel() ``` **异步编程** ```ts import { SystemController } from 'cve-connector' await SystemController.restartLevel() console.log('Level Restarted!') ``` **Promise** ```ts import { SystemController } from 'cve-connector' SystemController.restartLevel().then((res) => { console.log(res) }) ``` # Actor Controller **Methods** | 方法名 | 参数 | 说明 | | -------- | -------------- | ----------------------------- | | addDecal | Tag, URL, BBox | 创建贴花 | | delete | Tag, Deep | 删除指定 Tag 的 Actor,可递归 | | hide | Tag, Deep | 隐藏指定 Tag 的 Actor,可递归 | | show | Tag, Deep | 显示指定 Tag 的 Actor,可递归 | **Usage** - 创建贴花时,URL 传入图片的 Base64 字符串 - BBox 为平行于坐标轴的最小包围盒坐标,[xMin, yMin, xMax, yMax] ```ts import { ActorController } from 'cve-connector' ActorController.addDecal('Heatmap2D', '', [0, 0, 1, 1]) ActorController.delete('hidden', true) ActorController.hide('hidden', true) ActorController.show('visible', false) ``` # Analysis Controller **Methods** | 方法名 | 参数 | 说明 | | --------------- |-------| ------------------------ | | addMultiView | tag | 多视角分析:添加多视角 | | deleteSightline | index | 通视分析:  删除检视线 | | deleteSkyline | - | 天际线分析: 删除天际线 | | deleteViewshed | index | 可视域分析:  删除可视域 | | drawSightline | - | 通视分析: 绘制检视线 | | drawSkyline | - | 天际线分析: 绘制天际线 | | drawViewshed | - | 可视域分析: 绘制可视域 | | refreshMultiView | - | 多视角分析:刷新多视角 | | removeMultiView | tag | 多视角分析:移除多视角 | | startMultiView | tags | 多视角分析:开始多视角 | | stopMultiView | - | 多视角分析:停止多视角 | **Usage** - 执行空间分析指令之前,必须将 _视角_ 设置为 _编辑器模式_ - 通视分析: 执行 drawSightline() 后单击鼠标左键选取视点,移动光标后单击鼠标右键,绘制检视线 - 天际线分析: 执行 drawSkyline() 后改变视角,自动绘制检天际线 - 可视域分析: 执行 drawViewshed() 后单击鼠标左键选取视点,移动光标后单击鼠标右键结束,绘制可视域 ```ts import { AnalysisController, ViewController, ViewMode } from 'cve-connector' ViewController.changeMode(ViewMode.Editor) const resIA = await AnalysisController.drawSightline() AnalysisController.deleteSightline(resIA.Data) const resVA = await AnalysisController.drawViewshed() AnalysisController.deleteViewshed(resVA.Data) AnalysisController.drawSkyline() AnalysisController.deleteSkyline() ``` # Gis Controller **Methods** | 方法名 | 参数 | 说明 | | --------------------- | ---------------------- | -------------------------------- | | addArcgisLayer | ArcgisLayer | 添加 ArcGIS WMTS 服务 | | addCustomLayer | CustomLayer | 添加 自发布 WMTS 服务 | | addMapboxLayer | MapboxLayer | 添加 Mapbox WMTS 服务 | | addTiandituLayer | TiandituLayer | 添加 天地图  WMTS 服务 | | create3dTiles | Id, Url, Max | 创建 3D Tiles 图层 | | delete3dTiles | Id | 匹配 ID 删除  3D Tiles 图层 | | deleteAll | - | 删除全部 WMTS 图层 | | deleteLayer | Id | 匹配 ID 删除  WMTS 图层 | | deleteLayerGroup | GroupId | 匹配 Group ID 删除一组 WMTS 图层 | | config | GeoReference | 配置  GeoReferencingSystem | | hide3dTiles | Id | 匹配 ID 隐藏  3D Tiles  图层 | | hideAll | - | 隐藏全部 WMTS 图层 | | hideLayer | Id | 匹配 ID 隐藏  WMTS 图层 | | hideLayerGroup | GroupId | 匹配 Group ID 隐藏一组 WMTS 图层 | | hideOsgb | Id | 匹配 ID 隐藏  OSGB 图层 | | loadOsgb | Id,Dir,LodScale,Offset | 加载指定目录下的 OSGB 数据 | | setCesiumTerrainLayer | Ion | 设置地形服务源为 Cesium 在线地形 | | setCustomLayer | CustomLayer | 更改图层参数 | | setHeaders | Id, Headers | 更改图层请求头 | | setLayerIndex | Id, Index | 更改图层的 z-index | | setTerrainLayer | Url | 通过 url 设置地形服务源 | | show3dTiles | Id | 匹配 ID 显示  3D Tiles 图层 | | showAll | - | 显示全部 WMTS 图层 | | showLayer | Id | 匹配 ID 显示  WMTS 图层 | | showLayerGroup | GroupId | 匹配 Group ID 显示一组 WMTS 图层 | | showOsgb | Id | 匹配 ID 显示  OSGB 图层 | | toggleDebug | Id, Visible | 控制图层调试信息显隐 | | unloadOsgb | Id | 匹配 ID 销毁 OSGB 图层 | **补充说明** - _添加图层之前,必须先设置地形_ - 最多能加**15**个图层 - Layer 参数对照: | Property | Description | Custom | ArcGIS | Mapbox | 天地图 | | ------------------------ | :-------------------------- | :----: | :----: | :----: | :----: | | EPSG | EPSG 编号 | ✔ | - | - | - | | Format | 天地图风格的 URL  请求参数 | ✔ | - | - | - | | GroupId | 图层分组 ID | ✔ | ✔ | ✔ | ✔ | | Id | 图层 ID | ✔ | ✔ | ✔ | ✔ | | Index | 图层 z-index | ✔ | ✔ | ✔ | ✔ | | Layer | WMTS  请求参数 | ✔ | - | - | - | | RequestHeaders | 天地图风格的 URL  请求参数 | ✔ | ✔ | ✔ | ✔ | | Subdomains | 子域名集合 | ✔ | - | - | - | | Style | 天地图风格的 URL  请求参数 | ✔ | - | - | - | | TileMatrixSetID | 天地图风格的 URL  请求参数 | ✔ | - | - | - | | TileMatrixSetLabelPrefix | 瓦片矩阵集标签的前缀 | ✔ | - | - | - | | Toekn | 地图服务  Token | - | ✔ | ✔ | - | | Type | 枚举值 | - | ✔ | ✔ | ✔ | | Url | WMTS  服务 url | ✔ | - | - | - | - GeoReference 参数说明: | Property | Description | Type | Default Value | | ------------------------------ | -------------------- | ----------- | ------------- | | GeographicEPSG | 空间坐标系 ESPG 编号 | string | '4326' | | IsBigScene | 是否为大场景 | boolean | false | | IsOriginLocationInProjectedCRS | 是否使用投影坐标系 | boolean | - | | OriginCenter | 中心点坐标 | Coordinates | - | | ProjectedEPSG | 投影坐标系 ESPG 编号 | string | '4549' | - IsBigScene 为 true 时地球曲率会影响计算 - 使用投影坐标系时 OriginCenter 的值为投影坐标 [x, y, z] - 使用空间坐标系时 OriginCenter 的值为投影坐标 [longitude, latitude, altitude] **Usage** ```ts import { GisController } from 'cve-connector' import type { ArcgisLayer, CustomLayer, GeoReference, MapboxLayer, TiandituLayer, } from 'cve-connector' const reference: GeoReference = { IsOriginLocationInProjectedCRS: true, OriginCenter: [116, 39, 100], } GisController.config(reference) const Id = 'uid-A1B2C3D4E5' const GroupId = 'guid-A1B2C3D4E5' const RequestHeaders = {} const arcgisLayer: ArcgisLayer = { GroupId, Id, Index: 0, RequestHeaders, Type: 0, } const mapboxLayer: MapboxLayer = { GroupId, Id, Index: 0, RequestHeaders, Token: '', Type: 0, } const tiandituLayer: TiandituLayer = { GroupId, Id, Index: 0, RequestHeaders, Token: '', Type: 0, } const wmtsLayer: CustomLayer = { EPSG: '3857', Format: '', GroupId, Id, Index: 0, Layer: '', RequestHeaders, Subdomains: [], Style: 'image/jpeg', TileMatrixSetID: '', TileMatrixSetLabelPrefix: '', Url: 'default', } const Url = 'http://fake.ip.address:port/path/name' GisController.addArcgisLayer(arcgisLayer) GisController.addCustomLayer(wmtsLayer) GisController.addMapboxLayer(mapboxLayer) GisController.addTiandituLayer(tiandituLayer) GisController.create3dTiles(Id, Url) GisController.delete3dTiles(Id) GisController.deleteAll() GisController.deleteLayer(Id) GisController.deleteLayerGroup(GroupId) GisController.hide3dTiles(Id) GisController.hideAll() GisController.hideLayer(Id) GisController.hideLayerGroup(GroupId) GisController.hideOsgb(Id) GisController.setCesiumTerrainLayer(1) GisController.setCustomLayer(wmtsLayer) GisController.setHeaders(ID, RequestHeaders) GisController.setLayerIndex(ID, 1) GisController.setTerrainLayer('') GisController.show3dTiles(Id) GisController.showAll() GisController.showLayer(Id) GisController.showLayerGroup(GroupId) GisController.showOsgb(Id) GisController.toggleDebug(ID, true) ``` # Level Controller **Methods** | 方法名 | 参数 | 说明 | | ------------------ | ------------------------------------- | ---------- | | openLevel | main, streamings | 打开主关卡 | | restartLevel | | 重启主关卡 | | loadStreamLevels | streamings, exclusive, visible, block | 加载流关卡 | | unloadStreamLevels | streamings, block | 卸载流关卡 | **补充说明** - load 第一个可选参数为 **是否卸载其他的流关卡**,默认为 true - load 第二个可选参数为 **流关卡加载后是否可见**,默认为 true - load/unload 最后一个可选参数为 **是否阻塞主关卡**,默认为 false **Usage** ```ts import { LevelController } from 'cve-connector' LevelController.openLevel('Level1_Main', ['Level1_Base']) LevelController.restartLevel() LevelController.loadStreamLevel(['Level1_Base']) LevelController.unloadStreamLevel(['Level1_Base']) ``` # Model Controller **Methods** | 方法名 | 参数 | 说明 | | ------------- | ----------------- | ------------------------ | | focus | id | 通过 ID 视角聚焦到 Model | | load | path, id, groupId | 加载 Model | | unload | id | 通过 ID 卸载 Model | | unloadAll | - | 卸载所有 Model | | unloadByGroup | groupId | 通过 Group ID 卸载 Model | **Usage** ```ts import { ModelController } from 'cve-connector' const groupId = 'gid-1' const id = 'uid-a1b2c3d4e5f0' const path = 'C:\\fakepath\\demo-model.udatasmith' ModelController.load(path, id, groupId) ModelController.focus(id) ModelController.unload(id) ModelController.unloadAll() ModelController.unloadByGroup(groupId) ``` # Feature Controllers **Interface** ```ts interface Selector { Id?: string Name?: string Operator?: 'AND' | 'OR' Tags?: Condition[] } ``` **补充说明** Feature 的查找条件,支持 Id、Name、Tags 三种模式: - 按 Id 进行筛选,例如: { Id: ['Id-01','Id-02','Id-03'] } - 按 Name 进行筛选,例如: { Name: ['Name-01','Name-02','Name-03'] } - 按条件筛选,例如: { Tags: [ ["Age",">=",[18]], ["Job","in",["Tutor","Police"]] ], Operator:"And" } - 筛选条件 Condition 的数据结构: [key, operation, values] - Operation 为关系运算符,支持: '>''>=''<''<=''==''!=''in''not in' - 多个条件需要指定 Operator 逻辑运算符,支持: 'And''Or' ## Point Controller **Methods** | 方法名 | 参数 | 说明 | | ------------- | ---------------------- | ------------------------ | | addTag | Selector,string,string | 为 Point 增加一条 Tag | | removeTag | Selector,string | 为 Point 删除一条 Tag | | removeAllTags | Selector | 删除 Point 的全部 Tag | | create | PointData[] | 生成 Point | | delete | Selector | 删除指定的 Point | | show | Selector | 显示指定的 Point | | hide | Selector | 隐藏指定的 Point | | select | Selector | 选中指定的 Point(唯一) | | unselect | - | 取消选择的 Point | | update | PointData[] | 更新 Point 的补充参数 | **补充说明** - create 时 Parameters 参数必须设置,Parameters 决定点的样式; - create 执行完,找不到点,可以使用 select 方法选中该点位,视角会聚焦到点位上。 **Usage** ```ts import {PointController} from 'cve-connector' // PointData 参见 Features const points = [...] PointController.create(points) PointController.delete([{Id: ['Id-01', 'Id-02', 'Id-03']}]) PointController.show({Id: ['Id-01', 'Id-02', 'Id-03']}) PointController.hide({Id: ['A1B2C3D4E5']}) PointController.select({Id: ['Id-01']}) PointController.unselect() ``` ## Polyline Controller **Methods** | 方法名 | 参数 | 说明 | | -------------------------- | --------------------------- | --------------------------------------------- | | addTag | Selector,string,string | 为 Polyline 增加一条 Tag | | removeTag | Selector,string | 为 Polyline 删除一条 Tag | | removeAllTags | Selector | 删除 Polyline 的全部 Tag | | create | PolylineData[] | 生成  Polyline | | delete | Selector | 删除指定的  Polyline | | show | Selector | 显示指定的  Polyline | | showWithAnimateAndDuration | Selector, Animate, Duration | 同上,指定显示动画和动画持续时间 | | showWithAnimateAndSpeed | Selector, Animate, Speed | 同上,指定显示动画和动画速度 | | hide | Selector | 隐藏指定的  Polyline | | hideWithAnimateAndDuration | Selector, Animate, Duration | 同上,指定显示动画和动画持续时间 | | hideWithAnimateAndSpeed | Selector, Animate, Speed | 同上,指定隐藏动画和动画速度 | | select | Selector | 选中指定的 Polyline(唯一) | | unselect | - | 取消选择的  Polyline | | update | PolylineData[] | 更新 Polyline  的补充参数(不包括 Width 属性) | **补充说明** - Animation 几种类型的使用: | Key | Create | Hide | Show | | ------------ | :----: | :--: | :--: | | Immediately | ✔ | ✔ | ✔ | | StartToEnd | ✔ | ✔ | ✔ | | EndToStart | ✔ | ✔ | ✔ | | MiddleToSide | ✔ | - | ✔ | | SideToMiddle | - | ✔ | - | **Usage** ```ts import {PolylineController} from 'cve-connector' // PolylineData 参见 Features const polylines = [...] PolylineController.create(polylines) PolylineController.delete({Tags: [["XX属性", ">=", [100]], ["XX类型", "in", ["类型1", "类型2"]]], Operator: "And"}) PolylineController.show([{Id: ['Id-01', 'Id-02', 'Id-03']}]) PolylineController.showWithAnimateAndDuration([{Id: ['Id-01', 'Id-02', 'Id-03']}], 'StartToEnd', 1) PolylineController.showWithAnimateAndSpeed([{Id: ['Id-01', 'Id-02', 'Id-03']}], 'StartToEnd', 5) PolylineController.hide([{Id: ['Id-01', 'Id-02', 'Id-03']}]) PolylineController.hideWithAnimateAndDuration([{Id: ['Id-01', 'Id-02', 'Id-03']}], 'StartToEnd', 1) PolylineController.hideWithAnimateAndSpeed([{Id: ['Id-01', 'Id-02', 'Id-03']}], 'StartToEnd', 5) PolylineController.select({Id: ['Id-01']}) PolylineController.unselect() ``` ## Polygon Controller **Methods** | 方法名 | 参数 | 说明 | | ------------- | ---------------------- | -------------------------- | | addTag | Selector,string,string | 为 Polygon  增加一条 Tag | | removeTag | Selector,string | 为 Polygon  删除一条 Tag | | removeAllTags | Selector | 删除 Polygon  的全部 Tag | | create | PolygonData[] | 生成  Polygon | | delete | Selector | 删除指定的  Polygon | | show | Selector | 显示指定的  Polygon | | hide | Selector | 隐藏指定的  Polygon | | select | Selector | 选中指定的 Polygon(唯一) | | unselect | - | 取消选择的  Polygon | | update | PolygonData[] | 更新 Polygon 的补充参数 | **Usage** ```ts import {PolygonController} from 'cve-connector' // PolygonData 参见 Features const polygons = [...] PolygonController.create(polygons) PolygonController.delete({Tags: [["XX属性", ">=", [100]], ["XX类型", "in", ["类型1", "类型2"]]], Operator: "And"}) PolygonController.show([{Id: ['Id-01', 'Id-02', 'Id-03']}]) PolygonController.hide([{Id: ['Id-01', 'Id-02', 'Id-03']}]) PolygonController.select({Id: ['Id-01']}) PolygonController.unselect() ``` ## Polymesh Controller **Methods** | 方法名 | 参数 | 说明 | | ------------- | ---------------------- | --------------------------- | | addTag | Selector,string,string | 为 Polymesh  增加一条 Tag | | removeTag | Selector,string | 为 Polymesh  删除一条 Tag | | removeAllTags | Selector | 删除 Polymesh  的全部 Tag | | create | PolymeshData[] | 生成  Polymesh | | delete | Selector | 删除指定的  Polymesh | | show | Selector | 显示指定的  Polymesh | | hide | Selector | 隐藏指定的  Polymesh | | select | Selector | 选中指定的 Polymesh(唯一) | | unselect | - | 取消选择的  Polymesh | | update | PolymeshData[] | 更新 Polymesh 的补充参数 | **Usage** ```ts import { PolymeshController } from 'cve-connector' // PolymeshData 参见 Features const polygmeshes = [...] PolymeshController.create(polygmeshes) PolymeshController.delete({Tags: [["XX属性", ">=", [100]], ["XX类型", "in", ["类型1", "类型2"]]], Operator: "And"}) PolymeshController.show([{Id: ['Id-01', 'Id-02', 'Id-03']}]) PolymeshController.hide([{Id: ['Id-01', 'Id-02', 'Id-03']}]) PolymeshController.select({Id: ['Id-01']}) PolymeshController.unselect() ``` # Sequence Controller **Methods** | 方法名 | 必要参数 | 数据类型 | 说明 | | ------ | ------------ | -------- | -------- | | pause | IsLockCamera | - | 暂停 | | play | SequenceName | string | 播放 | | stop | - | - | 停止播放 | **Usage** ```ts import { SequenceController } from 'cve-connector' SequenceController.pause() SequenceController.play('Intro') SequenceController.stop() ``` # System Controller **Methods** | 方法名 | 必要参数 | 说明 | | --------- | -------- | ------------------------ | | mute | - | 关闭声音 | | setVolume | Volume | 设置音量大小, [0.0,1.0] | | unmute | - | 打开声音 | **Usage** ```ts import { SystemController } from 'cve-connector' SystemController.mute() SystemController.setVolume(0.3) SystemController.unmute() ``` # Time Controller **Methods** | 方法名 | 参数 | 说明 | | --------------- | -------- | ------------ | | disableRealtime | - | 禁用实时 | | enableRealtime | - | 启用实时 | | setDateTime | DateTime | 设置场景时间 | **补充说明** - 禁用实时后,渲染场景中的时间不随服务器时间变化; - 启用实时,渲染场景中的时间随服务器时间变化; - 在调用 setDateTime 函数前,请先调用 disableRealtime 函数。 **Usage** ```ts import { TimeController } from 'cve-connector' const now = new Date('2020-10-24 12:34:56') TimeController.disableRealtime() TimeController.enableRealtime() TimeController.setDateTime(now) ``` # View Controller **View Mode** ```ts enum ViewMode { SpringArm = 0, // 摇臂镜头视角 GIS = 1, // GIS 系统视角 Free = 2, // 自由视角 Editor = 3, // 编辑模式 } ``` | 操作模式 | SpringArm | GIS | Free | Editor | | :---------------: | :----------------: | :----------------: | :---------------------: | :---------------------: | | 实际值 | 0 | 1 | 2 | 3 | | 描述 | 摇臂镜头视角 | 传统 GIS 操作模式 | 自由视角 | 编辑器模式 | | 操作基准 | 基于中心点 | 基于鼠标所点击的点 | 基于镜头 | 基于镜头 | | WASDEQE 操作 | 移动中心点 | 移动镜头位置 | 移动镜头位置 | 移动镜头位置 | | 鼠标左键 | 旋转镜头 | 拖动镜头平移 | 旋转镜头 | 旋转镜头 | | 鼠标中键 | - | 旋转当前镜头 | - | - | | 鼠标右键 | 拖动中心点进行平移 | 基于当前镜头旋转 | 旋转镜头 | 旋转镜头 | | 滚轮 | 拉近\拉远距离 | 拉近\拉远距离 | 前方/后方稍微位移 | 前方/后方稍微位移 | | 鼠标长摁右键+滚轮 | - | - | 增加/减少镜头移动的速率 | 增加/减少镜头移动的速率 | - 执行空间分析指令之前,必须将 _视角模式_ 设置为 _编辑器模式_ **Methods** | 方法名 | 参数 | 说明 | | ------------- | ---------------------- | ------------------------------------ | | addPath | RoamingPath | 新增漫游路径 | | changeMode | ViewMode | 改变视角模式 | | deletePath | time | 通过 ID 删除漫游路径 | | flyTo | ViewSettings, duration | 飞到指定的位置 | | flyToBookmark | bookmark, duration | 飞到书签位置 | | getView | - | 获取当前视角 | | playPath | id | 通过 ID 播放路径漫游 | | replayPath | id | 通过 ID 重播路径漫游 | | resetView | duration | 视角初始化 | | seekPath | id, time | 通过 ID 和时间切换当前路径漫游的位置 | | stopPath | id | 通过 ID 停止路径漫游 | **视角补充说明** - Distance 是相机到 Location 的距离,UseCurrentDistance 为 false 才生效; - Location 的 x/y 不是经纬度,而是 UE 的世界坐标; - Rotation 的三个值 roll/pitch/yaw 分别表示相机沿 _前后_、_左右_、_竖直_ 轴旋转; - Rotation 三个参数,以人的视角为例,分别对应 _向左/右歪头_、_抬头/低头_、_向左/右转头_ 三种情况; - 对于 Cesium 开发,yaw 对应 heading; ```ts interface ViewSettings { Distance: number Location: [x: number, y: number, z: number] Rotation: [roll: number, pitch: number, yaw: number] UseCurrentDistance?: boolean UseCurrentRotation?: boolean } ``` **路径漫游补充说明** - Delays、Duration 单位是 _秒_,数组长度均为 _n-1_; - Positions 长度为 _n_。 ```ts interface RoamingPosition { Location: [x: number, y: number, z: number] Rotation: [roll: number, pitch: number, yaw: number] } interface RoamingPath { Delays: number[] Durations: number[] Positions: RoamingPosition[] } ``` **Usage** ```ts import { ViewController, ViewMode } from 'cve-connector' import type { ViewSettings } from 'cve-connector' const position: ViewSettings = { Distance: 182103.671875, Location: [-150933.81522, -23069.396282, 25299.628117], Rotation: [0, -25.206932, -68.69767], UseCurrentDistance: false, UseCurrentRotation: false, } ViewController.changeMode(ViewMode.GIS) ViewController.flyTo(position, 3).then((res) => { console.log(res) }) ViewController.flyToBookmark('bookmark', 3) ViewController.getView().then((desc) => { console.log(desc) }) ViewController.resetView(1) ``` **补充说明** - getView 方法返回一个 Promise,可用于异步编程 async/await - getView 结果是一个对象,Data 字段内包含 Location/Rotation/Distance # Weather Controller **Methods** | 方法名 | 参数 | 说明 | | ---------------- | ------------------ | -------------------- | | changeByPreset | Preset, Duration | 根据预设变换天气效果 | | changeBySettings | Settings, Duration | 根据参数变换天气效果 | **补充说明** - WeatherPreset 共有十种天气预设类型: | Key | Name | | ------------- | ---- | | Sunny | 晴天 | | Cloudy_Light | 少云 | | Cloudy_Medium | 多云 | | Cloudy_Heavy | 乌云 | | Rainy_Light | 小雨 | | Rainy_Medium | 中雨 | | Rainy_Heavy | 大雨 | | Snowy_Light | 小雪 | | Snowy_Medium | 中雪 | | Snowy_Heavy | 大雪 | - WeatherSettings 参数均为可选,可自由组合。参数如下: | Key | Name | Value | | ---------------- | ---------------- | ------- | | CloudCoverage | 天空中的云覆盖度 | (1, 10) | | Dust | 沙尘量 | (0, 10) | | DustCoverage | 场景沙尘覆盖度 | (0, 1) | | Fog | 雾量 | (1, 10) | | Rain | 雨量 | (0, 10) | | Snow | 雪量 | (0, 10) | | SnowCoverage | 场景雪覆盖度 | (0, 1) | | ThunderLightning | 雷电强度 | (0, 10) | | Wetness | 场景湿润度 | (0, 1) | | WindIntensity | 风强度 | (1, 10) | **Usage** ```ts import { WeatherController } from 'cve-connector' import type { WeatherPreset, WeatherSettings } from 'cve-connector' const preset: WeatherPreset = 'Sunny' const settings: WeatherSettings = { CloudCoverage: 5, // 天空中的云覆盖度(1-10) Fog: 6, // 雾量(1-10) WindIntensity: 3, // 风强度(1-10) } WeatherController.changeByPreset(preset, 3) WeatherController.changeBySettings(settings, 3) ```