From cd42a2431db89789ea87a975452c6375b7776eae Mon Sep 17 00:00:00 2001
From: volodymyr-bondarenko85
<131799099+volodymyr-bondarenko85@users.noreply.github.com>
Date: Mon, 23 Dec 2024 14:34:50 +0200
Subject: [PATCH] KUX-1761: Upgrade exoplayer to Media 3 (#69)
* KUX-1761: Upgrade exoplayer to Media 3
* ASTRO-1204: Astro -support Android 14 in player playkit SDK
* ASTRO-1204: Astro -support Android 14 in player playkit SDK
* Custom branch release publish updated
---
.github/publish.sh | 2 +-
.github/workflows/build.yml | 4 ++--
.github/workflows/publish.yml | 7 ++++++
build.gradle | 4 ++--
gradle/wrapper/gradle-wrapper.properties | 4 ++--
jitpack.yml | 2 +-
playkitvr/build.gradle | 22 ++++++++++++++-----
playkitvr/gradle-mvn-local.gradle | 4 ++--
playkitvr/gradle-mvn-push.gradle | 6 ++---
playkitvr/src/main/AndroidManifest.xml | 3 +--
.../playkitvr/DefaultVRPlayerFactory.java | 2 ++
.../playkitvr/DefaultVRPlayerWrapper.java | 2 ++
.../java/com/kaltura/playkitvr/VRView.java | 16 ++++++++------
13 files changed, 50 insertions(+), 28 deletions(-)
diff --git a/.github/publish.sh b/.github/publish.sh
index 4fc9c0a..b0a4ab3 100644
--- a/.github/publish.sh
+++ b/.github/publish.sh
@@ -43,7 +43,7 @@ set_version() {
if [ "$RELEASE_TYPE" == "Full" ]; then
echo "RELEASE_TYPE = '$RELEASE_TYPE'"
- perl -pi -e "s/:playkit-android:dev-SNAPSHOT/.playkit:playkit:$NEW_VERSION/" $BUILD_GRADLE
+ perl -pi -e "s/:playkit-android:.*?-SNAPSHOT/.playkit:playkit:$NEW_VERSION/" $BUILD_GRADLE
fi
}
diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml
index 07735d9..cdf69fc 100644
--- a/.github/workflows/build.yml
+++ b/.github/workflows/build.yml
@@ -20,10 +20,10 @@ jobs:
- name: Checkout repo and clone to CI workspace
uses: actions/checkout@v3
- - name: Setup JDK 11
+ - name: Setup JDK 17
uses: actions/setup-java@v3
with:
- java-version: '11'
+ java-version: '17'
distribution: 'adopt'
cache: 'gradle'
diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml
index c74a1b8..a13d336 100644
--- a/.github/workflows/publish.yml
+++ b/.github/workflows/publish.yml
@@ -50,6 +50,13 @@ jobs:
mkdir $PWD/.kltrenv && echo "${{ secrets.SIGNING_KEY }}" > $PWD/.kltrenv/secring.gpg.b64
base64 -d $PWD/.kltrenv/secring.gpg.b64 > $PWD/.kltrenv/secring.gpg
+ - name: Setup JDK 17
+ uses: actions/setup-java@v3
+ with:
+ java-version: '17'
+ distribution: 'adopt'
+ cache: 'gradle'
+
- name: Run publish Script
run: |
RELEASE_TYPE=${RELEASE_TYPE} NEW_VERSION=${NEW_VERSION}
diff --git a/build.gradle b/build.gradle
index 474607b..74de40d 100644
--- a/build.gradle
+++ b/build.gradle
@@ -7,14 +7,14 @@ ext["signingKeyId"] = System.getenv('SIGNING_KEYID')
ext["signingPassword"] = System.getenv('SIGNING_PASSWORD')
buildscript {
- ext.kotlin_version = '1.7.10'
+ ext.kotlin_version = '1.8.0'
repositories {
google()
mavenCentral()
maven { url "https://jitpack.io" }
}
dependencies {
- classpath 'com.android.tools.build:gradle:7.2.1'
+ classpath 'com.android.tools.build:gradle:8.3.2'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
classpath 'io.github.gradle-nexus:publish-plugin:1.1.0'
}
diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties
index c727ec2..3c2b939 100644
--- a/gradle/wrapper/gradle-wrapper.properties
+++ b/gradle/wrapper/gradle-wrapper.properties
@@ -1,6 +1,6 @@
-#Wed Apr 01 12:31:58 IDT 2020
+#Thu Jul 11 16:22:33 IDT 2019
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-7.3.3-all.zip
+distributionUrl=https\://services.gradle.org/distributions/gradle-8.4-all.zip
diff --git a/jitpack.yml b/jitpack.yml
index 02ab496..6bfd6a5 100644
--- a/jitpack.yml
+++ b/jitpack.yml
@@ -1,4 +1,4 @@
jdk:
- - openjdk11
+ - openjdk17
before_install:
- curl https://kaltura.github.io/fe-tools/android/license.sh | sh
diff --git a/playkitvr/build.gradle b/playkitvr/build.gradle
index 2cf162a..6c17f0e 100644
--- a/playkitvr/build.gradle
+++ b/playkitvr/build.gradle
@@ -2,14 +2,15 @@ apply plugin: 'com.android.library'
apply from: 'version.gradle'
android {
- compileSdkVersion 33
+ namespace 'com.kaltura.playkitvr'
+ compileSdk 34
compileOptions {
- sourceCompatibility JavaVersion.VERSION_1_8
- targetCompatibility JavaVersion.VERSION_1_8
+ sourceCompatibility JavaVersion.VERSION_17
+ targetCompatibility JavaVersion.VERSION_17
}
defaultConfig {
- minSdkVersion 16
- targetSdkVersion 33
+ minSdkVersion 21
+ targetSdkVersion 34
versionCode 1
versionName libVersion
@@ -23,6 +24,15 @@ android {
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
+ buildFeatures {
+ buildConfig = true
+ }
+ publishing {
+ publishing {
+ singleVariant('release') {
+ }
+ }
+ }
}
tasks.withType(Javadoc) {
@@ -31,7 +41,7 @@ tasks.withType(Javadoc) {
dependencies {
- implementation 'com.kaltura:playkit-android:dev-SNAPSHOT'
+ implementation 'com.kaltura:playkit-android:KUX-1761-SNAPSHOT'
//implementation project(":playkit")
//implementation 'com.kaltura:MD360Player4Android:master'
diff --git a/playkitvr/gradle-mvn-local.gradle b/playkitvr/gradle-mvn-local.gradle
index 6d0d890..389f44f 100644
--- a/playkitvr/gradle-mvn-local.gradle
+++ b/playkitvr/gradle-mvn-local.gradle
@@ -1,7 +1,7 @@
apply plugin: 'maven-publish'
task androidSourcesJar(type: Jar) {
- classifier 'sources'
+ archiveClassifier = 'sources'
from android.sourceSets.main.java.sourceFiles
}
@@ -9,7 +9,7 @@ project.afterEvaluate {
publishing {
publications {
mavenJava(MavenPublication) {
- from components.release
+ from components.findByName('release')
}
}
repositories {
diff --git a/playkitvr/gradle-mvn-push.gradle b/playkitvr/gradle-mvn-push.gradle
index e26cac0..f2c6402 100644
--- a/playkitvr/gradle-mvn-push.gradle
+++ b/playkitvr/gradle-mvn-push.gradle
@@ -27,7 +27,7 @@ afterEvaluate { project ->
publishing {
publications {
mavenJava(MavenPublication) {
- from components.release
+ from components.findByName('release')
groupId = GROUP
artifactId = POM_ARTIFACT_ID
@@ -97,12 +97,12 @@ afterEvaluate { project ->
}
task androidJavadocsJar(type: Jar, dependsOn: androidJavadocs) {
- classifier 'javadoc'
+ archiveClassifier = 'javadoc'
from androidJavadocs.destinationDir
}
task androidSourcesJar(type: Jar) {
- classifier 'sources'
+ archiveClassifier = 'sources'
from android.sourceSets.main.java.sourceFiles
}
diff --git a/playkitvr/src/main/AndroidManifest.xml b/playkitvr/src/main/AndroidManifest.xml
index 31a8830..be2b156 100644
--- a/playkitvr/src/main/AndroidManifest.xml
+++ b/playkitvr/src/main/AndroidManifest.xml
@@ -1,3 +1,2 @@
-
+
diff --git a/playkitvr/src/main/java/com/kaltura/playkitvr/DefaultVRPlayerFactory.java b/playkitvr/src/main/java/com/kaltura/playkitvr/DefaultVRPlayerFactory.java
index 94d6861..b8eab19 100644
--- a/playkitvr/src/main/java/com/kaltura/playkitvr/DefaultVRPlayerFactory.java
+++ b/playkitvr/src/main/java/com/kaltura/playkitvr/DefaultVRPlayerFactory.java
@@ -2,6 +2,7 @@
import android.content.Context;
+import com.kaltura.androidx.media3.common.util.UnstableApi;
import com.kaltura.playkit.player.BaseExoplayerView;
import com.kaltura.playkit.player.PlayerEngine;
import com.kaltura.playkit.player.vr.VRPlayerFactory;
@@ -13,6 +14,7 @@
* Created by anton.afanasiev on 23/07/2017.
*/
+@UnstableApi
public class DefaultVRPlayerFactory implements VRPlayerFactory {
@Override
diff --git a/playkitvr/src/main/java/com/kaltura/playkitvr/DefaultVRPlayerWrapper.java b/playkitvr/src/main/java/com/kaltura/playkitvr/DefaultVRPlayerWrapper.java
index 8a5d550..5c212b2 100644
--- a/playkitvr/src/main/java/com/kaltura/playkitvr/DefaultVRPlayerWrapper.java
+++ b/playkitvr/src/main/java/com/kaltura/playkitvr/DefaultVRPlayerWrapper.java
@@ -6,6 +6,7 @@
import com.asha.vrlib.MDVRLibrary;
import com.asha.vrlib.model.BarrelDistortionConfig;
+import com.kaltura.androidx.media3.common.util.UnstableApi;
import com.kaltura.playkit.PKController;
import com.kaltura.playkit.PKLog;
import com.kaltura.playkit.PlayerEngineWrapper;
@@ -20,6 +21,7 @@
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
+@UnstableApi
class DefaultVRPlayerWrapper extends PlayerEngineWrapper {
private PKLog log = PKLog.get(DefaultVRPlayerWrapper.class.getSimpleName());
diff --git a/playkitvr/src/main/java/com/kaltura/playkitvr/VRView.java b/playkitvr/src/main/java/com/kaltura/playkitvr/VRView.java
index 2a91c12..a4dd99d 100644
--- a/playkitvr/src/main/java/com/kaltura/playkitvr/VRView.java
+++ b/playkitvr/src/main/java/com/kaltura/playkitvr/VRView.java
@@ -16,14 +16,15 @@
import android.view.ViewGroup;
import android.widget.FrameLayout;
-import com.kaltura.android.exoplayer2.ExoPlayer;
-import com.kaltura.android.exoplayer2.Player;
-import com.kaltura.android.exoplayer2.text.Cue;
-import com.kaltura.android.exoplayer2.text.CueGroup;
-import com.kaltura.android.exoplayer2.ui.AspectRatioFrameLayout;
-import com.kaltura.android.exoplayer2.video.VideoSize;
+import com.kaltura.androidx.media3.common.util.UnstableApi;
+import com.kaltura.androidx.media3.exoplayer.ExoPlayer;
+import com.kaltura.androidx.media3.common.Player;
+import com.kaltura.androidx.media3.common.text.Cue;
+import com.kaltura.androidx.media3.common.text.CueGroup;
+import com.kaltura.androidx.media3.ui.AspectRatioFrameLayout;
+import com.kaltura.androidx.media3.common.VideoSize;
import com.kaltura.playkit.PKLog;
-import com.kaltura.android.exoplayer2.ui.SubtitleView;
+import com.kaltura.androidx.media3.ui.SubtitleView;
import com.kaltura.playkit.player.BaseExoplayerView;
import com.kaltura.playkit.player.PKSubtitlePosition;
@@ -32,6 +33,7 @@
import javax.annotation.Nonnull;
+@UnstableApi
class VRView extends BaseExoplayerView {
private static final PKLog log = PKLog.get("VRView");