How to set a navigation bar in clear / transparent background in SwiftUI?

prosmith

I am trying to figure out how to write a code for a custom navigation bar to display clear / transparent bar not "white" bar. See this screenshot: https://pasteboard.co/IBYJDtx.png

Here is my code:

import SwiftUI

struct ContentView: View {

init() {

    UINavigationBar.appearance().tintColor = .clear
    UINavigationBar.appearance().backgroundColor = .clear
}

var body: some View {

    NavigationView {
         ZStack {
              Color(.lightGray).edgesIgnoringSafeArea(.all)
                VStack() {
                    Spacer()
                    Text("Hello").foregroundColor(.white)
                    Spacer()
                }
            }
            .navigationBarTitle(Text("First View"), displayMode: .inline)
        }
    }
}

struct ContentView_Previews: PreviewProvider {
    static var previews: some View {
       ContentView()

 }
}

Does anybody know what is wrong with it? Any suggestion appreciated.

hightech

I tried to run your code on my Xcode. I received the same results like yours. I found a good solution to fix this issue. You just need to add a few lines of code into your init(). Here is the solution:

import SwiftUI

struct ContentView: View {

     init() {

          UINavigationBar.appearance().setBackgroundImage(UIImage(), for: UIBarMetrics.default)
          UINavigationBar.appearance().shadowImage = UIImage()
          UINavigationBar.appearance().isTranslucent = true
          UINavigationBar.appearance().tintColor = .clear
          UINavigationBar.appearance().backgroundColor = .clear
     }

     var body: some View {

          NavigationView {
              ZStack {
                  Color(.lightGray).edgesIgnoringSafeArea(.all)
                  VStack() {
                      Spacer()
                      Text("Hello").foregroundColor(.white)
                      Spacer()
                  }
             }
              .navigationBarTitle(Text("First View"), displayMode: .inline)
          }
       }
    }

   struct ContentView_Previews: PreviewProvider {
          static var previews: some View {
             ContentView()

          }
    }

I hope that helps you.

Collected from the Internet

Please contact [email protected] to delete if infringement.

edited at
0

Comments

0 comments
Login to comment

Related

Set navigation bar background image

How to set a transparent background of JPanel?

How to set transparent background of JDialog

How do I set my status bar transparent but keep by navigation bar black?

transparent navigation bar ios

UIWebView background is set to Clear Color, but it is not transparent

Background color on Navigation Bar is not set when my SwiftUI based app is launched in landscape mode

How to set a transparent navigation bar? iOS 11 swift 4 Xcode 9

Transparent navigation bar glitch

How to customize navigation bar in swiftui

How can I change the background color of the navigation bar in SwiftUI?

How to set completely transparent navigation bar (NOT TRANSLUCENT) and keep receiving window inset updates

How to ignore SwiftUI modal background, or make modal background clear/transparent?

How to make a semi-transparent Navigation Bar in SwiftUI?

How can I change my SwiftUI background without losing the navigation bar UI?

How to make background of List cells transparent in SwiftUI?

How to make the navigation bar transparent

How to set a control to a transparent background

How to set a button background to transparent?

set background image of navigation's bar item

How to set a tab background as transparent?

Android: How to set status bar and navigation bar semi transparent

Custom Navigation Bar Android - Quarter Screen Height and Transparent Background

SwiftUI Textfield - How to set the background Color for textfield in edit mode to clear

How to make a transparent bottom navigation bar in flutter

How to set the background color of system navigation bar to the one of the new Bottom Navigation bar in Material 3? (Android)

SwiftUI: How to generate a Map Route with transparent background?

How to make SwiftUI TabBar background always transparent

How to force navigation bar to show background in SwiftUI?

TOP Ranking

  1. 1

    Failed to listen on localhost:8000 (reason: Cannot assign requested address)

  2. 2

    Loopback Error: connect ECONNREFUSED 127.0.0.1:3306 (MAMP)

  3. 3

    How to import an asset in swift using Bundle.main.path() in a react-native native module

  4. 4

    pump.io port in URL

  5. 5

    Compiler error CS0246 (type or namespace not found) on using Ninject in ASP.NET vNext

  6. 6

    BigQuery - concatenate ignoring NULL

  7. 7

    ngClass error (Can't bind ngClass since it isn't a known property of div) in Angular 11.0.3

  8. 8

    ggplotly no applicable method for 'plotly_build' applied to an object of class "NULL" if statements

  9. 9

    Spring Boot JPA PostgreSQL Web App - Internal Authentication Error

  10. 10

    How to remove the extra space from right in a webview?

  11. 11

    java.lang.NullPointerException: Cannot read the array length because "<local3>" is null

  12. 12

    Jquery different data trapped from direct mousedown event and simulation via $(this).trigger('mousedown');

  13. 13

    flutter: dropdown item programmatically unselect problem

  14. 14

    How to use merge windows unallocated space into Ubuntu using GParted?

  15. 15

    Change dd-mm-yyyy date format of dataframe date column to yyyy-mm-dd

  16. 16

    Nuget add packages gives access denied errors

  17. 17

    Svchost high CPU from Microsoft.BingWeather app errors

  18. 18

    Can't pre-populate phone number and message body in SMS link on iPhones when SMS app is not running in the background

  19. 19

    12.04.3--- Dconf Editor won't show com>canonical>unity option

  20. 20

    Any way to remove trailing whitespace *FOR EDITED* lines in Eclipse [for Java]?

  21. 21

    maven-jaxb2-plugin cannot generate classes due to two declarations cause a collision in ObjectFactory class

HotTag

Archive