用户
 ?#19968;?#23494;码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,登录网站

小程序社区 首页 教程 实战教程 查看内容

借助小程序·云开发制作校园导览小程序丨实战

Rolan 2019-10-14 00:21

背景当你刚上大学的时候,要想不迷失校园,除了依靠不怎么可靠的路边标识外,总会收到那么一张卡通绘制的校园地图:这种静态图片可以让我们快速地了解到所需的地理位置信息,但使用和思考过后,会发现以下问题:地理 ...

背景

当你刚上大学的时候,要想不迷失校园,除了依靠不怎么可靠的路边标识外,总会收到那么一张卡通绘制的校园地图:

这种静态图片可以让我们快速地了解到所需的地理位置信息,但使用和思考过后,会发现以下问题:

  1. 地理位置信息粒度高,而同一个地点通常具有多个服务功能和别名。
  2. 地理位置信息变更导致地图信息过时。一旦服务网点迁移或更名,需要重绘地图,带来一定的延迟和信息滞后。
  3. 入口较深。存储在?#21482;?#19978;的地图并不是那么好找,尤其是随着时间的推移。
  4. 无法准确的定位当前所处位置,需要寻找参照物,这是静态地图致命的缺点。
  5. 缺乏更为详细的地点介绍,只能在有限的画面里堆积内容。

为此,我设计了一款校园导览应用,用当下流行的微信小程序结合云开发能力,低成本高效能地解决了以上问题。此外,?#19968;?#26681;据对市面上的同类应用进行设计上的研究,在界面和交互设计上做功夫。下面我会进行简短的介绍。

南苑导览

南苑导览是一款由学生独立开发的以地图为载体,提供 中山大学南方学院 (南苑)具体地点的位置信息、导航、校园历史及文化介绍的小程序。旨在解决校园导航标识不到位、地图?#38382;?#20302;效单一、信息设计不够好等问题,为来南苑新人和游客提供更加完美的出行体验。

<div align=center>

仅需修改地图配置文件,即可适配?#25105;?#22330;景(校园、景区)的小程序个性化地图定制。

技术栈:原生小程序 + TypeScript + gulp + vantUI + 云开发能力

2019 微信小程序高校大赛 · 华南赛区二等奖

</div>

南苑导览 · 开发

  1. config 配置
├─ src
├─── config
├───── index.ts // 入口
├───── cloud.ts // 云开发相关配置
├───── info.ts // 应用介绍信息
├───── markerStyle.ts // 地图marker样式
├───── panorama.ts // 第三方全景地图配置(个人类型无webview权限,默认关闭)
└───── secret.ts // 腾讯地图key?#35753;?#24863;信息(可选)
  1. 使用云数据库
// markers表 数据格式
{
  _id: "5ce8fe1c29c7a8581bc1e989",  // id,云数据库录入upsert更新用
  type: "生活服务",   // 场景名称
  icon: "shfw",     // marker默认图标,为场景名称拼音缩写
  scale: 15.0,   // 场景在地图上的缩放值,可选。已废弃,用includePoints代替
  position: 0, // 指定在各个场景中的排列顺序
  data: [   // 该场景下的地点markers
    {
      name: "孙中山铜像",   // 地点名称
      short_name: "铜像", // 名称缩写
      desc: "中山铜像...", // 描述信息
      logo: "tx",   // 地点logo,缩写拼音, 如作各?#21512;祃ogo展示
      icon: "[email protected]",   // 自定义marker图标,“@”后数字为图标相较于默认图标的缩放值
      images: 3,  // 图片数量,作云存储拼接路径用(cloud://cloudRoot/1教/n.jpg)
      panorama: 0,  // 全景场景id
      latitude: "23.635875",  // 经度
      longitude: "113.678965",  // 纬度
      contact: { phone: "020-123456", address: "出门左转" }   // 联系方式
    }
  ]
}

使用 excel 进行数据维护,通过 python pandas 进行数据清洗,使用 jsonlines 库输出符合云数据库的 JSON Lines 格式文件,以 upsert ?#38382;?#23548;入数据库。

数据更新流程如下:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9Kzq570X-1570761839095)( https://656e-enanyuan-6db383-... ]

  1. 加载并清洗数据

    使用 request 或云数据库进行异步数据请求时。由于 app.js 中的 onLaunch 和首页 index 的 onLoad 的执行顺序不是固定的,所以如果首页有基于 app.js 请求的数据时要注意生命周期的问题。

// index
async loadMarkers() {
  let markers;
  if (app.globalData.config.debug) {
    // 本地
    markers = mockMarkers;
  } else {
    // 云
    await wx.cloud
      .callFunction({
        name: "loadMarkers"
      })
      .then((res: any) => {
        markers = res.result.data;
      });
  }
  app.globalData.markers = markers;
}

clearMarkers(markers: any[]) {
  let num = 0;  // 每个marker都要有一个id
  for (const i of markers) {
    for (const j of i.data) {
      j.id = num;
      num += 1;
      j.iconPath = `/assets/images/markers/${j.icon ? j.icon : i.icon}.png`;

      ...

      // 自定义气泡样式
      j.callout = Object.assign(
        { content: j.short_name ? j.short_name : j.name },
        app.globalData.config.markerStyle.calloutStyle
      );
    }
  }
  return markers;
}
  1. 巧用 MapContext

    你不需要去手动地为每个场景设置 scale,用 includePoints 即可让地图视野自动覆盖到当前所有 POI。

    你也不需要去手动地去获取权限设置用户位置,用 moveToLocation 即可轻松定位。

// index
onReady() {
  this.setData!({
    mapContext: wx.createMapContext("map")
  });
}

includePoints(padding: number) {
  this.data.mapContext.includePoints({
    padding: [padding, padding, padding, padding],
    points: this.data.markers
  });
}

locate() {
  this.data.mapContext.moveToLocation();
}
  1. 使用云存储管理图片

    添?#26377;?#22270;片时,直?#26377;?#25913; images 字段即可,文件?#24515;?#24405;为地点名称。

<!-- 地点详情页 轮播图 -->
<swiper
  indicator-dots="{{imgUrls.length > 1}}"
  autoplay="{{true}}"
  interval="3000"
  duration="1000"
>
  <block wx:for="{{imgUrls}}" wx:key="{{index}}">
    <swiper-item>
      <image
        src="{{item}}"
        class="slide"
        data-id="{{index}}"
        bindtap="previewImage"
      />
    </swiper-item>
  </block>
</swiper>
for (let i = 0; i < marker.images; i++) {
  imgUrls.push(
    this.data.cloudRoot +
      "images/" +
      (marker.short_name || marker.name) +
      "/" +
      i +
      ".jpg"
  );
}

南苑导览 · 设计

如果你在微信上搜索「导览」二字,看到的小程序大多都是一个模板,页面层级深,界面?#23548;罰?#21015;表式的信息展?#38745;?#19981;符合我们日常使用地图 APP 的经验。为此,我做出了多项改良:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-j76bV81T-1570761839095)( https://656e-enanyuan-6db383-... ]

  1. 更好的视野 - 自定义导航栏与侧边栏

    因为只有特定的页面需要使用自定义导航栏,所以只需要设置页面级的 config:

"navigationStyle": "custom"

接下来获取胶?#37326;?#38062;位置信息:

bounding: wx.getMenuButtonBoundingClientRect();

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XoDA3u2I-1570761839096)( https://656e-enanyuan-6db383-... ]

动态地设置样式:

<!-- SIDE MENU -->
<view
  class="sidebar"
  hidden="{{toggleRoutes}}"
  style="top:{{bounding.height + bounding.top + 10}}px"
>
  ...
</view>
  1. FAB 与侧边栏设计

把最主要的定位、搜索和路线推荐功能在视觉上成为整体,通过点击 FAB 弹出菜单选项。侧边栏的地点场景菜单设计为下拉滚动,注意使用半遮设计来提醒用户滚动。同时,为了让界面更加精简,侧边菜单会在点击 FAB(Float Action Button)和母按钮时 toggle 显示与隐藏。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SP3GrjOr-1570761839096)( https://656e-enanyuan-6db383-... ]

  1. 用点击代替滚动 - scroll-into-view

    在路线面板和搜索页?#26657;?#20351;用到了 scroll-view 组件,利用其 scroll-into-view 特性,实现点击代替滚动的操作,同时也能起?#25945;?#37266;后置选项的作用。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-o18t46ea-1570761839097)( https://656e-enanyuan-6db383-... ]

windowWidth: wx.getSystemInfoSync().screenWidth;
<scroll-view class="route" scroll-x scroll-into-view="{{focusPointId}}">
  <view
    class="points"
    style="width:{{routes[routeIndex].count * 140 < windowWidth ? windowWidth : routes[routeIndex].count * 140}}rpx;"
  >
    ...
  </view>
</scroll-view>
  1. 更好的视角 - 全景功能

    结合 web-view 和全景服务?#25945;ǎ?#21487;以为一款地图导览应?#36855;?#33394;不少。

总结

云开发让小程序开发者无需搭建服务器,使用?#25945;?#25552;供的 API 即可快速地进行业务开发、上线和迭代,免费的基础版完全可以满足中小应用的需求。「南苑导览」借助腾讯云开发能力,上线以来,帮助到了许许多多的新生和来客,实现了产品价值。最后,期望官方早日开放自定义地图底图能力,让开发者能够个性化地图,探索出更多的应用场景!

源码地址

https://github.com/TencentCloudBase/Good-practice-tutorial-recommended

鲜花
鲜花
鸡蛋
鸡蛋
分享至 : QQ空间
收藏
原作者: CloudBase 来自: segmentfault.
不朽的浪漫援彩金
体彩组三倍投会赚钱吗 秒速飞艇盛宏开奖网 浙江11选5跨度走势 个人美工怎么赚钱 江西多乐彩新十一选五 通化大嘴手机版 中彩票14亿 广西11选5中三个 竞彩微信投注 体彩湖北11选5玩法 养殖做什么最赚钱呢 体彩河北十一选五开奖结果 股票交易时间 重庆百变王牌几点播出 新浪棋牌中心下载 跑马彩票计划ap