iOS change navigation bar title font and color

后端 未结 18 666
青春惊慌失措
青春惊慌失措 2020-12-04 08:40

So i have this code that should change the nav bar title font, but it doenst

    NSDictionary *attributes = [NSDictionary dictionaryWithObjectsAndKeys:[UIFon         


        
相关标签:
18条回答
  • 2020-12-04 08:47

    Here is an answer for Swift 4

    0 讨论(0)
  • 2020-12-04 08:52

    There is nothing wrong with the other answers. I'm just sharing the storyboard version for setting the font.

    1. Select Your Navigation Bar within your Navigation Controller

    2. Change the Title Font in the Attributes Inspector

    (You will likely need to toggle the Bar Tint for the Navigation Bar before Xcode picks up the new font)

    Notes (Caveats)

    Verified that this does work on Xcode 7.1.1+. (See the Samples below)

    1. You do need to toggle the nav bar tint before the font takes effect (seems like a bug in Xcode; you can switch it back to default and font will stick)
    2. If you choose a system font ~ Be sure to make sure the size is not 0.0 (Otherwise the new font will be ignored)

    1. Seems like this works with no problem when only one NavBar is in the view hierarchy. It appears that secondary NavBars in the same stack are ignored. (Note that if you show the master navigation controller's navBar all the other custom navBar settings are ignored).

    Gotchas (deux)

    Some of these are repeated which means they are very likely worth noting.

    1. Sometimes the storyboard xml gets corrupt. This requires you to review the structure in Storyboard as Source Code mode (right click the storyboard file > Open As ...)
    2. In some cases the navigationItem tag associated with user defined runtime attribute was set as an xml child of the view tag instead of the view controller tag. If so remove it from between the tags for proper operation.
    3. Toggle the NavBar Tint to ensure the custom font is used.
    4. Verify the size parameter of the font unless using a dynamic font style
    5. View hierarchy will override the settings. It appears that one font per stack is possible.

    Result

    Samples

    • Video Showing Multiple Fonts In Advanced Project
    • Simple Source Download
    • Advanced Project Download ~ Shows Multiple NavBar Fonts & Custom Font Workaround
    • Video Showing Multiple Fonts & Custom Fonts

    Handling Custom Fonts

    Note ~ A nice checklist can be found from the Code With Chris website and you can see the sample download project.

    If you have your own font and want to use that in your storyboard, then there is a decent set of answers on the following SO Question. One answer identifies these steps.

    1. Get you custom font file(.ttf,.ttc)
    2. Import the font files to your Xcode project
    3. In the app-info.plist,add a key named Fonts provided by application.It's an array type , add all your font file names to the array,note:including the file extension.
    4. In the storyboard , on the NavigationBar go to the Attribute Inspector,click the right icon button of the Font select area.In the popup panel , choose Font to Custom, and choose the Family of you embeded font name.

    Custom Font Workaround

    So Xcode naturally looks like it can handle custom fonts on UINavigationItem but that feature is just not updating properly (The font selected is ignored).

    To workaround this:

    One way is to fix using the storyboard and adding a line of code: First add a UIView (UIButton, UILabel, or some other UIView subclass) to the View Controller (Not the Navigation Item...Xcode is not currently allowing one to do that). After you add the control you can modify the font in the storyboard and add a reference as an outlet to your View Controller. Just assign that view to the UINavigationItem.titleView. You could also set the text name in code if necessary. Reported Bug (23600285).

    @IBOutlet var customFontTitleView: UIButton!
    
    //Sometime later...    
    self.navigationItem.titleView = customFontTitleView
    
    0 讨论(0)
  • 2020-12-04 08:52

    iOS 11

    Objective-C

    if (@available(iOS 11.0, *)) {
        self.navigationController.navigationItem.largeTitleDisplayMode =  UINavigationItemLargeTitleDisplayModeAlways;
        self.navigationController.navigationBar.prefersLargeTitles = true;
    
    // Change Color
        self.navigationController.navigationBar.largeTitleTextAttributes = @{NSForegroundColorAttributeName: [UIColor whiteColor]};
    
    } else {
        // Fallback on earlier versions
    }
    
    0 讨论(0)
  • 2020-12-04 08:53

    Swift:-

    self.navigationController?.navigationBar.titleTextAttributes = [NSAttributedStringKey.foregroundColor: UIColor.white, NSAttributedStringKey.font: UIFont(name:"Love Nature", size: 40)!]
    
    0 讨论(0)
  • 2020-12-04 08:55

    It's a bit more readable using literals:

    self.navigationController.navigationBar.titleTextAttributes = @{
                                                                  NSFontAttributeName:[UIFont fontWithName:@"mplus-1c-regular" size:21],
                                                                  NSForegroundColorAttributeName: [UIColor whiteColor]
                                                                  };
    
    0 讨论(0)
  • 2020-12-04 08:55

    Working in swift 3.0 For changing the title color you need to add titleTextAttributes like this

            let textAttributes = [NSForegroundColorAttributeName:UIColor.white]
            self.navigationController.navigationBar.titleTextAttributes = textAttributes
    
    For changing navigationBar background color you can use this
            self.navigationController.navigationBar.barTintColor = UIColor.white
    
    For changing navigationBar back title and back arrow color you can use this
           self.navigationController.navigationBar.tintColor = UIColor.white
    
    0 讨论(0)
提交回复
热议问题