Compare commits
2 Commits
ivan/mergi
...
loewy/asyn
| Author | SHA1 | Date | |
|---|---|---|---|
| 2d953c4c46 | |||
| 7a6afd52a3 |
@@ -24,7 +24,7 @@ class SideLoadedTextTrackList {
|
|||||||
}
|
}
|
||||||
val sideLoadedTextTrackList = SideLoadedTextTrackList()
|
val sideLoadedTextTrackList = SideLoadedTextTrackList()
|
||||||
for (i in 0 until src.size()) {
|
for (i in 0 until src.size()) {
|
||||||
val textTrack: ReadableMap = src.getMap(i)
|
val textTrack: ReadableMap = src.getMap(i) ?: continue
|
||||||
sideLoadedTextTrackList.tracks.add(SideLoadedTextTrack.parse(textTrack))
|
sideLoadedTextTrackList.tracks.add(SideLoadedTextTrack.parse(textTrack))
|
||||||
}
|
}
|
||||||
return sideLoadedTextTrackList
|
return sideLoadedTextTrackList
|
||||||
|
|||||||
@@ -228,7 +228,7 @@ class Source {
|
|||||||
if (propSrcHeadersArray != null) {
|
if (propSrcHeadersArray != null) {
|
||||||
if (propSrcHeadersArray.size() > 0) {
|
if (propSrcHeadersArray.size() > 0) {
|
||||||
for (i in 0 until propSrcHeadersArray.size()) {
|
for (i in 0 until propSrcHeadersArray.size()) {
|
||||||
val current = propSrcHeadersArray.getMap(i)
|
val current = propSrcHeadersArray.getMap(i) ?: continue
|
||||||
val key = if (current.hasKey("key")) current.getString("key") else null
|
val key = if (current.hasKey("key")) current.getString("key") else null
|
||||||
val value = if (current.hasKey("value")) current.getString("value") else null
|
val value = if (current.hasKey("value")) current.getString("value") else null
|
||||||
if (key != null && value != null) {
|
if (key != null && value != null) {
|
||||||
|
|||||||
@@ -288,12 +288,22 @@ class VideoEventEmitter {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private class VideoEvent(
|
||||||
|
surfaceId: Int,
|
||||||
|
viewId: Int,
|
||||||
|
private val name: String,
|
||||||
|
private val data: WritableMap?
|
||||||
|
) : Event<VideoEvent>(surfaceId, viewId) {
|
||||||
|
override fun getEventName() = name
|
||||||
|
override fun getEventData() = data
|
||||||
|
}
|
||||||
|
|
||||||
private class EventBuilder(private val surfaceId: Int, private val viewId: Int, private val dispatcher: EventDispatcher) {
|
private class EventBuilder(private val surfaceId: Int, private val viewId: Int, private val dispatcher: EventDispatcher) {
|
||||||
fun dispatch(event: EventTypes, paramsSetter: (WritableMap.() -> Unit)? = null) =
|
fun dispatch(event: EventTypes, paramsSetter: (WritableMap.() -> Unit)? = null) {
|
||||||
dispatcher.dispatchEvent(object : Event<Event<*>>(surfaceId, viewId) {
|
val eventName = "top${event.eventName.removePrefix("on")}"
|
||||||
override fun getEventName() = "top${event.eventName.removePrefix("on")}"
|
val eventData = Arguments.createMap().apply(paramsSetter ?: {})
|
||||||
override fun getEventData() = Arguments.createMap().apply(paramsSetter ?: {})
|
dispatcher.dispatchEvent(VideoEvent(surfaceId, viewId, eventName, eventData))
|
||||||
})
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun audioTracksToArray(audioTracks: java.util.ArrayList<Track>?): WritableArray =
|
private fun audioTracksToArray(audioTracks: java.util.ArrayList<Track>?): WritableArray =
|
||||||
|
|||||||
@@ -91,6 +91,7 @@ const Video = forwardRef<VideoRef, ReactVideoProps>(
|
|||||||
onError,
|
onError,
|
||||||
onReadyForDisplay,
|
onReadyForDisplay,
|
||||||
onSeek,
|
onSeek,
|
||||||
|
onSeekComplete,
|
||||||
onVolumeChange,
|
onVolumeChange,
|
||||||
onEnd,
|
onEnd,
|
||||||
onPlaybackStateChanged,
|
onPlaybackStateChanged,
|
||||||
@@ -488,7 +489,16 @@ const Video = forwardRef<VideoRef, ReactVideoProps>(
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
onSeeking={() => (isSeeking.current = true)}
|
onSeeking={() => (isSeeking.current = true)}
|
||||||
onSeeked={() => (isSeeking.current = false)}
|
onSeeked={() => {
|
||||||
|
(isSeeking.current = false)
|
||||||
|
|
||||||
|
onSeekComplete?.({
|
||||||
|
currentTime: (nativeRef.current?.currentTime || 0.0) - cropStartSeconds,
|
||||||
|
seekTime: 0.0,
|
||||||
|
target: 0.0,
|
||||||
|
|
||||||
|
})
|
||||||
|
}}
|
||||||
onVolumeChange={() => {
|
onVolumeChange={() => {
|
||||||
if (!nativeRef.current) {
|
if (!nativeRef.current) {
|
||||||
return;
|
return;
|
||||||
|
|||||||
Reference in New Issue
Block a user