繁体   English   中英

在 Swift/SwiftUI 中仅显示日期 object 的时间

[英]Displaying only time from a Date object in Swift/SwiftUI

我一直在使用结束时间显示音频持续时间。 一位优秀的 Stack Overflow 开发人员提出了这个解决方案。

因此,我在我的观点中添加了这个:

struct ContentView: View {
    @ObservedObject var viewModel = MyViewModel() //<- here
    var body: some View {
        VStack {
            
            Text(viewModel.endTime) //<- here
            
        }
    }
}

这是我的viewModel中的代码:

class MyViewModel: ObservableObject {
    @Published var endDate: Date? 
    var endTime: String{
        endDate == nil ? "":endDate!.description 
    }

    func play(){
        let path = Bundle.main.path(forResource: "song", ofType:"mp3")!
        let url = URL(fileURLWithPath: path)
        do {
            player = try AVAudioPlayer(contentsOf: url)
            
            endDate = Date() + player.duration
            if player.isPlaying{
                
                player.pause()
                
            }
            else{
                player.play()
                
            }
            isPlaying = player.isPlaying
        }catch{print("error")}

但我得到了错误的时间(不是系统时间),但日期正确。 我只想显示不带日期的正确时间。

从 iOS 14+ 开始, Text有一个名为 style 的属性,用于显示日期。

文本日期样式

用于显示日期的预定义样式。

init(Date, style: Text.DateStyle)

创建一个使用特定样式显示本地化日期和时间的实例。 https://developer.apple.com

您不需要使用DateFormatter 使用Text()time作为样式可能就足够了。

Text(Date(), style: .time) 

在你的情况下:

Text(viewModel.endTime, style: .time)

要显示格式化的日期,您可能需要使用DateFormatter

let dateFormatter = DateFormatter()
dateFormatter.dateStyle = .medium
dateFormatter.timeStyle = .none
 
let date = Date(timeIntervalSinceReferenceDate: 118800)
 
// US English Locale (en_US)
dateFormatter.locale = Locale(identifier: "en_US")
print(dateFormatter.string(from: date)) // Jan 2, 2001

资料来源: https://developer.apple.com/documentation/foundation/dateformatter

(请注意,众所周知,创建DateFormatter是一项昂贵的操作,因此请小心不要过于频繁地创建它们)

您的视图 model 中也有几个逻辑错误。 以下是如何处理此问题的示例:

struct ContentView : View {
    @ObservedObject private var vm = MyViewModel()
    
    var body: some View {
        Button(action:{
            vm.play()
        } ) {
            Text(vm.isPlaying ? "Stop" : "Play")
        }
        Text(vm.endTime)
    }
}

class MyViewModel: ObservableObject {
    @Published var endDate: Date?
    @Published var isPlaying = false
    
    var player = AVAudioPlayer()
    var dateFormatter = DateFormatter()
    
    var endTime: String{
        guard let endDate = endDate else {
            return ""
        }
        dateFormatter.dateStyle = .none
        dateFormatter.timeStyle = .medium
        return dateFormatter.string(from: endDate)
    }

    func play(){
        do{
            if player.isPlaying {
                player.pause()
            } else {
                let path = Bundle.main.path(forResource: "All Of Me Final Mix", ofType:"mp3")!
                let url = URL(fileURLWithPath: path)
                player = try AVAudioPlayer(contentsOf: url)
                endDate = Date() + player.duration - player.currentTime
                player.play()
            }
            isPlaying = player.isPlaying
        } catch {
            print("error: \(error)")
        }
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM