我正在尝试使用 UIKit 的内部后退按钮图像。 我之前问过这个问题,并得到了技术上正确的答案,它继承了之前的视图,但是如果我插入此代码,您可以控制当前视图上的后退按钮。
// Takeover Back Button
self.navigationItem.hidesBackButton = false
let newBackButton = UIBarButtonItem(title: "<", style: .Plain, target: self, action: "segueBack")
navigationItem.leftBarButtonItem = newBackButton
这给了我一个<, "ABC" would give me ABC etc but how do I trigger Swift to put up it's internal Back Button image. The code below doesn't work but I would have thought is along the right lines.
let backImg: UIImage = UIImage(named: "BACK_BUTTON_DEFAULT_ICON")!
navigationItem.leftBarButtonItem!.setBackgroundImage(backImg, forState: .Normal, barMetrics: .Default)
有人知道如何做到这一点吗?
尝试添加自定义视图作为后退按钮,如
var backButton = UIButton(frame: CGRectMake(0, 0, 70.0, 70.0))
var backImage = UIImage(named: "backBtn")
backButton.setImage(backImage, forState: UIControlState.Normal)
backButton.titleEdgeInsets = UIEdgeInsetsMake(10.0, 10.0, 10.0, 0.0)
backButton.setTitle("Back", forState: UIControlState.Normal)
backButton.addTarget(self, action: "buttonPressed", forControlEvents: UIControlEvents.TouchUpInside)
var backBarButton = UIBarButtonItem(customView: backButton)
var spacer = UIBarButtonItem(barButtonSystemItem: UIBarButtonSystemItem.FixedSpace, target: nil, action: nil)
spacer.width = -15
self.navigationItem.leftBarButtonItems = [spacer,backBarButton]
它看起来与 iOS 后退按钮相同
这个问题我纠结了一段时间。最后我用以下代码得到了背面图像:
let backImage = navigationController?.navigationBar.subviews[2].subviews[0].subviews[0].subviews[0] as! UIImageView).image
在运行上面的代码之前,请确保显示后退按钮。然后您可以将
backImage
保存到您想要的任何位置。
这是我得到的backImage。
这是我的解决方案:
override func viewDidLoad() {
...
let buttonBack = UIBarButtonItem(image: UIImage(named: "backButton"), style: .plain, target: self, action: #selector(buttonSavePressed(_:)))
self.navigationItem.leftBarButtonItem = buttonBack
let backButton = UIButton(frame: CGRect(x: 0, y: 0, width: 24.0, height: 24.0))
let backImage = UIImage(named: "backButton")
backButton.setImage(backImage, for: .normal)
backButton.setTitle("Back", for:.normal)
if #available(iOS 13.0, *) {
backButton.setTitleColor(.link, for: .normal)
} else {
backButton.setTitleColor(.blue, for: .normal)
}
backButton.addTarget(self, action:#selector(buttonSavePressed(_:)), for: .touchUpInside)
let backBarButton = UIBarButtonItem(customView: backButton)
let spacer = UIBarButtonItem(barButtonSystemItem: .fixedSpace, target: nil, action: nil)
spacer.width = -15
self.navigationItem.leftBarButtonItems = [spacer,backBarButton]
}
@objc func buttonBackPressed(_ sender: Any) {
...
}
尝试用这个来替换后退按钮图像:
let back_image = UIImage(named: "btn_back")
self.navigationBar.backIndicatorImage = back_image
self.navigationBar.backIndicatorTransitionMaskImage = back_image
如果您不喜欢“返回”标题,您也可以添加以下内容:
self.navigationBar.topItem?.title = ""
如果想获取默认的后退按钮图片,箭头是_UINavigationBarBackIndicatorView类型的类。
以下是黑客攻击,
UIImage *imgViewBack ;
for (UIView *view in self.navigationController.navigationBar.subviews) {
// The arrow is a class of type _UINavigationBarBackIndicatorView. This is not any of the private methods, so I think
// this is fine for the AppStore...
if ([NSStringFromClass([view class]) isEqualToString:@"_UINavigationBarBackIndicatorView"]) {
// Set the image from the Default BackBtn Imageview
UIImageView *imgView = (UIImageView *) view;
if(imgView){
imgViewBack = imgView.image ;
}
}
}
此解决方案使用自定义图标并添加对后退按钮的可点击区域的控制。
import SnapKit
private func setupBackButton() {
let imageView = UIImageView()
imageView.contentMode = .scaleAspectFit
imageView.image = UIImage(named: "Back")
let button = Button()
button.addSubview(imageView)
imageView.snp.makeConstraints { make in
make.left.equalToSuperview().offset(-15)
make.centerY.equalToSuperview()
make.height.equalTo(20)
}
button.addTarget(self, action: #selector(onBack(_:)), for: .touchUpInside)
// Somehow it's not tappable without this line
button.backgroundColor = .black
let barButtonItem = UIBarButtonItem(customView: button)
navigationItem.leftBarButtonItem = barButtonItem
}