Step 1. Add the JitPack repository to your build file
Add it in your root settings.gradle at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url 'https://jitpack.io' }
}
}
Add it in your settings.gradle.kts at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url = uri("https://jitpack.io") }
}
}
Add to pom.xml
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
Add it in your build.sbt at the end of resolvers:
resolvers += "jitpack" at "https://jitpack.io"
Add it in your project.clj at the end of repositories:
:repositories [["jitpack" "https://jitpack.io"]]
Step 2. Add the dependency
dependencies {
implementation 'com.github.metalurgus:AndroidVideoCache:v2.3.4.2'
}
dependencies {
implementation("com.github.metalurgus:AndroidVideoCache:v2.3.4.2")
}
<dependency>
<groupId>com.github.metalurgus</groupId>
<artifactId>AndroidVideoCache</artifactId>
<version>v2.3.4.2</version>
</dependency>
libraryDependencies += "com.github.metalurgus" % "AndroidVideoCache" % "v2.3.4.2"
:dependencies [[com.github.metalurgus/AndroidVideoCache "v2.3.4.2"]]
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):
repositories {
jcenter()
}
dependencies {
compile 'com.danikula:videocache:2.3.4'
}
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();
}
See sample
app for details.
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-2015 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.