1 Star 0 Fork 4

ZTao-z/原神地图V3

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

原神地图v3 (yuanshenmap-v3)

本项目基于quasar-vite构建

项目相关

安装依赖

yarn
# or
npm install

进入开发模式

quasar dev

构建

quasar build

地图相关功能

鉴权

在页面登录前,鉴定是否有gitee的oauth2相关的token,若没有的话,则以游客方式登录

Gitee Api文档

游客登录请求是本项目的接口,并非gitee api

鉴权实现在 router/index.js文件内

Router.beforeEach((to, from, next) => {
    //鉴定是否存在token,若否,默认以游客身份登录
    if (get_user_token() == null) {
      quest_request().then(res => {
        set_user_token(res.data.access_token, res.data.expires_in)
        next();
      })
    }
    else {
      next();
    }
  })

地图构建

地图构建相关函数在api/map.js文件内

地图相关参数及构建方法已经封装,无须了解其具体功能

生成地图时,首先在页面上生成其容器dom

<!-- id为map的div为容器,其余两个为地图的背景蒙层 -->
<div class="map_containor">
    <div class="stars"></div>
    <div class="twinkling"></div>
    <div id="map"></div>
</div>

然后在mounted时,生成地图

import { init_map } from "../api/map";
......
mounted() {
    //生成地图
    this.map = init_map();
  },

地图容器需要定义其高度和宽度,地图蒙层容器需要样式,可直接引用旧版样式文件

@import url("https://yuanshen.site/css/background.css");/* 地图蒙层样式 */

#map {
    width: 100vw;
    height: 100vh;
    background: transparent;
    z-index: 1000;
    background: radial-gradient(transparent 70%, rgba(0, 0, 0, 0.5));
}

点位选择

概述

在本项目中,点位筛选逻辑分为四级

地区(area)_→点位类型(type)→点位集合(item)→单个点位(layer)

注意

在地区筛选等级中,由于每个地区划分为多个子地区,因此规定,后续筛选等级于子地区为基准

点位类型的相关数据在每个地区‘基本’一致,因此在页面构建时点位类型便已被请求并渲染至物品选择器中

点位选择逻辑

本项目的点位请求逻辑如下:

首先渲染所有父级地区

选择父级地区之后,请求其子级地区的数据后,用户可以选择子地区

(上述即是页面上方地区选择器的功能)

选择完毕后,用户可以在右侧类型选择器选择点位类型

选择后,即查询该子地区下所选类型的所有点位集合,并渲染至类型的下拉列表之中

选择某一或某多个点位集合后,请求这些点位集合下所有单个点位的数据

点位生成

点位生成的相关函数在api/layer.js下

leaflet的点位的api

leaflet的点位组的api

具体的渲染过程和存储过程较为复杂,可参考 pages/IndexPage.vue 文件中的具体实现

空文件

简介

原神地图V3的开源仓库 展开 收起
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/ZTao-z/yuanshenmap_v3.git
git@gitee.com:ZTao-z/yuanshenmap_v3.git
ZTao-z
yuanshenmap_v3
原神地图V3
master

搜索帮助