昨天集成这个FWPopupView的时候发现弹出框不弹出来,因为项目里的弹出框是加载到自定义的FWPopupWindow上的,但是FWPopupWindow压根没初始化成功,(能弹出来才见鬼)
然后用低版本项目集成,一下子就成功了,所以猜想是windowScene的问题
专业术语咱也不会说,话不多说上代码
前期准备:
1.首先在你的xcode11 ios 13的环境下,新建一个xcode项目
data:image/s3,"s3://crabby-images/aad1c/aad1cafbe5a76c6fc9d8fbb77d88cdc9e9e4db07" alt=""
xcode 11, ios 13 新建的项目结构是下图这样:
data:image/s3,"s3://crabby-images/8e26f/8e26f2616db5f869fe253d19a80ef9b8fa558860" alt=""
2.打开终端用pod引入FWPopupView 和 IQKeyboardManagerSwift
data:image/s3,"s3://crabby-images/3fc8c/3fc8c2b968be2f77603fb82a0e63c099c0d47655" alt=""
3. 在pod里找到FWPopupWindow文件 并需要改两处
data:image/s3,"s3://crabby-images/f7378/f73785452d315f156d702b9e5101dfe58daf81b2" alt=""
@objc public class var sharedInstance: FWPopupWindow {
struct Static {
static let kbManager: FWPopupWindow = { () -> FWPopupWindow in
if #available(iOS 13.0, *) {
let windowScene = UIApplication.shared
.connectedScenes
.filter { $0.activationState == .foregroundActive }
.first
if let windowScene = windowScene as? UIWindowScene {
return FWPopupWindow(windowScene: windowScene)
}
}
return FWPopupWindow(frame: UIScreen.main.bounds)
}()
}
return Static.kbManager
}
data:image/s3,"s3://crabby-images/a7d06/a7d06d62448520b12c48c3476f9a719762fef281" alt=""
public override init(frame: CGRect) {
super.init(frame: frame)
self.setup()
}
@available(iOS 13.0, *)
public override init(windowScene: UIWindowScene) {
if #available(iOS 13.0, *) {
super.init(windowScene: windowScene)
setup()
} else {
// Fallback on earlier versions
fatalError("")
}
}
func setup() {
let rootVC = FWPopupRootViewController()
rootVC.view.backgroundColor = UIColor.clear
self.rootViewController = rootVC
self.windowLevel = UIWindow.Level.statusBar + 1
let tapGest = UITapGestureRecognizer(target: self, action: #selector(tapGesClick(tap:)))
// tapGest.cancelsTouchesInView = false
tapGest.delegate = self
self.addGestureRecognizer(tapGest)
let panGest = UIPanGestureRecognizer(target: self, action: #selector(panGesClick(pan:)))
self.addGestureRecognizer(panGest)
}
4、项目兼容ios13
data:image/s3,"s3://crabby-images/2979f/2979f1e695c10550875d2fe71fc0398b15e5b387" alt=""
项目会报一堆错
data:image/s3,"s3://crabby-images/48a6a/48a6a3a14f0c7b653232e6f2cca576ec3c555ee7" alt=""
需要在函数前添加一行代码
@available (iOS 13.0, *)
data:image/s3,"s3://crabby-images/b1b08/b1b084e217aa0fcfa4744e23887f04955df0f35a" alt=""
这里也会报错 ,直接在类前添加 @available (iOS 13.0, *)
data:image/s3,"s3://crabby-images/7f0b0/7f0b0f9d93c863d8f1806fba2a909651c7e2aef1" alt=""
data:image/s3,"s3://crabby-images/3e7d3/3e7d3fad5c4fbb27255fe4b19949e22d02866f92" alt=""
5.自定义根控制器
data:image/s3,"s3://crabby-images/5f306/5f30635318204da8396b79ebf12470512ebe8428" alt=""
guard let windowScene = (scene as? UIWindowScene) else { return }
self.window = UIWindow (windowScene: windowScene)
self.window?.rootViewController = UINavigationController(rootViewController: ViewController())
self.window?.backgroundColor = UIColor.yellow
self.window?.makeKeyAndVisible()
6. 最后在根控制器里随便写一个例子调用一个弹框
data:image/s3,"s3://crabby-images/7d516/7d516e57a144c395144eb66526aa38a42bc6f6d5" alt=""
//
// ViewController.swift
// PopViewTest
//
// Created by uu on 2019/11/14.
// Copyright © 2019 UU. All rights reserved.
//
import UIKit
import FWPopupView
class ViewController: UIViewController {
lazy var alertImage: FWAlertView = {
let block2: FWPopupItemClickedBlock = { [weak self] (popupView, index, title) in
if index == 1 {
// 这边演示了如何手动去调用隐藏
self?.alertImage.hide()
}
}
// 注意:此时“确定”按钮是不让按钮自己隐藏的
let items = [FWPopupItem(title: "取消", itemType: .normal, isCancel: true, canAutoHide: true, itemClickedBlock: block2),
FWPopupItem(title: "确定", itemType: .normal, isCancel: false, canAutoHide: false, itemClickedBlock: block2)]
// 注意:添加自定义的视图,需要设置确定的Frame值
let customImageView = UIImageView(image: UIImage(named: "audio_bgm_4"))
customImageView.frame = CGRect (x: 0, y: 0, width: 100, height: 100)
customImageView.backgroundColor = UIColor.blue
let vProperty = FWAlertViewProperty()
vProperty.touchWildToHide = "1"
let alertImage = FWAlertView.alert(title: "标题", detail: "带自定义视图", inputPlaceholder: nil, keyboardType: .default, isSecureTextEntry: false, customView: customImageView, items: items, vProperty: vProperty)
return alertImage
}()
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
self.navigationItem.rightBarButtonItem = UIBarButtonItem (title: "点我吖", style: .done, target: self, action: #selector(onClickPop))
}
@objc func onClickPop() {
print(self.alertImage.frame)
self.alertImage.show()
print(self.alertImage.frame)
}
}
成功在xcode 11, ios 13 上集成~~~~
注意!!!!!!!最主要的步骤是3
不懂的私信 溜了溜了
网友评论