簡體   English   中英

使用 swift 語言更改按鈕背景顏色

[英]Change button background color using swift language

我是 swift 語言的新手。 有人可以告訴我如何使用 swift 語言更改按鈕的背景顏色嗎?

button.backgroundColor = UIColor.blue

或任何其他顏色: redgreenyellow等。

另一種選擇是 RGBA 顏色:

button.backgroundColor = UIColor(red: 0.4, green: 1.0, blue: 0.2, alpha: 0.5)

試試這個,你需要像這樣添加255

button.backgroundColor = UIColor(red: 102/255, green: 250/255, blue: 51/255, alpha: 0.5)

更新 xcode 8 和 swift 3,指定常用顏色,如:

button.backgroundColor = UIColor.blue

Color()已被刪除。

如果你想以編程方式設置按鈕的背景顏色,那么這段代碼會很好地幫助你

斯威夫特 3 和斯威夫特 4

self.yourButton.backgroundColor = UIColor.red

Swift 2.3 或更低版本

self.yourButton.backgroundColor = UIColor.redColor()

使用 RGB

self.yourButton.backgroundColor = UIColor(red: 102/255, green: 250/255, blue: 51/255, alpha: 0.5)

或者您可以使用浮點值

button.backgroundColor = UIColor(red: 0.4, green: 1.0, blue: 0.2, alpha: 0.5)

您可以使用 getRed 函數設置按鈕的背景顏色。
假設您有:

  1. 一個稱為按鈕的 UIButton,以及
  2. 您想將按鈕的背景顏色更改為某個已知的 RBG 值

然后,將以下代碼放在要更改 UIButton 的背景顏色的函數中

var r:CGFloat = 0
var g:CGFloat = 0
var b:CGFloat = 0
var a:CGFloat = 0

// This will be some red-ish color
let color = UIColor(red: 200.0/255.0, green: 16.0/255.0, blue: 46.0/255.0, alpha: 1.0) 

if color.getRed(&r, green: &g, blue: &b, alpha: &a){
    button.backgroundColor = UIColor(red: r, green: g, blue: b, alpha: a)
}

Swift 4,5 使用多種方式添加背景顏色。

1.使用以下代碼設置按鈕顏色

button.backgroundColor = UIColor.blue 
**OR**
button.backgroundColor = .blue

2.使用RGB顏色:紅色,綠色,黃色等。

button.backgroundColor = UIColor(red: 0.1, green: 0.9, blue: 1.0, alpha: 1.0)

3.使用 255 如下

button.backgroundColor = UIColor(red: 203/255, green: 95/255, blue: 173/255, alpha: 1.0)

4.使用 UIColor 擴展如下

extension UIColor {
    convenience init(hex: String) {
        let scanner = Scanner(string: hex)
        scanner.scanLocation = 0
        
        var rgbColorValue: UInt64 = 0
        
        scanner.scanHexInt64(&rgbColorValue)
        
        let r = (rgbColorValue & 0xff0000) >> 16
        let g = (rgbColorValue & 0xff00) >> 8
        let b = rgbColorValue & 0xff
        
        self.init(
            red: CGFloat(r) / 0xff,
            green: CGFloat(g) / 0xff,
            blue: CGFloat(b) / 0xff, alpha: 1
        )
    }
}

如何使用

button.backgroundColor = UIColor(hex:"FFFFFF")

U 還可以圍繞 tintcolor 和 button image 來間接改變顏色。

/*Swift-5 update*/

let tempBtn: UIButton = UIButton(frame: CGRect(x: 5, y: 20, width: 40, height: 40))       
tempBtn.backgroundColor = UIColor.red

要更改按鈕的背景顏色,請使用:

yourBtn.backgroundColor = UIColor.black

如果您使用storyBoard ,請確保您已將您的storyBoard與您的viewController連接,並且您的項目已鏈接。

如果您不知道如何執行此操作,請查看下一個鏈接:

如何將 ViewController.swift 連接到 Storyboard 中的 ViewController?

斯威夫特 3

RGB 顏色

btnLogin.backgroundColor = UIColor.init(colorLiteralRed: (100/255), green: (150/255), blue: (200/255), alpha: 1)

使用本機顏色

btnLogin.backgroundColor = UIColor.darkGray

斯威夫特 4:

您可以輕松使用十六進制代碼:

self.backgroundColor = UIColor(hexString: "#ff259F6C")

self.layer.shadowColor = UIColor(hexString: "#08259F6C").cgColor

十六進制顏色代碼的擴展

extension UIColor {
    convenience init(hexString: String, alpha: CGFloat = 1.0) {
        let hexString: String = hexString.trimmingCharacters(in: CharacterSet.whitespacesAndNewlines)
        let scanner = Scanner(string: hexString)
        if (hexString.hasPrefix("#")) {
            scanner.scanLocation = 1
        }
        var color: UInt32 = 0
        scanner.scanHexInt32(&color)
        let mask = 0x000000FF
        let r = Int(color >> 16) & mask
        let g = Int(color >> 8) & mask
        let b = Int(color) & mask
        let red   = CGFloat(r) / 255.0
        let green = CGFloat(g) / 255.0
        let blue  = CGFloat(b) / 255.0
        self.init(red:red, green:green, blue:blue, alpha:alpha)
    }
    func toHexString() -> String {
        var r:CGFloat = 0
        var g:CGFloat = 0
        var b:CGFloat = 0
        var a:CGFloat = 0
        getRed(&r, green: &g, blue: &b, alpha: &a)
        let rgb:Int = (Int)(r*255)<<16 | (Int)(g*255)<<8 | (Int)(b*255)<<0
        return String(format:"#%06x", rgb)
    }
}

將要更改其背景的 UIButton 作為 OUTlet 連接到 ViewController.swift 文件后,您可以使用以下內容:

 yourUIButton.backgroundColor = UIColor.blue

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM