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

相关文章
|
3天前
|
Dart 前端开发 Android开发
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
1月前
|
人工智能 小程序
【一步步开发AI运动小程序】十五、AI运动识别中,如何判断人体站位的远近?
【云智AI运动识别小程序插件】提供人体、运动及姿态检测的AI能力,无需后台支持,具有快速、体验好、易集成等特点。本文介绍如何利用插件判断人体与摄像头的远近,确保人体图像在帧内的比例适中,以优化识别效果。通过`whole`检测规则,分别实现人体过近和过远的判断,并给出相应示例代码。
|
20天前
|
开发框架 小程序 前端开发
圈子社交app前端+后端源码,uniapp社交兴趣圈子开发,框架php圈子小程序安装搭建
本文介绍了圈子社交APP的源码获取、分析与定制,PHP实现的圈子框架设计及代码编写,以及圈子小程序的安装搭建。涵盖环境配置、数据库设计、前后端开发与接口对接等内容,确保平台的安全性、性能和功能完整性。通过详细指导,帮助开发者快速搭建稳定可靠的圈子社交平台。
155 18
|
2天前
|
小程序 IDE PHP
圈子源码如何打包生成App小程序/开发一个圈子系统软件所需要的费用体现在哪里?
将PHP源码打包成App的过程涉及多个步骤和技术选择。以圈子源码为例,首先明确需求,确定App功能和目标用户群体,并根据需求开发小程序页面,如用户注册、圈子列表等。源码准备阶段确保源码适用于小程序开发,环境配置需安装IDE(如微信开发者工具)及依赖库。最后在IDE中打包小程序并上传至管理平台,通过审核后发布。费用方面,模板开发成本较低,定制开发则更高,具体取决于需求复杂度和第三方服务费用。
14 0
|
1月前
|
人工智能 小程序 UED
【一步步开发AI运动小程序】十六、AI运动识别中,如何判断人体站位?
【云智AI运动识别小程序插件】提供人体、运动及姿态检测的AI能力,本地引擎无需后台支持,具备快速、体验好、易集成等优势。本文介绍如何利用插件的`camera-view`功能,通过检测人体站位视角(前、后、左、右),确保运动时的最佳识别率和用户体验。代码示例展示了如何实现视角检查,确保用户正或背对摄像头,为后续运动检测打下基础。
|
1月前
|
人工智能 小程序 API
【一步步开发AI运动小程序】十七、如何识别用户上传视频中的人体、运动、动作、姿态?
【云智AI运动识别小程序插件】提供人体、运动、姿态检测的AI能力,支持本地原生识别,无需后台服务,具有速度快、体验好、易集成等优点。本文介绍如何使用该插件实现用户上传视频的运动识别,包括视频解码抽帧和人体识别的实现方法。
|
1月前
|
人工智能 小程序 数据处理
uni-app开发AI康复锻炼小程序,帮助肢体受伤患者康复!
近期,多家康复机构咨询AI运动识别插件是否适用于肢力运动受限患者的康复锻炼。本文介绍该插件在康复锻炼中的应用场景,包括康复运动指导、运动记录、恢复程度记录及过程监测。插件集成了人体检测、姿态识别等功能,支持微信小程序平台,使用便捷,安全可靠,帮助康复治疗更加高效精准。
|
1月前
|
人工智能 小程序 JavaScript
【一步步开发AI运动小程序】十四、主包超出2M大小限制,如何将插件分包发布?
本文介绍了如何从零开始开发一个AI运动小程序,重点讲解了通过分包技术解决程序包超过2M限制的问题。详细步骤包括在uni-app中创建分包、配置`manifest.json`和`pages.json`文件,并提供了分包前后代码大小对比,帮助开发者高效实现AI运动功能。
|
1月前
|
开发框架 Android开发 iOS开发
安卓与iOS开发中的跨平台策略:一次编码,多平台部署
在移动应用开发的广阔天地中,安卓和iOS两大阵营各占一方。随着技术的发展,跨平台开发框架应运而生,它们承诺着“一次编码,到处运行”的便捷。本文将深入探讨跨平台开发的现状、挑战以及未来趋势,同时通过代码示例揭示跨平台工具的实际运用。
144 3
|
8月前
|
存储 Java 开发工具
Android开发的技术与开发流程
Android开发的技术与开发流程
422 1

热门文章

最新文章