Merge pull request #7 from YTVanced/videoinfo

VideoInformation for copy buttons
This commit is contained in:
VancedOfficial 2020-12-16 13:35:12 +02:00 committed by GitHub
commit a47bdb3a2b
3 changed files with 17 additions and 16 deletions

View File

@ -0,0 +1,6 @@
package fi.vanced.libraries.youtube.player;
public class VideoInformation {
public static String currentVideoId;
public static long lastKnownVideoTime = -1L;
}

View File

@ -18,6 +18,8 @@ import java.util.Arrays;
import java.util.Timer; import java.util.Timer;
import java.util.TimerTask; import java.util.TimerTask;
import fi.vanced.libraries.youtube.player.VideoInformation;
@SuppressLint({"LongLogTag"}) @SuppressLint({"LongLogTag"})
public class PlayerController { public class PlayerController {
public static final String TAG = "jakubweg.PlayerController"; public static final String TAG = "jakubweg.PlayerController";
@ -56,6 +58,8 @@ public class PlayerController {
return; return;
} }
VideoInformation.currentVideoId = videoId;
if (!SponsorBlockSettings.isSponsorBlockEnabled) { if (!SponsorBlockSettings.isSponsorBlockEnabled) {
currentVideoId = null; currentVideoId = null;
return; return;
@ -99,6 +103,7 @@ public class PlayerController {
setMillisecondMethod.setAccessible(true); setMillisecondMethod.setAccessible(true);
lastKnownVideoTime = 0; lastKnownVideoTime = 0;
VideoInformation.lastKnownVideoTime = 0;
currentVideoLength = 1; currentVideoLength = 1;
currentPlayerController = new WeakReference<>(o); currentPlayerController = new WeakReference<>(o);
@ -191,6 +196,7 @@ public class PlayerController {
public static void setCurrentVideoTime(long millis) { public static void setCurrentVideoTime(long millis) {
if (VERBOSE) if (VERBOSE)
Log.v(TAG, "setCurrentVideoTime: current video time: " + millis); Log.v(TAG, "setCurrentVideoTime: current video time: " + millis);
VideoInformation.lastKnownVideoTime = millis;
if (!SponsorBlockSettings.isSponsorBlockEnabled) return; if (!SponsorBlockSettings.isSponsorBlockEnabled) return;
lastKnownVideoTime = millis; lastKnownVideoTime = millis;
if (millis <= 0) return; if (millis <= 0) return;
@ -217,6 +223,7 @@ public class PlayerController {
public void run() { public void run() {
skipSponsorTask = null; skipSponsorTask = null;
lastKnownVideoTime = segment.start + 1; lastKnownVideoTime = segment.start + 1;
VideoInformation.lastKnownVideoTime = lastKnownVideoTime;
new Handler(Looper.getMainLooper()).post(findAndSkipSegmentRunnable); new Handler(Looper.getMainLooper()).post(findAndSkipSegmentRunnable);
} }
}; };
@ -263,8 +270,10 @@ public class PlayerController {
* Called very high frequency (once every about 100ms), also in background. It sometimes triggers when a video is paused (couple times in the row with the same value) * Called very high frequency (once every about 100ms), also in background. It sometimes triggers when a video is paused (couple times in the row with the same value)
*/ */
public static void setCurrentVideoTimeHighPrecision(final long millis) { public static void setCurrentVideoTimeHighPrecision(final long millis) {
if (lastKnownVideoTime > 0) if (lastKnownVideoTime > 0) {
lastKnownVideoTime = millis; lastKnownVideoTime = millis;
VideoInformation.lastKnownVideoTime = lastKnownVideoTime;
}
else else
setCurrentVideoTime(millis); setCurrentVideoTime(millis);
} }
@ -431,6 +440,7 @@ public class PlayerController {
if (VERBOSE) if (VERBOSE)
Log.i(TAG, "Skipping to millis=" + finalMillisecond); Log.i(TAG, "Skipping to millis=" + finalMillisecond);
lastKnownVideoTime = finalMillisecond; lastKnownVideoTime = finalMillisecond;
VideoInformation.lastKnownVideoTime = lastKnownVideoTime;
setMillisecondMethod.invoke(currentObj, finalMillisecond); setMillisecondMethod.invoke(currentObj, finalMillisecond);
} catch (Exception e) { } catch (Exception e) {
Log.e(TAG, "Cannot skip to millisecond", e); Log.e(TAG, "Cannot skip to millisecond", e);

View File

@ -1,38 +1,24 @@
package pl.jakubweg; package pl.jakubweg;
import android.annotation.SuppressLint; import android.annotation.SuppressLint;
import android.app.Activity;
import android.app.AlertDialog; import android.app.AlertDialog;
import android.content.Context; import android.content.Context;
import android.content.DialogInterface; import android.content.DialogInterface;
import android.content.res.Resources;
import android.graphics.drawable.Drawable;
import android.os.Handler; import android.os.Handler;
import android.os.Looper; import android.os.Looper;
import android.util.Log; import android.util.Log;
import android.view.Gravity;
import android.view.View; import android.view.View;
import android.view.ViewGroup;
import android.widget.EditText; import android.widget.EditText;
import android.widget.ImageView; import android.widget.ImageView;
import android.widget.RelativeLayout;
import android.widget.TextView;
import android.widget.Toast; import android.widget.Toast;
import org.json.JSONArray; import org.json.JSONArray;
import org.json.JSONObject; import org.json.JSONObject;
import java.io.BufferedReader; import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.EOFException;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.io.RandomAccessFile;
import java.lang.ref.WeakReference; import java.lang.ref.WeakReference;
import java.lang.reflect.Constructor;
import java.net.HttpURLConnection; import java.net.HttpURLConnection;
import java.net.URL; import java.net.URL;
import java.text.ParseException; import java.text.ParseException;
@ -52,7 +38,6 @@ import static pl.jakubweg.PlayerController.getCurrentVideoId;
import static pl.jakubweg.PlayerController.getLastKnownVideoTime; import static pl.jakubweg.PlayerController.getLastKnownVideoTime;
import static pl.jakubweg.PlayerController.sponsorSegmentsOfCurrentVideo; import static pl.jakubweg.PlayerController.sponsorSegmentsOfCurrentVideo;
import static pl.jakubweg.SponsorBlockSettings.sponsorBlockSkipSegmentsUrl; import static pl.jakubweg.SponsorBlockSettings.sponsorBlockSkipSegmentsUrl;
import static pl.jakubweg.StringRef.sf;
import static pl.jakubweg.StringRef.str; import static pl.jakubweg.StringRef.str;
@SuppressWarnings({"LongLogTag"}) @SuppressWarnings({"LongLogTag"})