1.获取用户当前所在的位置
在infi中点击加号,选择权限:当用户使用app的时候获取位置权限.
data:image/s3,"s3://crabby-images/52537/5253783f29d0215b5f126773134ba8bd5ce957c7" alt=""
填写使用位置权限的目的.
data:image/s3,"s3://crabby-images/73098/73098a798a3e18692876af43273d028fa28c27a0" alt=""
2.获取用户的经纬度.
ViewController:
import UIKit
import CoreLocation
class ViewController: UIViewController, CLLocationManagerDelegate { //遵循CLLocationManagerDelegate协议
//位置管理器
let locationManager = CLLocationManager()
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
locationManager.requestWhenInUseAuthorization() //请求当用户正在使用app的时候允许后台得到用户位置.只会弹出来一次
locationManager.delegate = self //位置管理器代理人是view controller对象.希望view controller能通过实现CLLocationManagerDelegate协议中的方法,获取到当前用户位置信息
locationManager.desiredAccuracy = kCLLocationAccuracyThreeKilometers //设置需要的位置精度(三公里误差精度)
locationManager.requestLocation() //请求用户位置
}
func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) { //requesLocation请求到了的话会执行这个方法
let lon = locations[0].coordinate.longitude //精度.因为location可能实时变化(地图app),所以是一个数组.我们只需要使用第一个获取到的位置.
let lat = locations[0].coordinate.latitude //纬度
print(lon)
print(lat)
}
func locationManager(_ manager: CLLocationManager, didFailWithError error: Error) { //requesLocation请求失败的话会执行这个方法
print(error)
}
}
data:image/s3,"s3://crabby-images/173cb/173cbb156536b72efda099bb0e88f854d5316230" alt=""
3.通过第三方服务获取当前天气
(1)安装cocoapods
在网站中可以找到,当向 https://devapi.qweather.com/v7/weather/now?\[请求参数\] 发送请求时,就可以得到当前天气.
通过依赖管理工具cocoapods命令行工具进行依赖管理.在终端里对它进行下载并安装,
在Mac的启动台上找到「终端」应用,或者在触控板上通过四指聚合来打开「启动台---终端」。
在命令行输入
sudo gem install cocoapods
(以超级管理员的身份,安装cocoapods这个应用.)
输入电脑开机密码.
data:image/s3,"s3://crabby-images/5c5a4/5c5a41ffdf50da3034d29b85ab87caac2d21ca5d" alt=""
等待安装成功.
data:image/s3,"s3://crabby-images/df0d0/df0d0a12f59a7e50ceea7f2c1c9678e1dfe476f5" alt=""
这里可能出现Error installing cocoapods:
The last version of activesupport (>= 5.0, < 8) to support your Ruby & RubyGems was 6.1.7.6. Try installing it with `gem install activesupport -v 6.1.7.6` and then running the current command again
activesupport requires Ruby version >= 2.7.0. The current ruby version is 2.6.10.210.
这个bug,解决方式请参照博客:https://www.cnblogs.com/lysboke/p/17678896.html
(2)安装功能包
在cocoapods官网https://cocoapods.org/的搜索栏搜索Alamofire.点击进入.
data:image/s3,"s3://crabby-images/69e9c/69e9c1897010ee3d4b77d3eab1e189031b0a1679" alt=""
用cocoapods安装Alamofire.
在终端中输入cd空格,将项目文件夹Weather拖入到cd后面.点击回车.
data:image/s3,"s3://crabby-images/630e1/630e11de2eae03cef4f9beb23eb24aa5a3373172" alt=""
终端输入
pod init
等待.完成之后打开Weather文件夹,发现成功创建Podfile文件.
data:image/s3,"s3://crabby-images/2cbbc/2cbbceb581bd4db62cafc866f2ac67cf76e10341" alt=""
data:image/s3,"s3://crabby-images/4b39a/4b39a4125133c4ea1cbddf812a148244e21dc269" alt=""
将Podfile拖入Xcode,Podfile自动弹出.
data:image/s3,"s3://crabby-images/940a9/940a9d7daadbd01763fba099e1da508a367a6055" alt=""
加入代码:
pod 'Alamofire'
保存并关闭Podfile.
data:image/s3,"s3://crabby-images/82527/82527a2f577cac5c664b41297f544188f1975e39" alt=""
在终端输入命令安装功能包:
pod install
data:image/s3,"s3://crabby-images/52caf/52cafdeed483885f96c64b031fcf58263dce2466" alt=""
关闭Xcode,从Weather文件中打开Weather.xcworkspace,可以看到项目结构如下.
data:image/s3,"s3://crabby-images/28fee/28fee905cadb2e7a5186069f1d4b1c09b1f47496" alt=""
4.利用和风API获取当前位置的天气信息
注册和风天气账号.在和风天气中创建一个免费的新项目.
https://console.qweather.com/#/apps/create-app/create
data:image/s3,"s3://crabby-images/f004a/f004af3494355db6f1e288b2ca076cbf961a1606" alt=""
得到key.
编写代码得到当前经纬度下的天气数据信息.
import UIKit
import CoreLocation
import Alamofire //引入和风API包
class ViewController: UIViewController, CLLocationManagerDelegate { //遵循CLLocationManagerDelegate协议
//位置管理器
let locationManager = CLLocationManager()
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
locationManager.requestWhenInUseAuthorization() //请求当用户正在使用app的时候允许后台得到用户位置.只会弹出来一次
locationManager.delegate = self //位置管理器代理人是view controller对象.希望view controller能通过实现CLLocationManagerDelegate协议中的方法,获取到当前用户位置信息
locationManager.desiredAccuracy = kCLLocationAccuracyThreeKilometers //设置需要的位置精度(三公里误差精度)
locationManager.requestLocation() //请求用户位置
}
func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) { //requesLocation请求到了的话会执行这个方法
let lon = locations[0].coordinate.longitude //精度.因为location可能实时变化(地图app),所以是一个数组.我们只需要使用第一个获取到的位置.
let lat = locations[0].coordinate.latitude //纬度
//print(lon)
//print(lat)
AF.request("https://devapi.qweather.com/v7/weather/now?location=\(lon),\(lat)&key=a91848aaab484a3599a703b139dfe87b").responseJSON { response in
if let data = response.value{
print(data)
}
} //请求和风API的网址,得到当前位置的天气
}
func locationManager(_ manager: CLLocationManager, didFailWithError error: Error) { //requesLocation请求失败的话会执行这个方法
print(error)
}
}
为了在测试中使用http传输,在Info中新增一个key和Value:App Transport Security Settings,在它里边再添加一个Allow Arbitrary Loads,Value设置为Yes.
data:image/s3,"s3://crabby-images/975a0/975a0923ebd723c0123580d3c0e7272ca2de8da6" alt=""
5.解析和风API返回的JSON数据
在Xcode中的Podfile中添加如下:
pod 'SwiftyJSON', '~> 4.0'
保存之后在终端输入:
pod install
data:image/s3,"s3://crabby-images/6bbf1/6bbf1b2018e9053c1f51a60fbe410a264d171370" alt=""
下载之后引入JSON解析包,写入代码,测试.
import UIKit
import CoreLocation
import Alamofire //引入和风API包
import SwiftyJSON //引入解析JSON数据的包
class ViewController: UIViewController, CLLocationManagerDelegate { //遵循CLLocationManagerDelegate协议
//位置管理器
let locationManager = CLLocationManager()
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
locationManager.requestWhenInUseAuthorization() //请求当用户正在使用app的时候允许后台得到用户位置.只会弹出来一次
locationManager.delegate = self //位置管理器代理人是view controller对象.希望view controller能通过实现CLLocationManagerDelegate协议中的方法,获取到当前用户位置信息
locationManager.desiredAccuracy = kCLLocationAccuracyThreeKilometers //设置需要的位置精度(三公里误差精度)
locationManager.requestLocation() //请求用户位置
}
func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) { //requesLocation请求到了的话会执行这个方法
let lon = locations[0].coordinate.longitude //精度.因为location可能实时变化(地图app),所以是一个数组.我们只需要使用第一个获取到的位置.
let lat = locations[0].coordinate.latitude //纬度
//print(lon)
//print(lat)
AF.request("https://devapi.qweather.com/v7/weather/now?location=\(lon),\(lat)&key=a91848aaab484a3599a703b139dfe87b").responseJSON { response in
if let data = response.value{
let weatherJSON = JSON(data)
print(weatherJSON)
}
} //请求和风API的网址,得到当前位置的天气
}
func locationManager(_ manager: CLLocationManager, didFailWithError error: Error) { //requesLocation请求失败的话会执行这个方法
print(error)
}
}
启动运行:
data:image/s3,"s3://crabby-images/592bf/592bf43b2da34a01958fcfe3ba58744951d02c33" alt=""
6.拿到天气数据并展示在界面上
把温度拖拽到ViewController中.
data:image/s3,"s3://crabby-images/c5cd4/c5cd4ee985860471c209470d80036f8b90825c83" alt=""
同理,将天气图标和用户当前所在的城市也拖拽到代码区.
data:image/s3,"s3://crabby-images/8ca10/8ca102d42bab10ff956d64beafc5f91b785cc0e4" alt=""
新建一个swift文件:
data:image/s3,"s3://crabby-images/dadec/dadec989b0852ac214f7a40898ae118adf012439" alt=""
Weather.swift:
import Foundation
class Weather{
var temp = ""
var icon = ""
var city = ""
}
ViewController:
import UIKit
import CoreLocation
import Alamofire //引入和风API包
import SwiftyJSON //引入解析JSON数据的包
class ViewController: UIViewController, CLLocationManagerDelegate { //遵循CLLocationManagerDelegate协议
@IBOutlet weak var tempLable: UILabel!
@IBOutlet weak var iconImageView: UIImageView!
@IBOutlet weak var cityLable: UILabel!
//位置管理器
let locationManager = CLLocationManager()
//Weather.swift实例化
let weather = Weather()
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
locationManager.requestWhenInUseAuthorization() //请求当用户正在使用app的时候允许后台得到用户位置.只会弹出来一次
locationManager.delegate = self //位置管理器代理人是view controller对象.希望view controller能通过实现CLLocationManagerDelegate协议中的方法,获取到当前用户位置信息
locationManager.desiredAccuracy = kCLLocationAccuracyThreeKilometers //设置需要的位置精度(三公里误差精度)
locationManager.requestLocation() //请求用户位置
}
func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) { //requesLocation请求到了的话会执行这个方法
let lon = locations[0].coordinate.longitude //精度.因为location可能实时变化(地图app),所以是一个数组.我们只需要使用第一个获取到的位置.
let lat = locations[0].coordinate.latitude //纬度
//print(lon)
//print(lat)
AF.request("https://devapi.qweather.com/v7/weather/now?location=\(lon),\(lat)&key=a91848aaab484a3599a703b139dfe87b").responseJSON { response in
if let data = response.value{
let weatherJSON = JSON(data)
//print(weatherJSON["now"]["temp"]) //或weatherJSON["now", "temp"]
//print(weatherJSON["refer"]["sources"][0]) //weatherJSON["refer", "sources", 0]
//MVC结构
self.weather.temp = "\(weatherJSON["now"]["temp"].stringValue)˚"
self.weather.icon = weatherJSON["now"]["icon"].stringValue
self.tempLable.text = self.weather.temp
self.iconImageView.image = UIImage(named: self.weather.icon)
}
} //请求和风API的网址,得到当前位置的天气
}
func locationManager(_ manager: CLLocationManager, didFailWithError error: Error) { //requesLocation请求失败的话会执行这个方法
print(error)
}
}
启动测试:
data:image/s3,"s3://crabby-images/a3ca7/a3ca76080c40519f37f6090398bf55158f12830b" alt=""
7.获取用户当前所在的城市
ViewController:
import UIKit
import CoreLocation
import Alamofire //引入和风API包
import SwiftyJSON //引入解析JSON数据的包
class ViewController: UIViewController, CLLocationManagerDelegate { //遵循CLLocationManagerDelegate协议
@IBOutlet weak var tempLable: UILabel!
@IBOutlet weak var iconImageView: UIImageView!
@IBOutlet weak var cityLable: UILabel!
//位置管理器
let locationManager = CLLocationManager()
//Weather.swift实例化
let weather = Weather()
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
locationManager.requestWhenInUseAuthorization() //请求当用户正在使用app的时候允许后台得到用户位置.只会弹出来一次
locationManager.delegate = self //位置管理器代理人是view controller对象.希望view controller能通过实现CLLocationManagerDelegate协议中的方法,获取到当前用户位置信息
locationManager.desiredAccuracy = kCLLocationAccuracyThreeKilometers //设置需要的位置精度(三公里误差精度)
locationManager.requestLocation() //请求用户位置
}
func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) { //requesLocation请求到了的话会执行这个方法
let lon = locations[0].coordinate.longitude //精度.因为location可能实时变化(地图app),所以是一个数组.我们只需要使用第一个获取到的位置.
let lat = locations[0].coordinate.latitude //纬度
//print(lon)
//print(lat)
AF.request("https://devapi.qweather.com/v7/weather/now?location=\(lon),\(lat)&key=a91848aaab484a3599a703b139dfe87b").responseJSON { response in
if let data = response.value{
let weatherJSON = JSON(data)
//print(weatherJSON["now"]["temp"]) //或weatherJSON["now", "temp"]
//print(weatherJSON["refer"]["sources"][0]) //weatherJSON["refer", "sources", 0]
//MVC结构
self.weather.temp = "\(weatherJSON["now"]["temp"].stringValue)˚"
self.weather.icon = weatherJSON["now"]["icon"].stringValue
self.tempLable.text = self.weather.temp
self.iconImageView.image = UIImage(named: self.weather.icon)
}
} //请求和风API的网址,得到当前位置的天气
AF.request("https://geoapi.qweather.com/v2/city/lookup?location=\(lon),\(lat)&key=a91848aaab484a3599a703b139dfe87b").responseJSON { response in
if let data = response.value{
let cityJSON = JSON(data)
//处理数据
self.weather.city = cityJSON["location", 0, "name"].stringValue
//处理AI
self.cityLable.text = self.weather.city
}
}
}
func locationManager(_ manager: CLLocationManager, didFailWithError error: Error) { //requesLocation请求失败的话会执行这个方法
cityLable.text = "获取用户城市失败"
}
}
启动测试:
data:image/s3,"s3://crabby-images/75513/75513247e19c481be974c0985c8313995e0a6482" alt=""