Proyectos de Subversion Iphone Microlearning - Nuevo Interface

Rev

Rev 25 | Rev 29 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
//
2
//  VideoPlayerView.swift
3
//  twogetskills
4
//
5
//  Created by Efrain Yanez Recanatini on 4/24/22.
6
//
7
import Foundation
8
import SwiftUI
9
import AVKit
17 efrain 10
import Network
11
import Alamofire
12
import SwiftyJSON
1 efrain 13
 
14
struct VideoPlayerView: View {
17 efrain 15
    @EnvironmentObject private var appNavigation : AppNavigation
1 efrain 16
    @State private var timerActive : Bool = false
17
    @State private var isCompleted : Bool = false
17 efrain 18
 
1 efrain 19
    private let timer = Timer.publish(every: 1, on: .main, in: .common).autoconnect()
17 efrain 20
 
21
    private var slideModel : SlideModel
22
    private var slideTitle : String
23
 
24
 
25
    private var url : URL?
1 efrain 26
    private var playerItem : AVPlayerItem
27
    private var player : AVPlayer
17 efrain 28
    private var appData = AppData.sharedInstance
1 efrain 29
 
17 efrain 30
    init()
1 efrain 31
    {
17 efrain 32
        print("urlExternalDownloaded : \(appData.urlExternalDownloaded)")
33
        self.url = URL(string: appData.urlExternalDownloaded)
34
 
1 efrain 35
        let slideDao = SlideDao.sharedInstance
17 efrain 36
        self.slideModel = slideDao.selectByUuid(uuid: appData.slideUuidActive)
1 efrain 37
 
17 efrain 38
        print("videoplayer appData slideUuid : \(appData.slideUuidActive)")
39
        print("videoplayer slideModel slideUuid : \(self.slideModel.uuid)")
40
 
1 efrain 41
        if self.slideModel.name.count > Constants.APP_BAR_TITLE_MAX_LENGTH {
42
            slideTitle = String(Array(self.slideModel.name)[0...Constants.APP_BAR_TITLE_MAX_LENGTH]) + "..."
43
        } else {
44
            slideTitle = self.slideModel.name
45
        }
46
 
28 efrain 47
        let headerSecurity = HeaderSecurity()
48
 
49
              let headers: [String: String] = [
50
                  Constants.HTTP_HEADER_ACCEPT: Constants.HTTP_HEADER_ACCEPT_VALUE,
51
                  Constants.HTTP_HEADER_SECURITY_RAND: String(headerSecurity.rand),
52
                  Constants.HTTP_HEADER_SECURITY_TOKEN: appData.deviceUuid,
53
                  Constants.HTTP_HEADER_SECURITY_CREATED: String(headerSecurity.created) ,
54
                  Constants.HTTP_HEADER_SECURITY_SECRET: headerSecurity.secret,
55
              ]
56
 
57
              let assets = AVURLAsset(url: self.url!, options: ["AVURLAssetHTTPHeaderFieldsKey": headers])
58
 
1 efrain 59
        playerItem = AVPlayerItem(asset: assets)
60
        let newTime : CMTime = CMTimeMakeWithSeconds(0, preferredTimescale:1)
61
 
62
        player = AVPlayer(playerItem: playerItem)
63
        player.seek(to: newTime)
17 efrain 64
 
1 efrain 65
    }
66
 
67
    var body: some View {
68
        VStack(spacing: 0) {
8 efrain 69
 
17 efrain 70
 
1 efrain 71
            HStack {
72
                Button(action: {
23 efrain 73
 
74
 
75
 
21 efrain 76
                    backToGallery()
1 efrain 77
                }, label: {
78
                    Image(systemName: "chevron.backward")
79
                    .frame(width: 32, height: 32, alignment: /*@START_MENU_TOKEN@*/.center/*@END_MENU_TOKEN@*/)
80
                    .aspectRatio(contentMode: .fit)
81
                    .foregroundColor(Color("color_app_bar_foreground"))
82
                })
83
                .padding(.leading, 16)
84
 
85
                Text(self.slideTitle)
86
                .font(Font.custom(Config.FONT_NAME_REGULAR, size: Config.FONT_SIZE_APP_BAR_HEAD1 ))
87
                .foregroundColor(Color("color_app_bar_foreground"))
88
                    .padding(.leading, 4)
89
 
90
                Spacer()
91
            }
92
            .background(Color("color_app_bar_background"))
93
            .edgesIgnoringSafeArea(.top)
94
            .frame(height: 50)
95
            Divider()
17 efrain 96
 
1 efrain 97
 
17 efrain 98
            GeometryReader { geometry in
99
 
100
                VideoPlayer(player: player)
101
                .onAppear() {
102
                    player.play()
103
                }
104
                .onDisappear() {
105
                    player.pause()
106
                }
107
 
108
                .onReceive(timer, perform: { _ in
109
                    let duration =  CMTimeGetSeconds(playerItem.asset.duration)
110
                    if duration > 0 {
111
 
112
                        let currentTime =  CMTimeGetSeconds(playerItem.currentTime())
113
                            let diference = duration - currentTime
25 efrain 114
 
115
                        print("duration: \(duration) currentTime : \(currentTime) diference: \(diference) ")
116
 
17 efrain 117
                            if diference < 10 {
118
                                self.isCompleted = true;
23 efrain 119
                            } else if diference <= 0 {
25 efrain 120
                                self.isCompleted = true;
121
 
17 efrain 122
                                self.timer.upstream.connect().cancel()
123
                                timerActive = false
21 efrain 124
                                backToGallery()
17 efrain 125
                            }
23 efrain 126
 
127
 
17 efrain 128
                        }
129
                    })
11 efrain 130
            }
1 efrain 131
        }
132
    }
133
 
21 efrain 134
    private func backToGallery()
135
    {
136
        if self.url != nil {
137
            do {
138
                try FileManager.default.removeItem(at: self.url!)
139
                       print("Video temporal borrado")
140
             } catch {
141
                print(error)
142
            }
143
        }
144
 
145
        let dataService = DataService()
146
        if self.isCompleted {
147
            dataService.completeSlide(slide: slideModel)
148
        } else {
149
            dataService.incompleteSlide(slide: slideModel)
150
        }
151
 
152
        if self.timerActive {
153
            self.timer.upstream.connect().cancel()
154
        }
155
 
156
        AppDelegate.orientationLock = UIInterfaceOrientationMask.portrait
157
        UIDevice.current.setValue(UIInterfaceOrientation.portrait.rawValue, forKey: "orientation")
158
        UIViewController.attemptRotationToDeviceOrientation()
159
 
160
 
161
        appNavigation.pageActive = .home
162
    }
1 efrain 163
 
21 efrain 164
 
1 efrain 165
 
166
 
167
}
168
 
169
 
170
struct VideoPlayerView_Previews: PreviewProvider {
171
    static var previews: some View {
17 efrain 172
        VideoPlayerView()
1 efrain 173
    }
174
}
175