Project Name | Stars | Downloads | Repos Using This | Packages Using This | Most Recent Commit | Total Releases | Latest Release | Open Issues | License | Language |
---|---|---|---|---|---|---|---|---|---|---|
Androidvideocache | 5,162 | 9 days ago | 156 | apache-2.0 | Java | |||||
Cache support for any video player with help of single line | ||||||||||
Dkvideoplayer | 4,309 | 3 months ago | 8 | July 24, 2022 | 65 | apache-2.0 | Java | |||
Android Video Player. 安卓视频播放器,封装MediaPlayer、ExoPlayer、IjkPlayer。模仿抖音并实现预加载,列表播放,悬浮播放,广告播放,弹幕,视频水印,视频滤镜 | ||||||||||
Yjplay | 1,635 | 3 years ago | 33 | apache-2.0 | C | |||||
一个支持自定义UI布局,流式API, 加密,直播 ,亮度,音量,快进等手势 ,广告视频预览,多种加载模式 ,多种分辨率切换 ,多种封面图, 自定义数据源,列表播放,倍数播放,边播变缓存<font color="red">不是使用AndroidVideoCache</font>,离线播放,神奇的播放器 | ||||||||||
Player | 782 | 8 days ago | 35 | unlicense | Java | |||||
▶ Simple and lightweight, yet polished and powerful Android video player based on ExoPlayer | ||||||||||
Exoplayerfilter | 758 | 2 years ago | 14 | Java | ||||||
This library uses OpenGL Shaders to apply effects on ExoPlayer video at Runtime | ||||||||||
Magicalexoplayer | 307 | 2 months ago | 23 | mit | Kotlin | |||||
The Easiest Way To Play/Stream Video And Audio Using Google ExoPlayer In Your Android Application | ||||||||||
Exoplayer Kotlin | 108 | 14 days ago | 1 | Kotlin | ||||||
Cookbook of multiple feature for Exoplayer | ||||||||||
Hybridmediaplayer | 71 | 3 months ago | 4 | Java | ||||||
Android music and video player. Uses ExoPlayer 2 and MediaPlayer for lower APIs and makes using ExoMediaPlayer easier. If you need advanced options such as handling Chromecast it is delivered by ExoMediaPlayer class. | ||||||||||
Yetanothervideoplayer | 56 | a year ago | gpl-3.0 | Java | ||||||
Yet Another Video Player for Andoid | ||||||||||
Androidvideoplayer | 52 | a year ago | 4 | Kotlin | ||||||
A video player based on Exoplayer |
Because there is no sense to download video a lot of times while streaming!
AndroidVideoCache
allows to add caching support to your VideoView/MediaPlayer
, ExoPlayer or any another player with help of single line!
Note AndroidVideoCache
works only with direct urls to media file, it doesn't support any streaming technology like DASH, SmoothStreaming, HLS.
Just add dependency (AndroidVideoCache
is available in jcenter):
dependencies {
compile 'com.danikula:videocache:2.7.1'
}
and use url from proxy instead of original url for adding caching:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
HttpProxyCacheServer proxy = getProxy();
String proxyUrl = proxy.getProxyUrl(VIDEO_URL);
videoView.setVideoPath(proxyUrl);
}
private HttpProxyCacheServer getProxy() {
// should return single instance of HttpProxyCacheServer shared for whole app.
}
To guarantee normal work you should use single instance of HttpProxyCacheServer
for whole app.
For example you can store shared proxy in your Application
:
public class App extends Application {
private HttpProxyCacheServer proxy;
public static HttpProxyCacheServer getProxy(Context context) {
App app = (App) context.getApplicationContext();
return app.proxy == null ? (app.proxy = app.newProxy()) : app.proxy;
}
private HttpProxyCacheServer newProxy() {
return new HttpProxyCacheServer(this);
}
}
or use simple factory. More preferable way is use some dependency injector like Dagger.
By default HttpProxyCacheServer
uses 512Mb for caching files. You can change this value:
private HttpProxyCacheServer newProxy() {
return new HttpProxyCacheServer.Builder(this)
.maxCacheSize(1024 * 1024 * 1024) // 1 Gb for cache
.build();
}
or can limit total count of files in cache:
private HttpProxyCacheServer newProxy() {
return new HttpProxyCacheServer.Builder(this)
.maxCacheFilesCount(20)
.build();
}
or even implement your own DiskUsage
strategy:
private HttpProxyCacheServer newProxy() {
return new HttpProxyCacheServer.Builder(this)
.diskUsage(new MyCoolDiskUsageStrategy())
.build();
}
Use HttpProxyCacheServer.registerCacheListener(CacheListener listener)
method to set listener with callback onCacheAvailable(File cacheFile, String url, int percentsAvailable)
to be aware of caching progress. Do not forget to to unsubscribe listener with help of HttpProxyCacheServer.unregisterCacheListener(CacheListener listener)
method to avoid memory leaks.
Use HttpProxyCacheServer.isCached(String url)
method to check was url's content fully cached to file or not.
See sample
app for more details.
By default AndroidVideoCache
uses MD5 of video url as file name. But in some cases url is not stable and it can contain some generated parts (e.g. session token). In this case caching mechanism will be broken. To fix it you have to provide own FileNameGenerator
:
public class MyFileNameGenerator implements FileNameGenerator {
// Urls contain mutable parts (parameter 'sessionToken') and stable video's id (parameter 'videoId').
// e. g. http://example.com?videoId=abcqaz&sessionToken=xyz987
public String generate(String url) {
Uri uri = Uri.parse(url);
String videoId = uri.getQueryParameter("videoId");
return videoId + ".mp4";
}
}
...
HttpProxyCacheServer proxy = new HttpProxyCacheServer.Builder(context)
.fileNameGenerator(new MyFileNameGenerator())
.build()
You can add custom headers to requests with help of HeadersInjector
:
public class UserAgentHeadersInjector implements HeaderInjector {
@Override
public Map<String, String> addHeaders(String url) {
return Maps.newHashMap("User-Agent", "Cool app v1.1");
}
}
private HttpProxyCacheServer newProxy() {
return new HttpProxyCacheServer.Builder(this)
.headerInjector(new UserAgentHeadersInjector())
.build();
}
You can use exoPlayer
with AndroidVideoCache
. See sample
app in exoPlayer
branch. Note exoPlayer supports cache as well.
See sample
app.
See Release Notes here
If it's a feature that you think would need to be discussed please open an issue first, otherwise, you can follow this process:
Copyright 2014-2017 Alexey Danilov
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.