我创建了一个应用程序菜单,用户可以在其中单击照片,并且图片显示在alertView中,并且我添加了2个动作->其中一个动作是“取消”,另一个动作是“编辑图像”应该打开图库以选择其他图像。但是,当我单击编辑按钮(添加了代码)时,它什么也不起作用,其作用与消除警报视图相同。 ALERTVIEW的代码是
@objc func taxImageTApped(_snder:UITapGestureRecognizer) {
print("TaxImage")
let alertView = UIAlertController(title: "Edit Tax Image", message: "", preferredStyle: UIAlertController.Style.alert)
let image = #imageLiteral(resourceName: "backimg@3x.png")
let uiImageAlertAction = UIAlertAction(title: "", style: .default, handler: nil)
let scaleSze = CGSize(width: 245, height: 245/image.size.width*image.size.height)
let reSizedImage = image//.resize(newSize: scaleSze)
uiImageAlertAction.setValue(reSizedImage.withRenderingMode(.alwaysOriginal), forKey: "image")
alertView.addAction(uiImageAlertAction)
alertView.addAction(UIAlertAction(title: "Cancel", style: UIAlertAction.Style.default, handler: nil))
alertView.addAction(UIAlertAction(title: "Edit", style: .default) {action in
let newImage = UIImagePickerController()
newImage.delegate = self
newImage.sourceType = UIImagePickerController.SourceType.photoLibrary
newImage.allowsEditing = false
})
self.present(alertView, animated: true, completion: nil)
}
/////////////////////below is details for tap gesture i have applied on //the label
taxImageView.translatesAutoresizingMaskIntoConstraints = false
taxImageView.textColor = tableTextColor
taxImageView.text = "View Image"
taxImageView.textAlignment = .left
taxImageView.attributedText = NSAttributedString(string: "View Image", attributes:
[.underlineStyle: NSUnderlineStyle.single.rawValue])
editInfoView.addSubview(taxImageView)
taxImageView.leftAnchor.constraint(equalTo: editInfoView.leftAnchor, constant: 260).isActive = true
taxImageView.topAnchor.constraint(equalTo: editInfoView.topAnchor, constant: 740).isActive = true
taxImageView.widthAnchor.constraint(equalToConstant: 300).isActive = true
taxImageView.heightAnchor.constraint(equalToConstant: 20).isActive = true
taxImageView.isUserInteractionEnabled = true
let taxImageGesture = UITapGestureRecognizer.init(target: self, action: #selector(taxImageTApped))
taxImageGesture.numberOfTapsRequired = 1
taxImageGesture.isEnabled = true
taxImageGesture.cancelsTouchesInView = false
taxImageView.gestureRecognizerShouldBegin(taxImageGesture)
taxImageView.addGestureRecognizer(taxImageGesture)
答案 0 :(得分:1)
尝试这个
在控制器中创建变量
let imagePickerController = UIImagePickerController()
将其添加到viewDidLoad
override func viewDidLoad() {
super.viewDidLoad()
imagePickerController.delegate = self
imagePickerController.allowsEditing = true
imagePickerController.modalPresentationStyle = .popover
}
从所需位置调用此功能,或者也可以添加为手势方法
func addActionSheet() {
let alertController = UIAlertController(title: nil, message: nil, preferredStyle: .actionSheet)
let galleryOption = UIAlertAction(title: "Choose Photo", style: .default, handler: { action in
self.imagePickerController.sourceType = .photoLibrary
self.present(self.imagePickerController, animated: true, completion: nil)
})
let cameraOption = UIAlertAction(title: "Take Photo", style: .default, handler: { action in
self.imagePickerController.sourceType = .camera
self.present(self.imagePickerController, animated: true, completion: nil)
})
let deleteOption = UIAlertAction(title: "Delete Photo", style: .default, handler: { action in
self.imageView.image = nil
})
let cancelOption = UIAlertAction(title: "Cancel", style: .cancel, handler: { action in
self.dismiss(animated: true, completion: nil)
})
alertController.addAction(galleryOption)
alertController.addAction(cameraOption)
alertController.addAction(deleteOption)
alertController.addAction(cancelOption)
self.present(alertController, animated: true, completion: nil)
}
添加UIImagePickerControllerDelegate
或UINavigationControllerDelegate
的委托方法以获取图像
extension ControllerName: UIImagePickerControllerDelegate, UINavigationControllerDelegate {
func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) {
let image = info[UIImagePickerControllerOriginalImage] as! UIImage
self.imageView.image = image
dismiss(animated: true, completion: nil)
}
func imagePickerControllerDidCancel(_ picker: UIImagePickerController) {
dismiss(animated: true, completion: nil)
}
}
答案 1 :(得分:1)
为Camera and Gallery创建NSObject类。
import UIKit
class CameraHandler: NSObject{
//MARK:- Shared Instance
static let shared = CameraHandler()
private override init() {
}
//MARK:- Variables
var currentVC: UIViewController!
//MARK: Internal Properties
var imagePickedBlock: ((UIImage) -> Void)?
//MARK:- Open Camera
func camera() {
if UIImagePickerController.isSourceTypeAvailable(.camera){
UINavigationBar.appearance().barTintColor = UIColor.black
let myPickerController = UIImagePickerController()
myPickerController.delegate = self;
myPickerController.sourceType = .camera
currentVC.present(myPickerController, animated: true, completion: nil)
}
}
//MARK:- Open Gallery
func photoLibrary() {
if UIImagePickerController.isSourceTypeAvailable(.photoLibrary){
UINavigationBar.appearance().barTintColor = UIColor.black
let myPickerController = UIImagePickerController()
myPickerController.delegate = self;
myPickerController.sourceType = .photoLibrary
currentVC.present(myPickerController, animated: true, completion: nil)
}
}
//MARK:- ActionSheet For Options
func showActionSheet(vc: UIViewController) {
currentVC = vc
let actionSheet = UIAlertController(title: nil, message: nil, preferredStyle: .actionSheet)
actionSheet.addAction(UIAlertAction(title: "Camera", style: .default, handler: { (alert:UIAlertAction!) -> Void in
self.camera()
}))
actionSheet.addAction(UIAlertAction(title: "Gallery", style: .default, handler: { (alert:UIAlertAction!) -> Void in
self.photoLibrary()
}))
actionSheet.addAction(UIAlertAction(title: "Cancel", style: .cancel, handler: nil))
vc.present(actionSheet, animated: true, completion: nil)
}
}
//MARK:- UIImagePickerController Delegate Methods
extension CameraHandler: UIImagePickerControllerDelegate, UINavigationControllerDelegate{
func imagePickerControllerDidCancel(_ picker: UIImagePickerController) {
UINavigationBar.appearance().barTintColor = UIColor.white
currentVC.dismiss(animated: true, completion: nil)
}
func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) {
UINavigationBar.appearance().barTintColor = UIColor.white
if let image = info[UIImagePickerController.InfoKey.originalImage] as? UIImage {
self.imagePickedBlock?(image)
}else{
print("Something went wrong")
}
currentVC.dismiss(animated: true, completion: nil)
}
}
在视图控制器中使用以下代码:
用于在当前视图控制器中显示警报:
CameraHandler.shared.showActionSheet(vc: self)
要获取所选图像:
CameraHandler.shared.currentVC = self
CameraHandler.shared.imagePickedBlock = {(image) in
print(image)
}