后退按钮图像 - 在 Swift 中它叫什么?

问题描述 投票:0回答:6

我正在尝试使用 Swift 的内部后退按钮图像。 我之前问过这个问题,并得到了技术上正确的答案,它继承了之前的视图,但是如果我插入此代码,您可以控制当前视图上的后退按钮。

// 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)

有人知道如何做到这一点吗?

swift uinavigationbar back-button
6个回答
11
投票

尝试添加自定义视图作为后退按钮,如

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 后退按钮相同


6
投票

这个问题我纠结了一段时间。最后我用以下代码得到了背面图像:

let backImage = navigationController?.navigationBar.subviews[2].subviews[0].subviews[0].subviews[0] as! UIImageView).image

在运行上面的代码之前,请确保显示后退按钮。然后您可以将

backImage
保存到您想要的任何位置。

这是我得到的backImage


1
投票

这是我的解决方案:

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) {

 ...
}


0
投票

如果想获取默认的后退按钮图片,箭头是_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 ;
                }
            }
        }

0
投票

尝试用这个来替换后退按钮图像:

let back_image = UIImage(named: "btn_back")
self.navigationBar.backIndicatorImage = back_image
self.navigationBar.backIndicatorTransitionMaskImage = back_image

如果您不喜欢“返回”标题,您也可以添加以下内容:

self.navigationBar.topItem?.title = ""

0
投票

此解决方案使用自定义图标并添加对后退按钮的可点击区域的控制。


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.right.equalToSuperview()
         make.centerY.equalToSuperview()
         make.width.equalTo(50)
         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
}
© www.soinside.com 2019 - 2024. All rights reserved.