更改 SegementedPickerStyle 的背景颜色UIKit 和 SwiftUI

问题描述

我在 SwiftUI 中使用 Picker 视图在 3 页中的 1 页之间导航。但是,我很难弄清楚如何自定义 SegmentedPickerStyle。

我对选择器的设想非常简单......它看起来像:

Feed | For You | Tools

事情是,而不是看起来像按钮(如 SegmentedPickerStyle 认情况下),它只是文本,使用下划线表示 selectedSegment Here's a mockup of what I mean

到目前为止,我只能想出如何自定义

  1. 整个 Picker 的字体颜色
  2. SelectedSegment 的背景 颜色
  3. 整个 Picker 的背景颜色,但是,由于某种原因,它不适用于 UIColor.clear 或 UIColor.White 吗?

我能够自定义选择器的唯一方法是覆盖 SwiftUI 继承自的 UIKit 组件 UISegmentedControl

这是我的代码

import SwiftUI

enum HoMetab: String,CaseIterable {
    case Feed = "Feed"
    case ForYou = "For You"
    case Tools = "Tools"
}

struct SelectedHoMetab: View {
    @Binding var selectedTab: HoMetab
    
    var body: some View {
        switch selectedTab {
        case .Feed:
            Text("Feed!")
        case .ForYou:
            Text("For you!")
        case .Tools:
            Text("Tools!")
        }
    }
}


    struct HomeView: View {
        @State private var currentTab: HoMetab = .ForYou
        
        // Change SegementedPicker styling
        init() {
            UISegmentedControl.appearance().selectedSegmentTintColor = UIColor(named: "navyBlue") // custom asset color (what i want the underline to be)
            UISegmentedControl.appearance().setTitleTextAttributes([.foregroundColor : UIColor.white],for: .selected)
            UISegmentedControl.appearance().backgroundColor = UIColor.clear
        }
        
        var body: some View {
            vstack {
                Picker("",selection: $currentTab) {
                    ForEach(HoMetab.allCases,id: \.self) {
                        Text($0.rawValue)
                    }
                }
                .pickerStyle(SegmentedPickerStyle())
                .padding(.bottom)
                .padding(.horizontal)
                
                
                SelectedHoMetab(selectedTab: self.$currentTab)
            }
        }
    }
    
    
    struct HoMetab_Previews: PreviewProvider {
        static var previews: some View {
            HomeView()
        }
    }

现在把我的头撞在墙上几个小时……非常感谢任何帮助;谢谢!

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...