Создание пользовательской кнопки «Назад» в моем приложении

Я пытаюсь изменить внешний вид кнопки «Назад» контроллера навигации по умолчанию в своем приложении.

Я хотел бы использовать и изображение (значок) и удалить текст «Назад». Этот код растягивает изображение по кнопке и не удаляет заголовок кнопки.

let backImg: UIImage = UIImage(named: "icon_back")!
UIBarButtonItem.appearance().setBackButtonBackgroundImage(backImg, for: .normal, barMetrics: .default)

Рекомендация, как это сделать внутри AppDelegate (didFinishLaunchingWithOptions)?


person Sanae Ariuop    schedule 08.08.2017    source источник
comment
Создайте с ним базовый подкласс UIViewController.   -  person El Tomato    schedule 08.08.2017
comment
@ElTomato Можете ли вы объяснить это немного подробнее, пожалуйста? Спасибо за помощь.   -  person Sanae Ariuop    schedule 08.08.2017


Ответы (2)


Простой способ сделать это просто создать один BaseViewController для вашего проекта, который является производным от UIViewController. Вы можете использовать общий метод в BaseViewController, чтобы создать свой custom leftBarButton в каждом viewController. Оставшийся viewController в вашем проекте должен быть derived from this BaseViewController,

class BaseViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        createLeftBarButton(image: #Pass image here#, width: #Pass width of your image view#) // Create custom back bar button.
    }

    /**Create cutom back bar button*/
    func createLeftBarButton(image: UIImage?, width: CGFloat) {

        let backButton: UIButton = UIButton(frame: CGRect(x: 0, y: 0, width: width, height: 50))
        backButton.imageView?.contentMode = .scaleAspectFill
        backButton.imageView?.bounds = CGRect(x: 0, y: 0, width: width, height: width)
        backButton.setImage(image, for: .normal)
        backButton.setImage(image, for: .highlighted)
        backButton.addTarget(self, action: #selector(leftBarButtonItemPressed(_:)), for: .touchUpInside)

        let leftItem: UIBarButtonItem = UIBarButtonItem(customView: backButton)
        navigationItem.leftBarButtonItem = leftItem

    }

    /**Custom back bar button pressed. So handle here*/
    func leftBarButtonItemPressed(_ sender: UIButton) {

        view.endEditing(true) // End editing if any.
        if isViewControllerPresented() { // Check view controller is presented or pushed
            dismiss(animated: true, completion: nil) // Dismiss ViewController if presented
        } else {
            _ = navigationController?.popViewController(animated: true) // Pop ViewController if pushed
        }

    }

    /**To check whether view controller is presented or pushed.*/
    func isViewControllerPresented() -> Bool {

        if self.presentingViewController?.presentedViewController == self {
            return true
        }
        if (self.navigationController != nil && self.navigationController?.presentingViewController?.presentedViewController == self.navigationController) && self.navigationController?.viewControllers.count == 1 {
            return true
        }
        if self.tabBarController?.presentingViewController is UITabBarController {
            return true
        }
        return false

    }

  }

// Sub class your remaining viewControllers like this.
class FirstViewController: BaseViewController {

    override func viewDidLoad() {
        super.viewDidLoad() // When calling this super method, the custom back bar button will be created for you
    }

}

Спасибо.

person Karthick Selvaraj    schedule 08.08.2017

Вы можете сделать это, установив navigationItem BackButtonBackgroundImage;

также вы можете установить внешний вид для глобального эффекта:

let item = UIBarButtonItem.appearance(whenContainedInInstancesOf: [UINavigationBar.self]) item.setBackButtonBackgroundVerticalPositionAdjustment(-10, for: .default) item.setBackButtonBackgroundImage(youImage, for: .normal, barMetrics: .default)


для удаления заднего заголовка вы можете сделать следующее:

@implementation UINavigationItem (BackItem)

-(UIBarButtonItem *)backBarButtonItem { UIBarButtonItem *item = [[UIBarButtonItem alloc] initWithTitle:@" " style:UIBarButtonItemStylePlain target:nil action:nil]; item.tintColor = [UIColor darkGrayColor]; return item; }

@end

person BruceLiu    schedule 08.08.2017