This repository has been archived by the owner on Feb 22, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 9.8k
[video_player] Caching for network data source #2429
Closed
Closed
Changes from all commits
Commits
Show all changes
128 commits
Select commit
Hold shift + click to select a range
76d56ca
Adds support for holes in polygon overlays to the Google Maps plugin
sanekyy 8826721
Add name and contact info to the AUTHORS file
sanekyy 9252dc4
fix holes generating in example
sanekyy a4eeab5
Merge branch 'master' into polygon_holes
sanekyy 1b26908
merge with upstream/master
sanekyy 01bd55c
Merge remote-tracking branch 'upstream/master' into polygon_holes
sanekyy 69d3889
Merge remote-tracking branch 'upstream/master' into polygon_holes
sanekyy 18137c2
change version to 0.5.19
sanekyy a86e25f
Merge remote-tracking branch 'upstream/master' into polygon_holes
sanekyy e866736
change version to 0.5.20
sanekyy 0d404b4
Merge remote-tracking branch 'upstream/master' into polygon_holes
sanekyy 32ee443
fix format
sanekyy 71c45b5
Merge remote-tracking branch 'upstream/master'
sanekyy 4f24a58
Merge branch 'polygon_holes'
sanekyy 5233c0d
fix format
sanekyy a952a34
Merge remote-tracking branch 'upstream/master'
sanekyy 1faf0d4
Merge branch 'master' into polygon_holes
sanekyy b4ae7bf
Merge remote-tracking branch 'upstream/master'
sanekyy 49d08b3
Merge branch 'master' into polygon_holes
sanekyy b526132
Merge remote-tracking branch 'upstream/master'
sanekyy 2d55631
Merge branch 'master' into polygon_holes
sanekyy 7871f33
Merge remote-tracking branch 'upstream/master'
sanekyy 185f67b
Merge branch 'master' into polygon_holes
sanekyy 14136d5
Merge remote-tracking branch 'upstream/master'
sanekyy 4283ce0
Merge branch 'master' into polygon_holes
sanekyy af1c9b0
add additional documentation about what is a hole
sanekyy 242aa87
migrate to Maps SDK v3
sanekyy 9255eac
add missed maps sdk aar
sanekyy 670f24a
remove unnecessary maps-sdk .arr from android/libs and add to example…
sanekyy 93535a0
add maps sdk v3 back
sanekyy c12ad1d
Revert "add maps sdk v3 back"
sanekyy d5fda58
Revert "remove unnecessary maps-sdk .arr from android/libs and add to…
sanekyy fc21131
Tile overlays
otopba 1289d4f
handle null tile
otopba edb0456
Add worker class
otopba 8edbf83
Merge branch 'tile_overlays'
sanekyy 0ee16bf
Merge branch 'google_maps_v3'
sanekyy 6eb491e
fix
otopba 47a7d67
handle initial state
otopba fa9b814
Merge branch 'tile_overlays'
otopba f3af72a
fix initial state
otopba 4ff7ebb
Merge branch 'tile_overlays'
otopba 9c0bcfc
updateInitialTileOverlays
otopba 94a9131
updateInitialTileOverlays
otopba b1812a3
add clearTileCache method
otopba 085385d
Merge pull request #1 from sanekyy/tile_overlays
otopba 0dd67f7
[video_player] Add caching on Android
999eagle 042037b
[video_player] Make caching configurable
999eagle fa0d54c
[video_player] Add video caching on iOS
999eagle 262ca38
[video_player] Change cache arguments to int
999eagle 1c45896
[video_player] Use static resource loader for caching
999eagle 0eeb002
ios escape alphanumeric characters
lukepighetti 33f0090
fix file loading on iOS, expose cache size arguments
lukepighetti fa96eab
comments
lukepighetti 6da01a8
[untested] static method to set cache once
lukepighetti 8b23e1b
remove unused constructor args, add asserts
lukepighetti e49ead2
Fix formatting
999eagle 90c229f
Add myself to AUTHORS
999eagle 5f4f141
Update version and changelog
999eagle 96d4ede
Merge remote-tracking branch 'upstream/master'
sanekyy 27b258c
Merge remote-tracking branch 'upstream/master'
sanekyy 5d2ee61
revert google_maps_v3
sanekyy b3bf399
revert tile overlays
sanekyy 4bb5b37
revert to origin master
sanekyy c81b666
test commit
sanekyy 010ea2b
Revert "test commit"
sanekyy d736a96
fix merge conflicts
sanekyy 7db7db3
Merge remote-tracking branch 'upstream/master'
sanekyy c0aa086
Merge remote-tracking branch 'upstream/master'
sanekyy 70ef4bb
Merge remote-tracking branch 'upstream/master'
otopba 41749fb
Fix blinking
otopba 0842159
Revert "Fix blinking"
otopba 6452e0d
merge upstream with caching feature from 999eagle fork
sanekyy 5b8c45d
fix documentation
sanekyy dfcf6e8
improve caching logic
sanekyy b2c8687
iOS support
otopba 9b93d68
rename maxFileSize -> maxCacheFileSize
otopba 7727ade
Read useCache only if have uriArg
otopba cdd0ebf
[shared_preferences] add a no-op android folder to web/macos packages…
amirh 46b9858
Remove AndroidX references from no-op android implementations (#2411)
amirh 6d6815e
[sensors]Cancel sensors example timer avoid exception (#2375)
figureConan c933bad
[e2e] Creates basic support/documentation/example to iOS. (#2394)
AlbertWang0116 cb87553
[shared_preferences web/macos] remove unused onMethodCall methods (#2…
amirh afe8b0e
[webview_flutter] add gesture navigation for iOS (#2339)
wwwdata 71cb85d
Update endorsed macos plugins readme and update others (#2407)
franciscojma86 2ae83bb
[plugin_platform_interface] Don't use const Object as a token (#2417)
amirh b41574a
[url_launcher_platform_interface] use non static token for platform i…
amirh ed43957
[ios_platform_images] Made ios_platform_images set the correct image …
gaaclarke 0f392ac
[google_sign_in] Pass the client id to the platform interface. (#2427)
chingjun 99a7b9b
[in_app_purchase]Change a comment. (#2329)
HiIamAlanOu 6bf582b
re-enable stable CI (#2402)
amirh 5ee6a24
[flutter_webview] Raise min Flutter SDK to stable (#2425)
2b2ecec
[battery] cleanup for Android embedding post 1.12 (#2400)
xster 3961bca
[google_sign_in] Expose network error (#2398)
yuwen-yan e44e6f5
[ios_platform_images] Removed android support from the pubspec. (#2432)
gaaclarke 13c796c
[google_sign_in]Update google_sign_in_example name in pubspec.yaml (#…
figureConan 47b6fd3
Merge remote-tracking branch 'upstream/master'
sanekyy e007126
Merge remote-tracking branch 'upstream/master'
sanekyy 96b4f7a
Merge remote-tracking branch 'upstream/master'
sanekyy a5bc3d5
Merge branch 'master' into caching
sanekyy dead810
Merge remote-tracking branch 'origin/caching' into caching
sanekyy 4aeb7a8
Merge remote-tracking branch 'upstream/master'
sanekyy 1774f26
Merge branch 'master' into caching
sanekyy b374825
workaround for success build checks in PR
sanekyy ed657d6
bump video_player_web version
sanekyy c920b58
Merge remote-tracking branch 'upstream/master' into caching
sanekyy 9c5810c
merge fixes
sanekyy 4e8c909
Merge remote-tracking branch 'upstream/master' into caching
sanekyy bd2c825
merge upstream
sanekyy d90473d
Merge remote-tracking branch 'upstream/master' into caching
sanekyy b3e94e7
fix merge issues
sanekyy 1e30a50
fix version and format
sanekyy 8f86154
fix version
sanekyy 130a847
Merge remote-tracking branch 'upstream/master' into caching
sanekyy 24e3b20
Merge remote-tracking branch 'upstream/master' into caching
sanekyy 3b800a7
Merge branch 'master' into caching
otopba 740cb3e
merge
otopba e33cffc
fix video_player_platform_interface version
otopba 5ac10c1
Merge branch 'upstream-master' into caching
sanekyy c1e2c2a
fetch upstream
sanekyy a9ca995
fix iOS issueses
sanekyy 16e9c54
revert dependencies issues
sanekyy 0a1f3c4
fix tests
sanekyy 5f16b27
apply format
sanekyy 1fc4b5c
fix tests
sanekyy ebfc32a
Merge branch 'master' into caching
otopba 77bc64b
Format code
otopba b38cc87
Fix number to long convert
otopba File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -59,3 +59,5 @@ Kazuki Yamaguchi <[email protected]> | |
Eitan Schwartz <[email protected]> | ||
Chris Rutkowski <[email protected]> | ||
Juan Alvarez <[email protected]> | ||
Aleksandr Yurkovskiy <[email protected]> | ||
Iurii Dorofeev <[email protected]> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,7 +6,6 @@ | |
|
||
/// An example of using the plugin, controlling lifecycle and playback of the | ||
/// video. | ||
|
||
import 'package:flutter/cupertino.dart'; | ||
import 'package:flutter/material.dart'; | ||
import 'package:video_player/video_player.dart'; | ||
|
@@ -221,6 +220,7 @@ class _BumbleBeeRemoteVideoState extends State<_BumbleBeeRemoteVideo> { | |
'https://flutter.github.io/assets-for-api-docs/assets/videos/bee.mp4', | ||
closedCaptionFile: _loadCaptions(), | ||
videoPlayerOptions: VideoPlayerOptions(mixWithOthers: true), | ||
useCache: true, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Same question here - it seems like it's probably fine to opt users into caching as long as the max values are set and we document what they are/how to change them. |
||
); | ||
|
||
_controller.addListener(() { | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,6 +5,7 @@ | |
#import "FLTVideoPlayerPlugin.h" | ||
#import <AVFoundation/AVFoundation.h> | ||
#import <GLKit/GLKit.h> | ||
#import "VIMediaCache.h" | ||
#import "messages.h" | ||
|
||
#if !__has_feature(objc_arc) | ||
|
@@ -51,6 +52,7 @@ - (void)play; | |
- (void)pause; | ||
- (void)setIsLooping:(bool)isLooping; | ||
- (void)updatePlayingState; | ||
+ (VIResourceLoaderManager*)resourceLoaderManager; | ||
@end | ||
|
||
static void* timeRangeContext = &timeRangeContext; | ||
|
@@ -163,10 +165,29 @@ - (void)createVideoOutputAndDisplayLink:(FLTFrameUpdater*)frameUpdater { | |
} | ||
|
||
- (instancetype)initWithURL:(NSURL*)url frameUpdater:(FLTFrameUpdater*)frameUpdater { | ||
AVPlayerItem* item = [AVPlayerItem playerItemWithURL:url]; | ||
return [self initWithURL:url frameUpdater:frameUpdater enableCache:NO]; | ||
} | ||
|
||
- (instancetype)initWithURL:(NSURL*)url | ||
frameUpdater:(FLTFrameUpdater*)frameUpdater | ||
enableCache:(BOOL)enableCache { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ditto |
||
AVPlayerItem* item; | ||
if (enableCache) { | ||
item = [[FLTVideoPlayer resourceLoaderManager] playerItemWithURL:url]; | ||
} else { | ||
item = [AVPlayerItem playerItemWithURL:url]; | ||
} | ||
return [self initWithPlayerItem:item frameUpdater:frameUpdater]; | ||
} | ||
|
||
+ (VIResourceLoaderManager*)resourceLoaderManager { | ||
static VIResourceLoaderManager* resourceLoaderManager = nil; | ||
if (resourceLoaderManager == nil) { | ||
resourceLoaderManager = [VIResourceLoaderManager new]; | ||
} | ||
return resourceLoaderManager; | ||
} | ||
|
||
- (CGAffineTransform)fixTransform:(AVAssetTrack*)videoTrack { | ||
CGAffineTransform transform = videoTrack.preferredTransform; | ||
// TODO(@recastrodiaz): why do we need to do this? Why is the preferredTransform incorrect? | ||
|
@@ -450,6 +471,8 @@ @interface FLTVideoPlayerPlugin () <FLTVideoPlayerApi> | |
@property(readonly, weak, nonatomic) NSObject<FlutterBinaryMessenger>* messenger; | ||
@property(readonly, strong, nonatomic) NSMutableDictionary* players; | ||
@property(readonly, strong, nonatomic) NSObject<FlutterPluginRegistrar>* registrar; | ||
@property(readonly, nonatomic) long maxCacheSize; | ||
@property(readonly, nonatomic) long maxCacheFileSize; | ||
@end | ||
|
||
@implementation FLTVideoPlayerPlugin | ||
|
@@ -497,7 +520,7 @@ - (FLTTextureMessage*)onPlayerSetup:(FLTVideoPlayer*)player | |
return result; | ||
} | ||
|
||
- (void)initialize:(FlutterError* __autoreleasing*)error { | ||
- (void)initialize:(FLTInitializeMessage*)input error:(FlutterError**)error { | ||
// Allow audio playback when the Ring/Silent switch is set to silent | ||
[[AVAudioSession sharedInstance] setCategory:AVAudioSessionCategoryPlayback error:nil]; | ||
|
||
|
@@ -506,6 +529,8 @@ - (void)initialize:(FlutterError* __autoreleasing*)error { | |
[_players[textureId] dispose]; | ||
} | ||
[_players removeAllObjects]; | ||
_maxCacheSize = [input.maxCacheSize longValue]; | ||
_maxCacheFileSize = [input.maxCacheFileSize longValue]; | ||
} | ||
|
||
- (FLTTextureMessage*)create:(FLTCreateMessage*)input error:(FlutterError**)error { | ||
|
@@ -521,8 +546,20 @@ - (FLTTextureMessage*)create:(FLTCreateMessage*)input error:(FlutterError**)erro | |
player = [[FLTVideoPlayer alloc] initWithAsset:assetPath frameUpdater:frameUpdater]; | ||
return [self onPlayerSetup:player frameUpdater:frameUpdater]; | ||
} else if (input.uri) { | ||
player = [[FLTVideoPlayer alloc] initWithURL:[NSURL URLWithString:input.uri] | ||
frameUpdater:frameUpdater]; | ||
BOOL useCache = input.useCache; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ditto |
||
BOOL enableCache = _maxCacheSize > 0 && _maxCacheFileSize > 0 && useCache; | ||
if (enableCache) { | ||
NSString* escapedURL = [input.uri | ||
stringByAddingPercentEncodingWithAllowedCharacters:NSMutableCharacterSet | ||
.alphanumericCharacterSet]; | ||
|
||
player = [[FLTVideoPlayer alloc] initWithURL:[NSURL URLWithString:escapedURL] | ||
frameUpdater:frameUpdater | ||
enableCache:enableCache]; | ||
} else { | ||
player = [[FLTVideoPlayer alloc] initWithURL:[NSURL URLWithString:input.uri] | ||
frameUpdater:frameUpdater]; | ||
} | ||
return [self onPlayerSetup:player frameUpdater:frameUpdater]; | ||
} else { | ||
*error = [FlutterError errorWithCode:@"video_player" message:@"not implemented" details:nil]; | ||
|
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: why have an extra parameter here instead of just setting this based on whether
maxCacheSize
andmaxCacheFileSize
> 0?