Android程序猿从零开发小程序项目(二)

简介: Android程序猿从零开发小程序项目(二)

前言

经过3天的中秋小长假后,今天又开始回到我疯狂的学习状态中了,记得前面我已经分享了一篇:Android程序猿从零开发小程序项目(一),接下来已经完成了这个小程序项目的天气预报部分了,这天气预报是我刚接触小程序的时候,跟着别人学习的,由于当时很多不懂的,做得也有点乱,所以今天就重新整理到本项目中。

效果图

先看效果图吧。。。

image.png

实践

涉及到的必备知识css的一些基础、小程序的网络请求、小程序js交互逻辑,如果对这些不够了解的话,建议先补充这些方面知识。

1.新建天气预报页面pages:

新建好小程序pages后,开发工具会自动生成页面的.js、.json、.wxml、.wxss这4个文件,具体的作用我就不啰嗦了!

2.定义页面标题为“天气预报”,当然这里可以不定义,将默认显示app.js里定义的全部标题

1{
2  "navigationBarTitleText": "天气预报"
3}

3.布局排版wxml

1<!--天气预报-->
 2<view class='page-body'>
 3  <view class='top'>
 4    <image src="../../images/weather_bg.jpg" class="img-bg"></image>
 5    <view class='top-context'>
 6      <!--城市+天气信息-->
 7      <view class="currentWeather">
 8        <view class="city">
 9          <text decode="{{true}}">{{currCity}}&nbsp;{{currLocation}}</text>
10        </view> 
11        <view class='temp-view'>
12          <text class='temp'>{{nowTmp}}</text> <text >℃</text>
13        </view>
14        <view class='weather-view'>
15          <text decode="{{true}}">{{condTxt}}&nbsp;|&nbsp;{{lifeType}}</text>
16        </view>
17      </view>
18      <!--天气详情-->
19      <view class="weatherDetail">
20        <view>
21          <view>{{dir}}</view>
22          <view>{{windDir}}</view>
23          <view class="bold">{{windSc}}级</view>
24        </view>
25        <view class="wline"></view>
26        <view>
27          <view>相对湿度</view>
28          <view class="bold">{{hum}}%</view>
29        </view>
30        <view class="wline"></view>
31        <view>
32          <view>体感温度</view>
33          <view class="bold">{{fl}}℃</view>
34        </view>
35      </view>
36    </view>
37  </view>
38
39  <view wx:for="{{dailyForecast}}" wx:key="this" wx:for-index="i" wx:for-item="item">
40
41  <view class="future-weather-view">
42
43    <!--开头 日期显示判断 -->
44    <view class="item_temp" wx:if="{{i>=3}}">{{item.date}}</view>
45    <view class="item_temp" wx:else>{{day[i]}}</view>
46
47    <!--中间部分 图片(区分白天黑夜) 和天气情况-->
48    <view>
49      <image class="forecast-img" src="../../images/icons/{{item.cond_code_d}}.png" wx:if="{{updateTime < 18}}"></image>
50      <image class="forecast-img" src="../../images/icons/{{item.cond_code_n}}.png" wx:else></image>
51      <view class="item_temp" wx:if="{{item.cond_txt_d == item.cond_txt_n}}">{{item.cond_txt_d}}</view>
52      <view class="item_temp" wx:else>{{item.cond_txt_d}}转{{item.cond_txt_n}}</view>
53    </view>
54    <!--最后 温度 -->
55    <view class="item_temp">{{item.tmp_min}}/ {{item.tmp_max}}℃</view>
56  </view>
57</view>
58</view>

4.wxss样式,就是wxml的样式设置,主要用到flex布局,这里就只贴部分了,具体看demo

1.page-body {
2  width: 100%;
3  min-height: 100%;
4  display:flex;
5  flex-direction:column;
6  justify-content: space-between;
7  font-size: 32rpx;
8  font-family: -apple-system-font,Helvetica Neue,Helvetica,sans-serif;
9}

5.js交互逻辑。主要是获取当前的位置经纬度,然后请求和风天气的接口,获取到天气数据后,动态展示到页面,具体看demo

 1//通过微信,获取当前经纬度
 2  getLocation: function () {
 3    var that = this;
 4    wx.getLocation({
 5      type: "wgs84",
 6      success: function (res) {
 7        var latitude = res.latitude //纬度
 8        var longitude = res.longitude //经度
 9        //显示加载动画
10        wx.showLoading({
11          title: '加载中',
12        })
13
14        //调用天气查询
15        that.getWeatherInfo(latitude, longitude);
16      }
17    })
18  },
19  //通过和风天气接口,获取天气情况
20  getWeatherInfo: function (latitude, longitude) {
21    var that = this;
22    var keyV = '01a7798b060b468abdad006ea3de4713';//你自己的key
23    var url = 'https://free-api.heweather.com/s6/weather';
24    wx.request({
25      url: url,
26      data: {
27        key: keyV,
28        location: longitude + ',' + latitude
29      },
30      success: function (res) {
31        //1解析整理数据
32
33        //2设置数据
34
35      }
36    });
37
38    //隐藏加载动画
39    setTimeout(function () {
40      wx.hideLoading()
41    }, 2000)
42  }

接下来我将会利用业余时间来完成这个属于自己的小程序项目,欢迎大家关注本公众号,一起学习,谢谢!

项目地址:https://github.com/zsml2016/LivingTools

相关文章
|
9天前
|
人工智能 小程序
【一步步开发AI运动小程序】十五、AI运动识别中,如何判断人体站位的远近?
【云智AI运动识别小程序插件】提供人体、运动及姿态检测的AI能力,无需后台支持,具有快速、体验好、易集成等特点。本文介绍如何利用插件判断人体与摄像头的远近,确保人体图像在帧内的比例适中,以优化识别效果。通过`whole`检测规则,分别实现人体过近和过远的判断,并给出相应示例代码。
|
3天前
|
人工智能 小程序 API
【一步步开发AI运动小程序】十七、如何识别用户上传视频中的人体、运动、动作、姿态?
【云智AI运动识别小程序插件】提供人体、运动、姿态检测的AI能力,支持本地原生识别,无需后台服务,具有速度快、体验好、易集成等优点。本文介绍如何使用该插件实现用户上传视频的运动识别,包括视频解码抽帧和人体识别的实现方法。
|
8天前
|
人工智能 小程序 UED
【一步步开发AI运动小程序】十六、AI运动识别中,如何判断人体站位?
【云智AI运动识别小程序插件】提供人体、运动及姿态检测的AI能力,本地引擎无需后台支持,具备快速、体验好、易集成等优势。本文介绍如何利用插件的`camera-view`功能,通过检测人体站位视角(前、后、左、右),确保运动时的最佳识别率和用户体验。代码示例展示了如何实现视角检查,确保用户正或背对摄像头,为后续运动检测打下基础。
|
8天前
|
移动开发 小程序 PHP
校园圈子论坛系统采取的PHP语音和uni账号开发的小程序APP公众号H5是否只需要4800元?是的,就是只需要4800元
关于校园圈子论坛系统采用PHP语言和uni-app开发的小程序、APP、公众号和H5是否仅需4800元这个问题,实际上很难给出一个确定的答案。这个价格可能受到多种因素的影响
38 8
|
4天前
|
人工智能 小程序 数据处理
uni-app开发AI康复锻炼小程序,帮助肢体受伤患者康复!
近期,多家康复机构咨询AI运动识别插件是否适用于肢力运动受限患者的康复锻炼。本文介绍该插件在康复锻炼中的应用场景,包括康复运动指导、运动记录、恢复程度记录及过程监测。插件集成了人体检测、姿态识别等功能,支持微信小程序平台,使用便捷,安全可靠,帮助康复治疗更加高效精准。
|
10天前
|
人工智能 小程序 JavaScript
【一步步开发AI运动小程序】十四、主包超出2M大小限制,如何将插件分包发布?
本文介绍了如何从零开始开发一个AI运动小程序,重点讲解了通过分包技术解决程序包超过2M限制的问题。详细步骤包括在uni-app中创建分包、配置`manifest.json`和`pages.json`文件,并提供了分包前后代码大小对比,帮助开发者高效实现AI运动功能。
|
14天前
|
开发框架 Android开发 iOS开发
安卓与iOS开发中的跨平台策略:一次编码,多平台部署
在移动应用开发的广阔天地中,安卓和iOS两大阵营各占一方。随着技术的发展,跨平台开发框架应运而生,它们承诺着“一次编码,到处运行”的便捷。本文将深入探讨跨平台开发的现状、挑战以及未来趋势,同时通过代码示例揭示跨平台工具的实际运用。
|
7月前
|
存储 Java 开发工具
Android开发的技术与开发流程
Android开发的技术与开发流程
406 1
|
4月前
|
安全 Android开发 Swift
安卓与iOS开发:平台差异与技术选择
【8月更文挑战第26天】 在移动应用开发的广阔天地中,安卓和iOS两大平台各占一方。本文旨在探索这两个系统在开发过程中的不同之处,并分析开发者如何根据项目需求选择合适的技术栈。通过深入浅出的对比,我们将揭示各自平台的优势与挑战,帮助开发者做出更明智的决策。
78 5
|
4月前
|
移动开发 搜索推荐 Android开发
安卓与iOS开发:一场跨平台的技术角逐
在移动开发的广阔舞台上,两大主角——安卓和iOS,持续上演着激烈的技术角逐。本文将深入浅出地探讨这两个平台的开发环境、工具和未来趋势,旨在为开发者揭示跨平台开发的秘密,同时激发读者对技术进步的思考和对未来的期待。