diff --git a/.github/CONTRIBUTING.md b/.github/CONTRIBUTING.md index 07cb9f66c..574c87ad3 100644 --- a/.github/CONTRIBUTING.md +++ b/.github/CONTRIBUTING.md @@ -5,11 +5,14 @@ PLEASE READ THESE GUIDELINES CAREFULLY BEFORE ANY CONTRIBUTION! ## Crash reporting -Do not report crashes in the GitHub issue tracker. NewPipe has an automated crash report system that will ask you to send a report via e-mail when a crash occurs. This contains all the data we need for debugging, and allows you to even add a comment to it. You'll see exactly what is sent, the system is 100% transparent. +Do not report crashes in the GitHub issue tracker. NewPipe has an automated crash report system that will ask you to +send a report via e-mail when a crash occurs. This contains all the data we need for debugging, and allows you to even +add a comment to it. You'll see exactly what is sent, the system is 100% transparent. ## Issue reporting/feature requests -* Search the [existing issues](https://github.com/TeamNewPipe/NewPipe/issues) first to make sure your issue/feature hasn't been reported/requested before +* Search the [existing issues](https://github.com/TeamNewPipe/NewPipe/issues) first to make sure your issue/feature +hasn't been reported/requested before * Check whether your issue/feature is already fixed/implemented * Check if the issue still exists in the latest release/beta version * If you are an Android/Java developer, you are always welcome to fix/implement an issue/a feature yourself. PRs welcome! @@ -19,30 +22,47 @@ Do not report crashes in the GitHub issue tracker. NewPipe has an automated cras * Issues that only contain a generated bug report, but no describtion might be closed. ## Bug Fixing -* If you want to help NewPipe to become free of bugs (this is our utopic goal for NewPipe), you can send us an email to tnp@newpipe.schabi.org to let me know that you intend to help. We'll send you further instructions. You may, on request, register at our [Sentry](https://sentry.schabi.org) instance (see section "Crash reporting" for more information. +* If you want to help NewPipe to become free of bugs (this is our utopic goal for NewPipe), you can send us an email to +tnp@newpipe.schabi.org to let me know that you intend to help. We'll send you further instructions. You may, on request, +register at our [Sentry](https://sentry.schabi.org) instance (see section "Crash reporting" for more information. ## Translation -* NewPipe can be translated via [Weblate](https://hosted.weblate.org/projects/newpipe/strings/). You can log in there with your GitHub account. +* NewPipe can be translated via [Weblate](https://hosted.weblate.org/projects/newpipe/strings/). You can log in there +with your GitHub account. ## Code contribution * Stick to NewPipe's style conventions (well, just look the other code and then do it the same way :)) -* Do not bring non-free software (e.g., binary blobs) into the project. Also, make sure you do not introduce Google libraries. +* Do not bring non-free software (e.g., binary blobs) into the project. Also, make sure you do not introduce Google + libraries. * Stick to [F-Droid contribution guidelines](https://f-droid.org/wiki/page/Inclusion_Policy) -* Make changes on a separate branch, not on the master branch. This is commonly known as *feature branch workflow*. You may then send your changes as a pull request on GitHub. Patches to the email address mentioned in this document might not be considered, GitHub is the primary platform. (This only affects you if you are a member of TeamNewPipe) -* When submitting changes, you confirm that your code is licensed under the terms of the [GNU General Public License v3](https://www.gnu.org/licenses/gpl-3.0.html). -* Please test (compile and run) your code before you submit changes! Ideally, provide test feedback in the PR description. Untested code will **not** be merged! +* Make changes on a separate branch, not on the master branch. This is commonly known as *feature branch workflow*. You + may then send your changes as a pull request on GitHub. Patches to the email address mentioned in this document might + not be considered, GitHub is the primary platform. (This only affects you if you are a member of TeamNewPipe) +* When submitting changes, you confirm that your code is licensed under the terms of the + [GNU General Public License v3](https://www.gnu.org/licenses/gpl-3.0.html). +* Please test (compile and run) your code before you submit changes! Ideally, provide test feedback in the PR + description. Untested code will **not** be merged! * Try to figure out yourself why builds on our CI fail. -* Make sure your PR is up-to-date with the rest of the code. Often, a simple click on "Update branch" will do the job, but if not, you are asked to merge the master branch manually and resolve the problems on your own. That will make the maintainers' jobs way easier. -* Please show intention to maintain your features and code after you contributed it. Unmaintained code is a hassle for the core developers, and just adds work. If you do not intend to maintain features you contributed, please think again about submission, or clearly state that in the description of your PR. +* Make sure your PR is up-to-date with the rest of the code. Often, a simple click on "Update branch" will do the job, + but if not, you are asked to merge the master branch manually and resolve the problems on your own. That will make the + maintainers' jobs way easier. +* Please show intention to maintain your features and code after you contributed it. Unmaintained code is a hassle for + the core developers, and just adds work. If you do not intend to maintain features you contributed, please think again + about submission, or clearly state that in the description of your PR. * Respond yourselves if someone requests changes or otherwise raises issues about your PRs. * Check if your contributions align with the [fdroid inclusion guidelines](https://f-droid.org/en/docs/Inclusion_Policy/). * Check if your submission can be build with the current fdroid build server setup. +* Send PR that only cover one specific issue/solution/bug. Do not send PRs that are huge and consists of multiple + independent solutions. ## Communication * WE DO NOW HAVE A MAILING LIST: [newpipe@list.schabi.org](https://list.schabi.org/cgi-bin/mailman/listinfo/newpipe). -* There is an IRC channel on Freenode which is regularly visited by the core team and other developers: [#newpipe](irc:irc.freenode.net/newpipe). [Click here for Webchat](https://webchat.freenode.net/?channels=newpipe)! -* If you want to get in touch with the core team or one of our other contributors you can send an email to tnp(at)schabi.org. Please do not send issue reports, they will be ignored and remain unanswered! Use the GitHub issue tracker described above! +* There is an IRC channel on Freenode which is regularly visited by the core team and other developers: + [#newpipe](irc:irc.freenode.net/newpipe). [Click here for Webchat](https://webchat.freenode.net/?channels=newpipe)! +* If you want to get in touch with the core team or one of our other contributors you can send an email to + tnp(at)schabi.org. Please do not send issue reports, they will be ignored and remain unanswered! Use the GitHub issue + tracker described above! * Feel free to post suggestions, changes, ideas etc. on GitHub, IRC or the mailing list! diff --git a/.travis.yml b/.travis.yml index d5d3aed9c..d6f97ab55 100644 --- a/.travis.yml +++ b/.travis.yml @@ -5,13 +5,13 @@ android: components: # The BuildTools version used by NewPipe - tools - - build-tools-27.0.3 + - build-tools-28.0.3 # The SDK version used to compile NewPipe - - android-27 + - android-28 before_install: - - yes | sdkmanager "platforms;android-27" + - yes | sdkmanager "platforms;android-28" script: ./gradlew -Dorg.gradle.jvmargs=-Xmx1536m assembleDebug lintDebug testDebugUnitTest licenses: diff --git a/README.md b/README.md index b154fad58..15ba3d04b 100644 --- a/README.md +++ b/README.md @@ -1,74 +1,77 @@ -

+

NewPipe

-

A free lightweight YouTube frontend for Android.

-

+

A libre lightweight streaming frontend for Android.

+

- - - - - - + + + + + +

-
+

ScreenshotsDescriptionFeaturesContributionDonateLicense

WebsiteBlogPress

-
-WARNING: PUTTING NEWPIPE OR ANY FORK OF IT INTO GOOGLE PLAYSTORE VIOLATES THEIR TERMS OF CONDITIONS. +
+ +WARNING: PUTTING NEWPIPE OR ANY FORK OF IT INTO GOOGLE PLAYSTORE VIOLATES THEIR TERMS OF CONDITIONS. ## Screenshots -[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_1.png) -[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_2.png) -[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_3.png) -[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_4.png) -[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_5.png) -[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_6.png) -[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_7.png) -[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_8.png) -[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_9.png) +[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_01.png) +[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_02.png) +[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_03.png) +[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_04.png) +[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_05.png) +[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_06.png) +[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_07.png) +[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_08.png) +[](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_09.png) [](fastlane/metadata/android/en-US/images/phoneScreenshots/shot_10.png) +[](fastlane/metadata/android/en-US/images/tenInchScreenshots/shot_11.png) +[](fastlane/metadata/android/en-US/images/tenInchScreenshots/shot_12.png) ## Description -NewPipe does not use any Google framework libraries, or the YouTube API. It only parses the website in order to gain the information it needs. Therefore this app can be used on devices without Google Services installed. Also, you don't need a YouTube account to use NewPipe, and it's FLOSS. +NewPipe does not use any Google framework libraries, nor the YouTube API. Websites are only parsed to fetch required info, so this app can be used on devices without Google services installed. Also, you don't need a YouTube account to use NewPipe, which is copylefted libre software. ### Features * Search videos -* Display general information about a video +* Display general info about videos * Watch YouTube videos * Listen to YouTube videos * Popup mode (floating player) -* Select the streaming player to watch the video with -* Download videos +* Select streaming player to watch video with +* Download videos * Download audio only * Open a video in Kodi -* Show Next/Related videos +* Show next/related videos * Search YouTube in a specific language * Watch/Block age restricted material -* Display general information about channels +* Display general info about channels * Search channels * Watch videos from a channel * Orbot/Tor support (not yet directly) -* 1080p/2k/4k support +* 1080p/2K/4K support * View history * Subscribe to channels * Search history -* Search/Watch Playlists -* Watch as queues Playlists -* Queuing videos +* Search/watch playlists +* Watch as enqueued playlists +* Enqueue videos * Local playlists * Subtitles -* Multi-service support (eg. SoundCloud in NewPipe Beta) +* Multi-service support (e.g. SoundCloud \[beta\]) +* Livestream support ### Coming Features -* Livestream support * Cast to UPnP and Cast * Show comments -* ... and many more +* … and many more ## Contribution Whether you have ideas, translations, design changes, code cleaning, or real heavy code changes, help is always welcome. @@ -77,26 +80,31 @@ The more is done the better it gets! If you'd like to get involved, check our [contribution notes](.github/CONTRIBUTING.md). ## Donate -If you like NewPipe we'd be happy about a donation. You can either donate via Bitcoin, Bountysource or Liberapay. For further information about donating to NewPipe, please visit our [website](https://newpipe.schabi.org/donate). +If you like NewPipe we'd be happy about a donation. You can either send bitcoin or donate via Bountysource or Liberapay. For further info on donating to NewPipe, please visit our [website](https://newpipe.schabi.org/donate). - - + + - - - + + + - - - + + +
BitcoinBitcoin QR CodeBitcoinBitcoin QR code 16A9J59ahMRqkLSZjhYj33n9j3fMztFxnh
LiberapayVisit NewPipe at liberapay.comDonate via LiberapayLiberapayVisit NewPipe at liberapay.comDonate via Liberapay
BountysourceVisit NewPipe at bountysource.comCheck out how many bounties you can earn.BountysourceVisit NewPipe at bountysource.comCheck out how many bounties you can earn.
+## Privacy Policy + +The NewPipe project aims to provide a private, anonymous experience for using media web services. +Therefore, the app does not collect any data without your consent. NewPipe's privacy policy explains in detail what data is sent and stored when you send a crash report, or comment in our blog. You can find the document [here](https://newpipe.schabi.org/legal/privacy/). + ## License [![GNU GPLv3 Image](https://www.gnu.org/graphics/gplv3-127x51.png)](http://www.gnu.org/licenses/gpl-3.0.en.html) diff --git a/app/build.gradle b/app/build.gradle index 2104d2023..b34970907 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -1,15 +1,15 @@ apply plugin: 'com.android.application' android { - compileSdkVersion 27 - buildToolsVersion '27.0.3' + compileSdkVersion 28 + buildToolsVersion '28.0.3' defaultConfig { applicationId "org.schabi.newpipe" - minSdkVersion 15 - targetSdkVersion 27 - versionCode 68 - versionName "0.14.1" + minSdkVersion 19 + targetSdkVersion 28 + versionCode 69 + versionName "0.14.2" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" vectorDrawables.useSupportLibrary = true @@ -22,7 +22,6 @@ android { } debug { multiDexEnabled true - debuggable true applicationIdSuffix ".debug" } @@ -41,62 +40,61 @@ android { } ext { - supportLibVersion = '27.1.1' - exoPlayerLibVersion = '2.8.2' + supportLibVersion = '28.0.0' + exoPlayerLibVersion = '2.8.4' //2.9.0 roomDbLibVersion = '1.1.1' - leakCanaryLibVersion = '1.5.4' - okHttpLibVersion = '3.10.0' + leakCanaryLibVersion = '1.5.4' //1.6.1 + okHttpLibVersion = '3.11.0' icepickLibVersion = '3.2.0' stethoLibVersion = '1.5.0' } dependencies { - androidTestImplementation('com.android.support.test.espresso:espresso-core:2.2.2') { + androidTestImplementation('com.android.support.test.espresso:espresso-core:3.0.2', { exclude module: 'support-annotations' - } + }) - implementation 'com.github.yausername:NewPipeExtractor:d1ff1c7' + implementation 'com.github.yausername:NewPipeExtractor:4c49a34' testImplementation 'junit:junit:4.12' - testImplementation 'org.mockito:mockito-core:2.8.9' + testImplementation 'org.mockito:mockito-core:2.23.0' - implementation "com.android.support:appcompat-v7:$supportLibVersion" - implementation "com.android.support:support-v4:$supportLibVersion" - implementation "com.android.support:design:$supportLibVersion" - implementation "com.android.support:recyclerview-v7:$supportLibVersion" - implementation "com.android.support:preference-v14:$supportLibVersion" + implementation "com.android.support:appcompat-v7:${supportLibVersion}" + implementation "com.android.support:support-v4:${supportLibVersion}" + implementation "com.android.support:design:${supportLibVersion}" + implementation "com.android.support:recyclerview-v7:${supportLibVersion}" + implementation "com.android.support:preference-v14:${supportLibVersion}" + implementation "com.android.support:cardview-v7:${supportLibVersion}" + implementation 'com.android.support.constraint:constraint-layout:1.1.3' - implementation 'ch.acra:acra:4.9.2' + implementation 'ch.acra:acra:4.9.2' //4.11 implementation 'com.nostra13.universalimageloader:universal-image-loader:1.9.5' implementation 'de.hdodenhof:circleimageview:2.2.0' implementation 'com.github.nirhart:ParallaxScroll:dd53d1f9d1' implementation 'com.nononsenseapps:filepicker:4.2.1' - implementation "com.google.android.exoplayer:exoplayer:$exoPlayerLibVersion" - implementation "com.google.android.exoplayer:extension-mediasession:$exoPlayerLibVersion" + implementation "com.google.android.exoplayer:exoplayer:${exoPlayerLibVersion}" + implementation "com.google.android.exoplayer:extension-mediasession:${exoPlayerLibVersion}" - debugImplementation "com.facebook.stetho:stetho:$stethoLibVersion" - debugImplementation "com.facebook.stetho:stetho-urlconnection:$stethoLibVersion" + debugImplementation "com.facebook.stetho:stetho:${stethoLibVersion}" + debugImplementation "com.facebook.stetho:stetho-urlconnection:${stethoLibVersion}" debugImplementation 'com.android.support:multidex:1.0.3' - implementation 'io.reactivex.rxjava2:rxjava:2.1.14' - implementation 'io.reactivex.rxjava2:rxandroid:2.0.2' + implementation 'io.reactivex.rxjava2:rxjava:2.2.2' + implementation 'io.reactivex.rxjava2:rxandroid:2.1.0' implementation 'com.jakewharton.rxbinding2:rxbinding:2.1.1' - implementation "android.arch.persistence.room:runtime:$roomDbLibVersion" - implementation "android.arch.persistence.room:rxjava2:$roomDbLibVersion" - annotationProcessor "android.arch.persistence.room:compiler:$roomDbLibVersion" + implementation "android.arch.persistence.room:runtime:${roomDbLibVersion}" + implementation "android.arch.persistence.room:rxjava2:${roomDbLibVersion}" + annotationProcessor "android.arch.persistence.room:compiler:${roomDbLibVersion}" - implementation "frankiesardo:icepick:$icepickLibVersion" - annotationProcessor "frankiesardo:icepick-processor:$icepickLibVersion" + implementation "frankiesardo:icepick:${icepickLibVersion}" + annotationProcessor "frankiesardo:icepick-processor:${icepickLibVersion}" - debugImplementation "com.squareup.leakcanary:leakcanary-android:$leakCanaryLibVersion" - releaseImplementation "com.squareup.leakcanary:leakcanary-android-no-op:$leakCanaryLibVersion" + debugImplementation "com.squareup.leakcanary:leakcanary-android:${leakCanaryLibVersion}" + releaseImplementation "com.squareup.leakcanary:leakcanary-android-no-op:${leakCanaryLibVersion}" - - implementation "com.squareup.okhttp3:okhttp:$okHttpLibVersion" - debugImplementation "com.facebook.stetho:stetho-okhttp3:$stethoLibVersion" - implementation 'com.android.support.constraint:constraint-layout:1.1.2' - implementation 'com.android.support:cardview-v7:27.1.1' + implementation "com.squareup.okhttp3:okhttp:${okHttpLibVersion}" + debugImplementation "com.facebook.stetho:stetho-okhttp3:${stethoLibVersion}" } diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index e4d448184..1bc205f33 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -9,6 +9,7 @@ + - \ No newline at end of file + diff --git a/app/src/main/java/android/support/design/widget/FlingBehavior.java b/app/src/main/java/android/support/design/widget/FlingBehavior.java index 217e3ae3a..a453d302b 100644 --- a/app/src/main/java/android/support/design/widget/FlingBehavior.java +++ b/app/src/main/java/android/support/design/widget/FlingBehavior.java @@ -2,8 +2,8 @@ package android.support.design.widget; import android.animation.ValueAnimator; import android.content.Context; -import android.os.Parcelable; import android.support.annotation.NonNull; +import android.support.design.animation.AnimationUtils; import android.util.AttributeSet; import android.view.View; @@ -20,11 +20,6 @@ public final class FlingBehavior extends AppBarLayout.Behavior { super(context, attrs); } - @Override - public boolean onStartNestedScroll(CoordinatorLayout parent, AppBarLayout child, View directTargetChild, View target, int nestedScrollAxes, int type) { - return super.onStartNestedScroll(parent, child, directTargetChild, target, nestedScrollAxes, type); - } - @Override public void onNestedPreScroll(CoordinatorLayout coordinatorLayout, AppBarLayout child, View target, int dx, int dy, int[] consumed, int type) { if (dy != 0) { @@ -43,31 +38,6 @@ public final class FlingBehavior extends AppBarLayout.Behavior { } } - @Override - public void onNestedScroll(CoordinatorLayout coordinatorLayout, AppBarLayout child, View target, int dxConsumed, int dyConsumed, int dxUnconsumed, int dyUnconsumed, int type) { - super.onNestedScroll(coordinatorLayout, child, target, dxConsumed, dyConsumed, dxUnconsumed, dyUnconsumed, type); - } - - @Override - public void onStopNestedScroll(CoordinatorLayout coordinatorLayout, AppBarLayout abl, View target, int type) { - super.onStopNestedScroll(coordinatorLayout, abl, target, type); - } - - @Override - public boolean onMeasureChild(CoordinatorLayout parent, AppBarLayout child, int parentWidthMeasureSpec, int widthUsed, int parentHeightMeasureSpec, int heightUsed) { - return super.onMeasureChild(parent, child, parentWidthMeasureSpec, widthUsed, parentHeightMeasureSpec, heightUsed); - } - - @Override - public Parcelable onSaveInstanceState(CoordinatorLayout parent, AppBarLayout abl) { - return super.onSaveInstanceState(parent, abl); - } - - @Override - public void onRestoreInstanceState(CoordinatorLayout parent, AppBarLayout appBarLayout, Parcelable state) { - super.onRestoreInstanceState(parent, appBarLayout, state); - } - @Override public boolean onNestedPreFling(@NonNull CoordinatorLayout coordinatorLayout, @NonNull AppBarLayout child, @NonNull View target, float velocityX, float velocityY) { diff --git a/app/src/main/java/org/schabi/newpipe/App.java b/app/src/main/java/org/schabi/newpipe/App.java index dfce8f100..314c95c8d 100644 --- a/app/src/main/java/org/schabi/newpipe/App.java +++ b/app/src/main/java/org/schabi/newpipe/App.java @@ -5,6 +5,7 @@ import android.app.NotificationChannel; import android.app.NotificationManager; import android.content.Context; import android.os.Build; +import android.preference.PreferenceManager; import android.support.annotation.Nullable; import android.util.Log; @@ -21,6 +22,7 @@ import org.acra.config.ConfigurationBuilder; import org.acra.sender.ReportSenderFactory; import org.schabi.newpipe.extractor.Downloader; import org.schabi.newpipe.extractor.NewPipe; +import org.schabi.newpipe.extractor.utils.Localization; import org.schabi.newpipe.report.AcraReportSenderFactory; import org.schabi.newpipe.report.ErrorActivity; import org.schabi.newpipe.report.UserAction; @@ -65,7 +67,8 @@ public class App extends Application { private RefWatcher refWatcher; @SuppressWarnings("unchecked") - private static final Class[] reportSenderFactoryClasses = new Class[]{AcraReportSenderFactory.class}; + private static final Class[] + reportSenderFactoryClasses = new Class[]{AcraReportSenderFactory.class}; @Override protected void attachBaseContext(Context base) { @@ -88,7 +91,8 @@ public class App extends Application { // Initialize settings first because others inits can use its values SettingsActivity.initSettings(this); - NewPipe.init(getDownloader()); + NewPipe.init(getDownloader(), + org.schabi.newpipe.util.Localization.getPreferredExtractorLocal(this)); StateSaver.init(this); initNotificationChannel(); @@ -180,7 +184,11 @@ public class App extends Application { ACRA.init(this, acraConfig); } catch (ACRAConfigurationException ace) { ace.printStackTrace(); - ErrorActivity.reportError(this, ace, null, null, ErrorActivity.ErrorInfo.make(UserAction.SOMETHING_ELSE, "none", + ErrorActivity.reportError(this, + ace, + null, + null, + ErrorActivity.ErrorInfo.make(UserAction.SOMETHING_ELSE, "none", "Could not initialize ACRA crash report", R.string.app_ui_crash)); } } @@ -200,7 +208,8 @@ public class App extends Application { NotificationChannel mChannel = new NotificationChannel(id, name, importance); mChannel.setDescription(description); - NotificationManager mNotificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); + NotificationManager mNotificationManager = + (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); mNotificationManager.createNotificationChannel(mChannel); } diff --git a/app/src/main/java/org/schabi/newpipe/Downloader.java b/app/src/main/java/org/schabi/newpipe/Downloader.java index 16f2ed4ae..26c58e277 100644 --- a/app/src/main/java/org/schabi/newpipe/Downloader.java +++ b/app/src/main/java/org/schabi/newpipe/Downloader.java @@ -6,6 +6,7 @@ import android.text.TextUtils; import org.schabi.newpipe.extractor.DownloadRequest; import org.schabi.newpipe.extractor.DownloadResponse; import org.schabi.newpipe.extractor.exceptions.ReCaptchaException; +import org.schabi.newpipe.extractor.utils.Localization; import java.io.IOException; import java.io.InputStream; @@ -109,13 +110,13 @@ public class Downloader implements org.schabi.newpipe.extractor.Downloader { * but set the HTTP header field "Accept-Language" to the supplied string. * * @param siteUrl the URL of the text file to return the contents of - * @param language the language (usually a 2-character code) to set as the preferred language + * @param localization the language and country (usually a 2-character code) to set * @return the contents of the specified text file */ @Override - public String download(String siteUrl, String language) throws IOException, ReCaptchaException { + public String download(String siteUrl, Localization localization) throws IOException, ReCaptchaException { Map requestProperties = new HashMap<>(); - requestProperties.put("Accept-Language", language); + requestProperties.put("Accept-Language", localization.getLanguage()); return download(siteUrl, requestProperties); } diff --git a/app/src/main/java/org/schabi/newpipe/RouterActivity.java b/app/src/main/java/org/schabi/newpipe/RouterActivity.java index e22e2f474..b8941670f 100644 --- a/app/src/main/java/org/schabi/newpipe/RouterActivity.java +++ b/app/src/main/java/org/schabi/newpipe/RouterActivity.java @@ -542,8 +542,7 @@ public class RouterActivity extends AppCompatActivity { final SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(this); boolean isExtVideoEnabled = preferences.getBoolean(getString(R.string.use_external_video_player_key), false); - boolean isExtAudioEnabled = preferences.getBoolean(getString(R.string.use_external_audio_player_key), false); - boolean useOldVideoPlayer = PlayerHelper.isUsingOldPlayer(this); + boolean isExtAudioEnabled = preferences.getBoolean(getString(R.string.use_external_audio_player_key), false);; PlayQueue playQueue; String playerChoice = choice.playerChoice; @@ -555,9 +554,6 @@ public class RouterActivity extends AppCompatActivity { } else if (playerChoice.equals(videoPlayerKey) && isExtVideoEnabled) { NavigationHelper.playOnExternalVideoPlayer(this, (StreamInfo) info); - } else if (playerChoice.equals(videoPlayerKey) && useOldVideoPlayer) { - NavigationHelper.playOnOldVideoPlayer(this, (StreamInfo) info); - } else { playQueue = new SinglePlayQueue((StreamInfo) info); diff --git a/app/src/main/java/org/schabi/newpipe/fragments/detail/VideoDetailFragment.java b/app/src/main/java/org/schabi/newpipe/fragments/detail/VideoDetailFragment.java index d3f602ebd..3d5ac2d14 100644 --- a/app/src/main/java/org/schabi/newpipe/fragments/detail/VideoDetailFragment.java +++ b/app/src/main/java/org/schabi/newpipe/fragments/detail/VideoDetailFragment.java @@ -73,8 +73,6 @@ import org.schabi.newpipe.local.dialog.PlaylistAppendDialog; import org.schabi.newpipe.local.history.HistoryRecordManager; import org.schabi.newpipe.player.MainVideoPlayer; import org.schabi.newpipe.player.PopupVideoPlayer; -import org.schabi.newpipe.player.helper.PlayerHelper; -import org.schabi.newpipe.player.old.PlayVideoActivity; import org.schabi.newpipe.player.playqueue.PlayQueue; import org.schabi.newpipe.player.playqueue.SinglePlayQueue; import org.schabi.newpipe.report.ErrorActivity; @@ -154,6 +152,7 @@ public class VideoDetailFragment private View videoTitleRoot; private TextView videoTitleTextView; + @Nullable private ImageView videoTitleToggleArrow; private TextView videoCountView; @@ -420,14 +419,16 @@ public class VideoDetailFragment } private void toggleTitleAndDescription() { - if (videoDescriptionRootLayout.getVisibility() == View.VISIBLE) { - videoTitleTextView.setMaxLines(1); - videoDescriptionRootLayout.setVisibility(View.GONE); - videoTitleToggleArrow.setImageResource(R.drawable.arrow_down); - } else { - videoTitleTextView.setMaxLines(10); - videoDescriptionRootLayout.setVisibility(View.VISIBLE); - videoTitleToggleArrow.setImageResource(R.drawable.arrow_up); + if (videoTitleToggleArrow != null) { //it is null for tablets + if (videoDescriptionRootLayout.getVisibility() == View.VISIBLE) { + videoTitleTextView.setMaxLines(1); + videoDescriptionRootLayout.setVisibility(View.GONE); + videoTitleToggleArrow.setImageResource(R.drawable.arrow_down); + } else { + videoTitleTextView.setMaxLines(10); + videoDescriptionRootLayout.setVisibility(View.VISIBLE); + videoTitleToggleArrow.setImageResource(R.drawable.arrow_up); + } } } @@ -581,6 +582,7 @@ public class VideoDetailFragment } } + /*////////////////////////////////////////////////////////////////////////// // Menu //////////////////////////////////////////////////////////////////////////*/ @@ -872,7 +874,7 @@ public class VideoDetailFragment .getBoolean(this.getString(R.string.use_external_video_player_key), false)) { startOnExternalPlayer(activity, currentInfo, selectedVideoStream); } else { - openNormalPlayer(selectedVideoStream); + openNormalPlayer(); } } @@ -885,24 +887,13 @@ public class VideoDetailFragment } } - private void openNormalPlayer(VideoStream selectedVideoStream) { + private void openNormalPlayer() { Intent mIntent; - boolean useOldPlayer = PlayerHelper.isUsingOldPlayer(activity) || (Build.VERSION.SDK_INT < 16); - if (!useOldPlayer) { - // ExoPlayer - final PlayQueue playQueue = new SinglePlayQueue(currentInfo); - mIntent = NavigationHelper.getPlayerIntent(activity, - MainVideoPlayer.class, - playQueue, - getSelectedVideoStream().getResolution()); - } else { - // Internal Player - mIntent = new Intent(activity, PlayVideoActivity.class) - .putExtra(PlayVideoActivity.VIDEO_TITLE, currentInfo.getName()) - .putExtra(PlayVideoActivity.STREAM_URL, selectedVideoStream.getUrl()) - .putExtra(PlayVideoActivity.VIDEO_URL, currentInfo.getUrl()) - .putExtra(PlayVideoActivity.START_POSITION, currentInfo.getStartPosition()); - } + final PlayQueue playQueue = new SinglePlayQueue(currentInfo); + mIntent = NavigationHelper.getPlayerIntent(activity, + MainVideoPlayer.class, + playQueue, + getSelectedVideoStream().getResolution()); startActivity(mIntent); } @@ -1042,8 +1033,12 @@ public class VideoDetailFragment animateView(videoTitleTextView, true, 0); videoDescriptionRootLayout.setVisibility(View.GONE); - videoTitleToggleArrow.setImageResource(R.drawable.arrow_down); - videoTitleToggleArrow.setVisibility(View.GONE); + if (videoTitleToggleArrow != null) { //phone + videoTitleToggleArrow.setImageResource(R.drawable.arrow_down); + videoTitleToggleArrow.setVisibility(View.GONE); + } else { //tablet + //TODO make comments/related streams fragment invisible + } videoTitleRoot.setClickable(false); imageLoader.cancelDisplayTask(thumbnailImageView); @@ -1124,11 +1119,15 @@ public class VideoDetailFragment detailDurationView.setVisibility(View.GONE); } - videoTitleRoot.setClickable(true); - videoTitleToggleArrow.setVisibility(View.VISIBLE); - videoTitleToggleArrow.setImageResource(R.drawable.arrow_down); videoDescriptionView.setVisibility(View.GONE); - videoDescriptionRootLayout.setVisibility(View.GONE); + if (videoTitleToggleArrow != null) { + videoTitleRoot.setClickable(true); + videoTitleToggleArrow.setVisibility(View.VISIBLE); + videoTitleToggleArrow.setImageResource(R.drawable.arrow_down); + videoDescriptionRootLayout.setVisibility(View.GONE); + } else { + videoDescriptionRootLayout.setVisibility(View.VISIBLE); + } if (!TextUtils.isEmpty(info.getUploadDate())) { videoUploadDateView.setText(Localization.localizeDate(activity, info.getUploadDate())); } diff --git a/app/src/main/java/org/schabi/newpipe/fragments/list/BaseListFragment.java b/app/src/main/java/org/schabi/newpipe/fragments/list/BaseListFragment.java index 672d8c2be..e46606871 100644 --- a/app/src/main/java/org/schabi/newpipe/fragments/list/BaseListFragment.java +++ b/app/src/main/java/org/schabi/newpipe/fragments/list/BaseListFragment.java @@ -3,10 +3,15 @@ package org.schabi.newpipe.fragments.list; import android.app.Activity; import android.content.Context; import android.content.DialogInterface; +import android.content.SharedPreferences; +import android.content.res.Configuration; +import android.content.res.Resources; import android.os.Bundle; +import android.preference.PreferenceManager; import android.support.annotation.NonNull; import android.support.v7.app.ActionBar; import android.support.v7.app.AppCompatActivity; +import android.support.v7.widget.GridLayoutManager; import android.support.v7.widget.LinearLayoutManager; import android.support.v7.widget.RecyclerView; import android.util.Log; @@ -37,7 +42,7 @@ import java.util.Queue; import static org.schabi.newpipe.util.AnimationUtils.animateView; -public abstract class BaseListFragment extends BaseStateFragment implements ListViewContract, StateSaver.WriteRead { +public abstract class BaseListFragment extends BaseStateFragment implements ListViewContract, StateSaver.WriteRead, SharedPreferences.OnSharedPreferenceChangeListener { /*////////////////////////////////////////////////////////////////////////// // Views @@ -45,6 +50,9 @@ public abstract class BaseListFragment extends BaseStateFragment implem protected InfoListAdapter infoListAdapter; protected RecyclerView itemsList; + private int updateFlags = 0; + + private static final int LIST_MODE_UPDATE_FLAG = 0x32; /*////////////////////////////////////////////////////////////////////////// // LifeCycle @@ -60,12 +68,31 @@ public abstract class BaseListFragment extends BaseStateFragment implem public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setHasOptionsMenu(true); + PreferenceManager.getDefaultSharedPreferences(activity) + .registerOnSharedPreferenceChangeListener(this); } @Override public void onDestroy() { super.onDestroy(); StateSaver.onDestroy(savedState); + PreferenceManager.getDefaultSharedPreferences(activity) + .unregisterOnSharedPreferenceChangeListener(this); + } + + @Override + public void onResume() { + super.onResume(); + + if (updateFlags != 0) { + if ((updateFlags & LIST_MODE_UPDATE_FLAG) != 0) { + final boolean useGrid = isGridLayout(); + itemsList.setLayoutManager(useGrid ? getGridLayoutManager() : getListLayoutManager()); + infoListAdapter.setGridItemVariants(useGrid); + infoListAdapter.notifyDataSetChanged(); + } + updateFlags = 0; + } } /*////////////////////////////////////////////////////////////////////////// @@ -120,13 +147,25 @@ public abstract class BaseListFragment extends BaseStateFragment implem return new LinearLayoutManager(activity); } + protected RecyclerView.LayoutManager getGridLayoutManager() { + final Resources resources = activity.getResources(); + int width = resources.getDimensionPixelSize(R.dimen.video_item_grid_thumbnail_image_width); + width += (24 * resources.getDisplayMetrics().density); + final int spanCount = (int) Math.floor(resources.getDisplayMetrics().widthPixels / (double)width); + final GridLayoutManager lm = new GridLayoutManager(activity, spanCount); + lm.setSpanSizeLookup(infoListAdapter.getSpanSizeLookup(spanCount)); + return lm; + } + @Override protected void initViews(View rootView, Bundle savedInstanceState) { super.initViews(rootView, savedInstanceState); + final boolean useGrid = isGridLayout(); itemsList = rootView.findViewById(R.id.items_list); - itemsList.setLayoutManager(getListLayoutManager()); + itemsList.setLayoutManager(useGrid ? getGridLayoutManager() : getListLayoutManager()); + infoListAdapter.setGridItemVariants(useGrid); infoListAdapter.setFooter(getListFooter()); infoListAdapter.setHeader(getListHeader()); @@ -316,4 +355,22 @@ public abstract class BaseListFragment extends BaseStateFragment implem public void handleNextItems(N result) { isLoading.set(false); } + + @Override + public void onSharedPreferenceChanged(SharedPreferences sharedPreferences, String key) { + if (key.equals(getString(R.string.list_view_mode_key))) { + updateFlags |= LIST_MODE_UPDATE_FLAG; + } + } + + protected boolean isGridLayout() { + final String list_mode = PreferenceManager.getDefaultSharedPreferences(activity).getString(getString(R.string.list_view_mode_key), getString(R.string.list_view_mode_value)); + if ("auto".equals(list_mode)) { + final Configuration configuration = getResources().getConfiguration(); + return configuration.orientation == Configuration.ORIENTATION_LANDSCAPE + && configuration.isLayoutSizeAtLeast(Configuration.SCREENLAYOUT_SIZE_LARGE); + } else { + return "grid".equals(list_mode); + } + } } diff --git a/app/src/main/java/org/schabi/newpipe/fragments/list/kiosk/KioskFragment.java b/app/src/main/java/org/schabi/newpipe/fragments/list/kiosk/KioskFragment.java index 92138f7db..7d4500691 100644 --- a/app/src/main/java/org/schabi/newpipe/fragments/list/kiosk/KioskFragment.java +++ b/app/src/main/java/org/schabi/newpipe/fragments/list/kiosk/KioskFragment.java @@ -128,26 +128,16 @@ public class KioskFragment extends BaseListInfoFragment { @Override public Single loadResult(boolean forceReload) { - String contentCountry = PreferenceManager - .getDefaultSharedPreferences(activity) - .getString(getString(R.string.content_country_key), - getString(R.string.default_country_value)); return ExtractorHelper.getKioskInfo(serviceId, url, - contentCountry, forceReload); } @Override public Single loadMoreItemsLogic() { - String contentCountry = PreferenceManager - .getDefaultSharedPreferences(activity) - .getString(getString(R.string.content_country_key), - getString(R.string.default_country_value)); return ExtractorHelper.getMoreKioskItems(serviceId, url, - currentNextPageUrl, - contentCountry); + currentNextPageUrl); } /*////////////////////////////////////////////////////////////////////////// diff --git a/app/src/main/java/org/schabi/newpipe/fragments/list/search/SearchFragment.java b/app/src/main/java/org/schabi/newpipe/fragments/list/search/SearchFragment.java index 19c7d463e..2833abb8d 100644 --- a/app/src/main/java/org/schabi/newpipe/fragments/list/search/SearchFragment.java +++ b/app/src/main/java/org/schabi/newpipe/fragments/list/search/SearchFragment.java @@ -626,7 +626,7 @@ public class SearchFragment } final Observable> network = ExtractorHelper - .suggestionsFor(serviceId, query, contentCountry) + .suggestionsFor(serviceId, query) .toObservable() .map(strings -> { List result = new ArrayList<>(); @@ -726,8 +726,7 @@ public class SearchFragment searchDisposable = ExtractorHelper.searchFor(serviceId, searchString, Arrays.asList(contentFilter), - sortFilter, - contentCountry) + sortFilter) .subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) .doOnEvent((searchResult, throwable) -> isLoading.set(false)) @@ -745,8 +744,7 @@ public class SearchFragment searchString, asList(contentFilter), sortFilter, - nextPageUrl, - contentCountry) + nextPageUrl) .subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) .doOnEvent((nextItemsResult, throwable) -> isLoading.set(false)) diff --git a/app/src/main/java/org/schabi/newpipe/info_list/InfoListAdapter.java b/app/src/main/java/org/schabi/newpipe/info_list/InfoListAdapter.java index 64abf67f8..5e7095c7d 100644 --- a/app/src/main/java/org/schabi/newpipe/info_list/InfoListAdapter.java +++ b/app/src/main/java/org/schabi/newpipe/info_list/InfoListAdapter.java @@ -1,6 +1,7 @@ package org.schabi.newpipe.info_list; import android.app.Activity; +import android.support.v7.widget.GridLayoutManager; import android.support.v7.widget.RecyclerView; import android.util.Log; import android.view.View; @@ -15,9 +16,12 @@ import org.schabi.newpipe.info_list.holder.ChannelInfoItemHolder; import org.schabi.newpipe.info_list.holder.ChannelMiniInfoItemHolder; import org.schabi.newpipe.info_list.holder.CommentsInfoItemHolder; import org.schabi.newpipe.info_list.holder.CommentsMiniInfoItemHolder; +import org.schabi.newpipe.info_list.holder.ChannelGridInfoItemHolder; import org.schabi.newpipe.info_list.holder.InfoItemHolder; +import org.schabi.newpipe.info_list.holder.PlaylistGridInfoItemHolder; import org.schabi.newpipe.info_list.holder.PlaylistInfoItemHolder; import org.schabi.newpipe.info_list.holder.PlaylistMiniInfoItemHolder; +import org.schabi.newpipe.info_list.holder.StreamGridInfoItemHolder; import org.schabi.newpipe.info_list.holder.StreamInfoItemHolder; import org.schabi.newpipe.info_list.holder.StreamMiniInfoItemHolder; import org.schabi.newpipe.util.FallbackViewHolder; @@ -55,16 +59,20 @@ public class InfoListAdapter extends RecyclerView.Adapter infoItemList; private boolean useMiniVariant = false; + private boolean useGridVariant = false; private boolean showFooter = false; private View header = null; private View footer = null; @@ -103,6 +111,10 @@ public class InfoListAdapter extends RecyclerView.Adapter data) { if (data != null) { if (DEBUG) { @@ -215,11 +227,11 @@ public class InfoListAdapter extends RecyclerView.Adapter { + if (itemBuilder.getOnChannelSelectedListener() != null) { + itemBuilder.getOnChannelSelectedListener().held(item); + } + return true; + }); } protected String getDetailLine(final ChannelInfoItem item) { diff --git a/app/src/main/java/org/schabi/newpipe/info_list/holder/PlaylistGridInfoItemHolder.java b/app/src/main/java/org/schabi/newpipe/info_list/holder/PlaylistGridInfoItemHolder.java new file mode 100644 index 000000000..96b9c90a7 --- /dev/null +++ b/app/src/main/java/org/schabi/newpipe/info_list/holder/PlaylistGridInfoItemHolder.java @@ -0,0 +1,13 @@ +package org.schabi.newpipe.info_list.holder; + +import android.view.ViewGroup; + +import org.schabi.newpipe.R; +import org.schabi.newpipe.info_list.InfoItemBuilder; + +public class PlaylistGridInfoItemHolder extends PlaylistMiniInfoItemHolder { + + public PlaylistGridInfoItemHolder(InfoItemBuilder infoItemBuilder, ViewGroup parent) { + super(infoItemBuilder, R.layout.list_playlist_grid_item, parent); + } +} \ No newline at end of file diff --git a/app/src/main/java/org/schabi/newpipe/info_list/holder/StreamGridInfoItemHolder.java b/app/src/main/java/org/schabi/newpipe/info_list/holder/StreamGridInfoItemHolder.java new file mode 100644 index 000000000..a2e585857 --- /dev/null +++ b/app/src/main/java/org/schabi/newpipe/info_list/holder/StreamGridInfoItemHolder.java @@ -0,0 +1,13 @@ +package org.schabi.newpipe.info_list.holder; + +import android.view.ViewGroup; + +import org.schabi.newpipe.R; +import org.schabi.newpipe.info_list.InfoItemBuilder; + +public class StreamGridInfoItemHolder extends StreamMiniInfoItemHolder { + + public StreamGridInfoItemHolder(InfoItemBuilder infoItemBuilder, ViewGroup parent) { + super(infoItemBuilder, R.layout.list_stream_grid_item, parent); + } +} diff --git a/app/src/main/java/org/schabi/newpipe/local/BaseLocalListFragment.java b/app/src/main/java/org/schabi/newpipe/local/BaseLocalListFragment.java index 5192aa2ab..abdf82353 100644 --- a/app/src/main/java/org/schabi/newpipe/local/BaseLocalListFragment.java +++ b/app/src/main/java/org/schabi/newpipe/local/BaseLocalListFragment.java @@ -1,8 +1,13 @@ package org.schabi.newpipe.local; +import android.content.SharedPreferences; +import android.content.res.Configuration; +import android.content.res.Resources; import android.os.Bundle; +import android.preference.PreferenceManager; import android.support.v4.app.Fragment; import android.support.v7.app.ActionBar; +import android.support.v7.widget.GridLayoutManager; import android.support.v7.widget.LinearLayoutManager; import android.support.v7.widget.RecyclerView; import android.util.Log; @@ -25,7 +30,7 @@ import static org.schabi.newpipe.util.AnimationUtils.animateView; * called and is memory efficient when in backstack. * */ public abstract class BaseLocalListFragment extends BaseStateFragment - implements ListViewContract { + implements ListViewContract, SharedPreferences.OnSharedPreferenceChangeListener { /*////////////////////////////////////////////////////////////////////////// // Views @@ -36,6 +41,9 @@ public abstract class BaseLocalListFragment extends BaseStateFragment protected LocalItemListAdapter itemListAdapter; protected RecyclerView itemsList; + private int updateFlags = 0; + + private static final int LIST_MODE_UPDATE_FLAG = 0x32; /*////////////////////////////////////////////////////////////////////////// // Lifecycle - Creation @@ -45,6 +53,29 @@ public abstract class BaseLocalListFragment extends BaseStateFragment public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setHasOptionsMenu(true); + PreferenceManager.getDefaultSharedPreferences(activity) + .registerOnSharedPreferenceChangeListener(this); + } + + @Override + public void onDestroy() { + super.onDestroy(); + PreferenceManager.getDefaultSharedPreferences(activity) + .unregisterOnSharedPreferenceChangeListener(this); + } + + @Override + public void onResume() { + super.onResume(); + if (updateFlags != 0) { + if ((updateFlags & LIST_MODE_UPDATE_FLAG) != 0) { + final boolean useGrid = isGridLayout(); + itemsList.setLayoutManager(useGrid ? getGridLayoutManager() : getListLayoutManager()); + itemListAdapter.setGridItemVariants(useGrid); + itemListAdapter.notifyDataSetChanged(); + } + updateFlags = 0; + } } /*////////////////////////////////////////////////////////////////////////// @@ -59,6 +90,16 @@ public abstract class BaseLocalListFragment extends BaseStateFragment return activity.getLayoutInflater().inflate(R.layout.pignate_footer, itemsList, false); } + protected RecyclerView.LayoutManager getGridLayoutManager() { + final Resources resources = activity.getResources(); + int width = resources.getDimensionPixelSize(R.dimen.video_item_grid_thumbnail_image_width); + width += (24 * resources.getDisplayMetrics().density); + final int spanCount = (int) Math.floor(resources.getDisplayMetrics().widthPixels / (double)width); + final GridLayoutManager lm = new GridLayoutManager(activity, spanCount); + lm.setSpanSizeLookup(itemListAdapter.getSpanSizeLookup(spanCount)); + return lm; + } + protected RecyclerView.LayoutManager getListLayoutManager() { return new LinearLayoutManager(activity); } @@ -67,10 +108,13 @@ public abstract class BaseLocalListFragment extends BaseStateFragment protected void initViews(View rootView, Bundle savedInstanceState) { super.initViews(rootView, savedInstanceState); - itemsList = rootView.findViewById(R.id.items_list); - itemsList.setLayoutManager(getListLayoutManager()); - itemListAdapter = new LocalItemListAdapter(activity); + + final boolean useGrid = isGridLayout(); + itemsList = rootView.findViewById(R.id.items_list); + itemsList.setLayoutManager(useGrid ? getGridLayoutManager() : getListLayoutManager()); + + itemListAdapter.setGridItemVariants(useGrid); itemListAdapter.setHeader(headerRootView = getListHeader()); itemListAdapter.setFooter(footerRootView = getListFooter()); @@ -174,4 +218,22 @@ public abstract class BaseLocalListFragment extends BaseStateFragment resetFragment(); return super.onError(exception); } + + @Override + public void onSharedPreferenceChanged(SharedPreferences sharedPreferences, String key) { + if (key.equals(getString(R.string.list_view_mode_key))) { + updateFlags |= LIST_MODE_UPDATE_FLAG; + } + } + + protected boolean isGridLayout() { + final String list_mode = PreferenceManager.getDefaultSharedPreferences(activity).getString(getString(R.string.list_view_mode_key), getString(R.string.list_view_mode_value)); + if ("auto".equals(list_mode)) { + final Configuration configuration = getResources().getConfiguration(); + return configuration.orientation == Configuration.ORIENTATION_LANDSCAPE + && configuration.isLayoutSizeAtLeast(Configuration.SCREENLAYOUT_SIZE_LARGE); + } else { + return "grid".equals(list_mode); + } + } } diff --git a/app/src/main/java/org/schabi/newpipe/local/LocalItemListAdapter.java b/app/src/main/java/org/schabi/newpipe/local/LocalItemListAdapter.java index 99937b58c..e298dedd3 100644 --- a/app/src/main/java/org/schabi/newpipe/local/LocalItemListAdapter.java +++ b/app/src/main/java/org/schabi/newpipe/local/LocalItemListAdapter.java @@ -1,18 +1,21 @@ package org.schabi.newpipe.local; import android.app.Activity; +import android.support.v7.widget.GridLayoutManager; import android.support.v7.widget.RecyclerView; import android.util.Log; import android.view.View; import android.view.ViewGroup; import org.schabi.newpipe.database.LocalItem; -import org.schabi.newpipe.local.HeaderFooterHolder; -import org.schabi.newpipe.local.LocalItemBuilder; import org.schabi.newpipe.local.holder.LocalItemHolder; +import org.schabi.newpipe.local.holder.LocalPlaylistGridItemHolder; import org.schabi.newpipe.local.holder.LocalPlaylistItemHolder; +import org.schabi.newpipe.local.holder.LocalPlaylistStreamGridItemHolder; import org.schabi.newpipe.local.holder.LocalPlaylistStreamItemHolder; +import org.schabi.newpipe.local.holder.LocalStatisticStreamGridItemHolder; import org.schabi.newpipe.local.holder.LocalStatisticStreamItemHolder; +import org.schabi.newpipe.local.holder.RemotePlaylistGridItemHolder; import org.schabi.newpipe.local.holder.RemotePlaylistItemHolder; import org.schabi.newpipe.util.FallbackViewHolder; import org.schabi.newpipe.util.Localization; @@ -52,14 +55,19 @@ public class LocalItemListAdapter extends RecyclerView.Adapter localItems; private final DateFormat dateFormat; private boolean showFooter = false; + private boolean useGridVariant = false; private View header = null; private View footer = null; @@ -134,6 +142,10 @@ public class LocalItemListAdapter extends RecyclerView.Adapter> { +public class SubscriptionFragment extends BaseStateFragment> implements SharedPreferences.OnSharedPreferenceChangeListener { private static final int REQUEST_EXPORT_CODE = 666; private static final int REQUEST_IMPORT_CODE = 667; @@ -78,6 +89,9 @@ public class SubscriptionFragment extends BaseStateFragment() { - @Override + public void selected(ChannelInfoItem selectedItem) { final FragmentManager fragmentManager = getFM(); NavigationHelper.openChannelFragment(fragmentManager, @@ -326,6 +369,11 @@ public class SubscriptionFragment extends BaseStateFragment importExportOptions.switchState()); } + private void showLongTapDialog(ChannelInfoItem selectedItem) { + final Context context = getContext(); + final Activity activity = getActivity(); + if (context == null || context.getResources() == null || getActivity() == null) return; + + final String[] commands = new String[]{ + context.getResources().getString(R.string.share), + context.getResources().getString(R.string.unsubscribe) + }; + + final DialogInterface.OnClickListener actions = (dialogInterface, i) -> { + switch (i) { + case 0: + shareChannel(selectedItem); + break; + case 1: + deleteChannel(selectedItem); + break; + default: + break; + } + }; + + final View bannerView = View.inflate(activity, R.layout.dialog_title, null); + bannerView.setSelected(true); + + TextView titleView = bannerView.findViewById(R.id.itemTitleView); + titleView.setText(selectedItem.getName()); + + TextView detailsView = bannerView.findViewById(R.id.itemAdditionalDetails); + detailsView.setVisibility(View.GONE); + + new AlertDialog.Builder(activity) + .setCustomTitle(bannerView) + .setItems(commands, actions) + .create() + .show(); + + } + + private void shareChannel (ChannelInfoItem selectedItem) { + shareUrl(selectedItem.getName(), selectedItem.getUrl()); + } + + @SuppressLint("CheckResult") + private void deleteChannel (ChannelInfoItem selectedItem) { + subscriptionService.subscriptionTable() + .getSubscription(selectedItem.getServiceId(), selectedItem.getUrl()) + .toObservable() + .observeOn(Schedulers.io()) + .subscribe(getDeleteObserver()); + + Toast.makeText(activity, getString(R.string.channel_unsubscribed), Toast.LENGTH_SHORT).show(); + } + + + + private Observer> getDeleteObserver(){ + return new Observer>() { + @Override + public void onSubscribe(Disposable d) { + disposables.add(d); + } + + @Override + public void onNext(List subscriptionEntities) { + subscriptionService.subscriptionTable().delete(subscriptionEntities); + } + + @Override + public void onError(Throwable exception) { + SubscriptionFragment.this.onError(exception); + } + + @Override + public void onComplete() { } + }; + } + private void resetFragment() { if (disposables != null) disposables.clear(); if (infoListAdapter != null) infoListAdapter.clearStreamItemList(); @@ -445,4 +572,22 @@ public class SubscriptionFragment extends BaseStateFragment 0) { playQueue.setIndex(sizeBeforeAppend); } @@ -296,7 +322,6 @@ public abstract class BasePlayer implements databaseUpdateReactor.clear(); progressUpdateReactor.set(null); - simpleExoPlayer = null; } /*////////////////////////////////////////////////////////////////////////// @@ -424,13 +449,15 @@ public abstract class BasePlayer implements if (!isProgressLoopRunning()) startProgressLoop(); } - public void onBuffering() {} + public void onBuffering() { + } public void onPaused() { if (isProgressLoopRunning()) stopProgressLoop(); } - public void onPausedSeek() {} + public void onPausedSeek() { + } public void onCompleted() { if (DEBUG) Log.d(TAG, "onCompleted() called"); @@ -601,19 +628,19 @@ public abstract class BasePlayer implements /** * Processes the exceptions produced by {@link com.google.android.exoplayer2.ExoPlayer ExoPlayer}. * There are multiple types of errors:

- * + *

* {@link ExoPlaybackException#TYPE_SOURCE TYPE_SOURCE}:

- * + *

* {@link ExoPlaybackException#TYPE_UNEXPECTED TYPE_UNEXPECTED}:

* If a runtime error occurred, then we can try to recover it by restarting the playback * after setting the timestamp recovery.

- * + *

* {@link ExoPlaybackException#TYPE_RENDERER TYPE_RENDERER}:

* If the renderer failed, treat the error as unrecoverable. * * @see #processSourceError(IOException) * @see Player.EventListener#onPlayerError(ExoPlaybackException) - * */ + */ @Override public void onPlayerError(ExoPlaybackException error) { if (DEBUG) Log.d(TAG, "ExoPlayer - onPlayerError() called with: " + @@ -899,8 +926,8 @@ public abstract class BasePlayer implements if (DEBUG) Log.d(TAG, "onPlayPrevious() called"); /* If current playback has run for PLAY_PREV_ACTIVATION_LIMIT_MILLIS milliseconds, - * restart current track. Also restart the track if the current track - * is the first in a queue.*/ + * restart current track. Also restart the track if the current track + * is the first in a queue.*/ if (simpleExoPlayer.getCurrentPosition() > PLAY_PREV_ACTIVATION_LIMIT_MILLIS || playQueue.getIndex() == 0) { seekToDefault(); @@ -1009,8 +1036,8 @@ public abstract class BasePlayer implements try { metadata = (MediaSourceTag) simpleExoPlayer.getCurrentTag(); } catch (IndexOutOfBoundsException | ClassCastException error) { - if(DEBUG) Log.d(TAG, "Could not update metadata: " + error.getMessage()); - if(DEBUG) error.printStackTrace(); + if (DEBUG) Log.d(TAG, "Could not update metadata: " + error.getMessage()); + if (DEBUG) error.printStackTrace(); return; } @@ -1074,7 +1101,9 @@ public abstract class BasePlayer implements currentThumbnail; } - /** Checks if the current playback is a livestream AND is playing at or beyond the live edge */ + /** + * Checks if the current playback is a livestream AND is playing at or beyond the live edge + */ @SuppressWarnings("BooleanMethodIsAlwaysInverted") public boolean isLiveEdge() { if (simpleExoPlayer == null || !isLive()) return false; @@ -1098,13 +1127,14 @@ public abstract class BasePlayer implements } catch (@NonNull IndexOutOfBoundsException ignored) { // Why would this even happen =( // But lets log it anyway. Save is save - if(DEBUG) Log.d(TAG, "Could not update metadata: " + ignored.getMessage()); - if(DEBUG) ignored.printStackTrace(); + if (DEBUG) Log.d(TAG, "Could not update metadata: " + ignored.getMessage()); + if (DEBUG) ignored.printStackTrace(); return false; } } public boolean isPlaying() { + if (simpleExoPlayer == null) return false; final int state = simpleExoPlayer.getPlaybackState(); return (state == Player.STATE_READY || state == Player.STATE_BUFFERING) && simpleExoPlayer.getPlayWhenReady(); @@ -1112,7 +1142,9 @@ public abstract class BasePlayer implements @Player.RepeatMode public int getRepeatMode() { - return simpleExoPlayer == null ? Player.REPEAT_MODE_OFF : simpleExoPlayer.getRepeatMode(); + return simpleExoPlayer == null + ? Player.REPEAT_MODE_OFF + : simpleExoPlayer.getRepeatMode(); } public void setRepeatMode(@Player.RepeatMode final int repeatMode) { @@ -1178,4 +1210,8 @@ public abstract class BasePlayer implements if (DEBUG) Log.d(TAG, "Setting recovery, queue: " + queuePos + ", pos: " + windowPos); playQueue.setRecovery(queuePos, windowPos); } + + public boolean gotDestroyed() { + return simpleExoPlayer == null; + } } diff --git a/app/src/main/java/org/schabi/newpipe/player/MainVideoPlayer.java b/app/src/main/java/org/schabi/newpipe/player/MainVideoPlayer.java index 4e8398ff2..f4fea5165 100644 --- a/app/src/main/java/org/schabi/newpipe/player/MainVideoPlayer.java +++ b/app/src/main/java/org/schabi/newpipe/player/MainVideoPlayer.java @@ -175,6 +175,10 @@ public final class MainVideoPlayer extends AppCompatActivity setLandscape(lastOrientationWasLandscape); } + final int lastResizeMode = defaultPreferences.getInt( + getString(R.string.last_resize_mode), AspectRatioFrameLayout.RESIZE_MODE_FIT); + playerImpl.setResizeMode(lastResizeMode); + // Upon going in or out of multiwindow mode, isInMultiWindow will always be false, // since the first onResume needs to restore the player. // Subsequent onResume calls while multiwindow mode remains the same and the player is @@ -213,10 +217,9 @@ public final class MainVideoPlayer extends AppCompatActivity if (playerImpl == null) return; playerImpl.setRecovery(); - playerState = new PlayerState(playerImpl.getPlayQueue(), playerImpl.getRepeatMode(), - playerImpl.getPlaybackSpeed(), playerImpl.getPlaybackPitch(), - playerImpl.getPlaybackQuality(), playerImpl.getPlaybackSkipSilence(), - playerImpl.isPlaying()); + if(!playerImpl.gotDestroyed()) { + playerState = createPlayerState(); + } StateSaver.tryToSave(isChangingConfigurations(), null, outState, this); } @@ -231,6 +234,7 @@ public final class MainVideoPlayer extends AppCompatActivity if (!isBackPressed) { playerImpl.minimize(); } + playerState = createPlayerState(); playerImpl.destroy(); isInMultiWindow = false; @@ -241,6 +245,13 @@ public final class MainVideoPlayer extends AppCompatActivity // State Saving //////////////////////////////////////////////////////////////////////////*/ + private PlayerState createPlayerState() { + return new PlayerState(playerImpl.getPlayQueue(), playerImpl.getRepeatMode(), + playerImpl.getPlaybackSpeed(), playerImpl.getPlaybackPitch(), + playerImpl.getPlaybackQuality(), playerImpl.getPlaybackSkipSilence(), + playerImpl.isPlaying()); + } + @Override public String generateSuffix() { return "." + UUID.randomUUID().toString() + ".player"; @@ -705,14 +716,27 @@ public final class MainVideoPlayer extends AppCompatActivity @Override protected int nextResizeMode(int currentResizeMode) { + final int newResizeMode; switch (currentResizeMode) { case AspectRatioFrameLayout.RESIZE_MODE_FIT: - return AspectRatioFrameLayout.RESIZE_MODE_FILL; + newResizeMode = AspectRatioFrameLayout.RESIZE_MODE_FILL; + break; case AspectRatioFrameLayout.RESIZE_MODE_FILL: - return AspectRatioFrameLayout.RESIZE_MODE_ZOOM; + newResizeMode = AspectRatioFrameLayout.RESIZE_MODE_ZOOM; + break; default: - return AspectRatioFrameLayout.RESIZE_MODE_FIT; + newResizeMode = AspectRatioFrameLayout.RESIZE_MODE_FIT; + break; } + + storeResizeMode(newResizeMode); + return newResizeMode; + } + + private void storeResizeMode(@AspectRatioFrameLayout.ResizeMode int resizeMode) { + defaultPreferences.edit() + .putInt(getString(R.string.last_resize_mode), resizeMode) + .apply(); } @Override @@ -876,6 +900,11 @@ public final class MainVideoPlayer extends AppCompatActivity public void onMove(int sourceIndex, int targetIndex) { if (playQueue != null) playQueue.move(sourceIndex, targetIndex); } + + @Override + public void onSwiped(int index) { + if(index != -1) playQueue.remove(index); + } }; } @@ -989,12 +1018,14 @@ public final class MainVideoPlayer extends AppCompatActivity private static final int MOVEMENT_THRESHOLD = 40; - private final boolean isPlayerGestureEnabled = PlayerHelper.isPlayerGestureEnabled(getApplicationContext()); + private final boolean isVolumeGestureEnabled = PlayerHelper.isVolumeGestureEnabled(getApplicationContext()); + private final boolean isBrightnessGestureEnabled = PlayerHelper.isBrightnessGestureEnabled(getApplicationContext()); + private final int maxVolume = playerImpl.getAudioReactor().getMaxVolume(); @Override public boolean onScroll(MotionEvent initialEvent, MotionEvent movingEvent, float distanceX, float distanceY) { - if (!isPlayerGestureEnabled) return false; + if (!isVolumeGestureEnabled && !isBrightnessGestureEnabled) return false; //noinspection PointlessBooleanExpression if (DEBUG && false) Log.d(TAG, "MainVideoPlayer.onScroll = " + @@ -1010,7 +1041,11 @@ public final class MainVideoPlayer extends AppCompatActivity isMoving = true; - if (initialEvent.getX() > playerImpl.getRootView().getWidth() / 2) { + boolean acceptAnyArea = isVolumeGestureEnabled != isBrightnessGestureEnabled; + boolean acceptVolumeArea = acceptAnyArea || initialEvent.getX() > playerImpl.getRootView().getWidth() / 2; + boolean acceptBrightnessArea = acceptAnyArea || !acceptVolumeArea; + + if (isVolumeGestureEnabled && acceptVolumeArea) { playerImpl.getVolumeProgressBar().incrementProgressBy((int) distanceY); float currentProgressPercent = (float) playerImpl.getVolumeProgressBar().getProgress() / playerImpl.getMaxGestureLength(); @@ -1035,7 +1070,7 @@ public final class MainVideoPlayer extends AppCompatActivity if (playerImpl.getBrightnessRelativeLayout().getVisibility() == View.VISIBLE) { playerImpl.getBrightnessRelativeLayout().setVisibility(View.GONE); } - } else { + } else if (isBrightnessGestureEnabled && acceptBrightnessArea) { playerImpl.getBrightnessProgressBar().incrementProgressBy((int) distanceY); float currentProgressPercent = (float) playerImpl.getBrightnessProgressBar().getProgress() / playerImpl.getMaxGestureLength(); diff --git a/app/src/main/java/org/schabi/newpipe/player/PopupVideoPlayer.java b/app/src/main/java/org/schabi/newpipe/player/PopupVideoPlayer.java index a36a0576c..f5c731ed9 100644 --- a/app/src/main/java/org/schabi/newpipe/player/PopupVideoPlayer.java +++ b/app/src/main/java/org/schabi/newpipe/player/PopupVideoPlayer.java @@ -68,7 +68,6 @@ import org.schabi.newpipe.extractor.stream.VideoStream; import org.schabi.newpipe.player.event.PlayerEventListener; import org.schabi.newpipe.player.helper.LockManager; import org.schabi.newpipe.player.helper.PlayerHelper; -import org.schabi.newpipe.player.old.PlayVideoActivity; import org.schabi.newpipe.player.resolver.MediaSourceTag; import org.schabi.newpipe.player.resolver.VideoPlaybackResolver; import org.schabi.newpipe.util.ListHelper; @@ -80,7 +79,6 @@ import java.util.List; import static org.schabi.newpipe.player.BasePlayer.STATE_PLAYING; import static org.schabi.newpipe.player.VideoPlayer.DEFAULT_CONTROLS_DURATION; import static org.schabi.newpipe.player.VideoPlayer.DEFAULT_CONTROLS_HIDE_TIME; -import static org.schabi.newpipe.player.helper.PlayerHelper.isUsingOldPlayer; import static org.schabi.newpipe.util.AnimationUtils.animateView; /** @@ -554,27 +552,17 @@ public final class PopupVideoPlayer extends Service { if (DEBUG) Log.d(TAG, "onFullScreenButtonClicked() called"); setRecovery(); - Intent intent; - if (!isUsingOldPlayer(getApplicationContext())) { - intent = NavigationHelper.getPlayerIntent( - context, - MainVideoPlayer.class, - this.getPlayQueue(), - this.getRepeatMode(), - this.getPlaybackSpeed(), - this.getPlaybackPitch(), - this.getPlaybackSkipSilence(), - this.getPlaybackQuality() - ); - intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); - } else { - intent = new Intent(PopupVideoPlayer.this, PlayVideoActivity.class) - .putExtra(PlayVideoActivity.VIDEO_TITLE, getVideoTitle()) - .putExtra(PlayVideoActivity.STREAM_URL, getSelectedVideoStream().getUrl()) - .putExtra(PlayVideoActivity.VIDEO_URL, getVideoUrl()) - .putExtra(PlayVideoActivity.START_POSITION, Math.round(getPlayer().getCurrentPosition() / 1000f)); - intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); - } + final Intent intent = NavigationHelper.getPlayerIntent( + context, + MainVideoPlayer.class, + this.getPlayQueue(), + this.getRepeatMode(), + this.getPlaybackSpeed(), + this.getPlaybackPitch(), + this.getPlaybackSkipSilence(), + this.getPlaybackQuality() + ); + intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); context.startActivity(intent); closePopup(); } diff --git a/app/src/main/java/org/schabi/newpipe/player/ServicePlayerActivity.java b/app/src/main/java/org/schabi/newpipe/player/ServicePlayerActivity.java index 94305e6c4..2ec4275fc 100644 --- a/app/src/main/java/org/schabi/newpipe/player/ServicePlayerActivity.java +++ b/app/src/main/java/org/schabi/newpipe/player/ServicePlayerActivity.java @@ -375,6 +375,11 @@ public abstract class ServicePlayerActivity extends AppCompatActivity public void onMove(int sourceIndex, int targetIndex) { if (player != null) player.getPlayQueue().move(sourceIndex, targetIndex); } + + @Override + public void onSwiped(int index) { + if (index != -1) player.getPlayQueue().remove(index); + } }; } diff --git a/app/src/main/java/org/schabi/newpipe/player/VideoPlayer.java b/app/src/main/java/org/schabi/newpipe/player/VideoPlayer.java index 8e7db0dae..d30d9b8be 100644 --- a/app/src/main/java/org/schabi/newpipe/player/VideoPlayer.java +++ b/app/src/main/java/org/schabi/newpipe/player/VideoPlayer.java @@ -683,12 +683,17 @@ public abstract class VideoPlayer extends BasePlayer if (getAspectRatioFrameLayout() != null) { final int currentResizeMode = getAspectRatioFrameLayout().getResizeMode(); final int newResizeMode = nextResizeMode(currentResizeMode); - getAspectRatioFrameLayout().setResizeMode(newResizeMode); - getResizeView().setText(PlayerHelper.resizeTypeOf(context, newResizeMode)); + setResizeMode(newResizeMode); } } + protected void setResizeMode(@AspectRatioFrameLayout.ResizeMode final int resizeMode) { + getAspectRatioFrameLayout().setResizeMode(resizeMode); + getResizeView().setText(PlayerHelper.resizeTypeOf(context, resizeMode)); + } + protected abstract int nextResizeMode(@AspectRatioFrameLayout.ResizeMode final int resizeMode); + /*////////////////////////////////////////////////////////////////////////// // SeekBar Listener //////////////////////////////////////////////////////////////////////////*/ diff --git a/app/src/main/java/org/schabi/newpipe/player/helper/PlayerHelper.java b/app/src/main/java/org/schabi/newpipe/player/helper/PlayerHelper.java index 05afe2859..bd174eb45 100644 --- a/app/src/main/java/org/schabi/newpipe/player/helper/PlayerHelper.java +++ b/app/src/main/java/org/schabi/newpipe/player/helper/PlayerHelper.java @@ -19,11 +19,11 @@ import com.google.android.exoplayer2.util.MimeTypes; import org.schabi.newpipe.R; import org.schabi.newpipe.extractor.InfoItem; -import org.schabi.newpipe.extractor.Subtitles; +import org.schabi.newpipe.extractor.MediaFormat; import org.schabi.newpipe.extractor.stream.AudioStream; import org.schabi.newpipe.extractor.stream.StreamInfo; import org.schabi.newpipe.extractor.stream.StreamInfoItem; -import org.schabi.newpipe.extractor.stream.SubtitlesFormat; +import org.schabi.newpipe.extractor.stream.SubtitlesStream; import org.schabi.newpipe.extractor.stream.VideoStream; import org.schabi.newpipe.player.playqueue.PlayQueue; import org.schabi.newpipe.player.playqueue.PlayQueueItem; @@ -87,7 +87,7 @@ public class PlayerHelper { return pitchFormatter.format(pitch); } - public static String mimeTypesOf(final SubtitlesFormat format) { + public static String mimeTypesOf(final MediaFormat format) { switch (format) { case VTT: return MimeTypes.TEXT_VTT; case TTML: return MimeTypes.APPLICATION_TTML; @@ -97,7 +97,7 @@ public class PlayerHelper { @NonNull public static String captionLanguageOf(@NonNull final Context context, - @NonNull final Subtitles subtitles) { + @NonNull final SubtitlesStream subtitles) { final String displayName = subtitles.getLocale().getDisplayName(subtitles.getLocale()); return displayName + (subtitles.isAutoGenerated() ? " (" + context.getString(R.string.caption_auto_generated)+ ")" : ""); } @@ -169,12 +169,12 @@ public class PlayerHelper { return isResumeAfterAudioFocusGain(context, false); } - public static boolean isPlayerGestureEnabled(@NonNull final Context context) { - return isPlayerGestureEnabled(context, true); + public static boolean isVolumeGestureEnabled(@NonNull final Context context) { + return isVolumeGestureEnabled(context, true); } - public static boolean isUsingOldPlayer(@NonNull final Context context) { - return isUsingOldPlayer(context, false); + public static boolean isBrightnessGestureEnabled(@NonNull final Context context) { + return isBrightnessGestureEnabled(context, true); } public static boolean isRememberingPopupDimensions(@NonNull final Context context) { @@ -306,12 +306,12 @@ public class PlayerHelper { return getPreferences(context).getBoolean(context.getString(R.string.resume_on_audio_focus_gain_key), b); } - private static boolean isPlayerGestureEnabled(@NonNull final Context context, final boolean b) { - return getPreferences(context).getBoolean(context.getString(R.string.player_gesture_controls_key), b); + private static boolean isVolumeGestureEnabled(@NonNull final Context context, final boolean b) { + return getPreferences(context).getBoolean(context.getString(R.string.volume_gesture_control_key), b); } - private static boolean isUsingOldPlayer(@NonNull final Context context, final boolean b) { - return getPreferences(context).getBoolean(context.getString(R.string.use_old_player_key), b); + private static boolean isBrightnessGestureEnabled(@NonNull final Context context, final boolean b) { + return getPreferences(context).getBoolean(context.getString(R.string.brightness_gesture_control_key), b); } private static boolean isRememberingPopupDimensions(@NonNull final Context context, final boolean b) { diff --git a/app/src/main/java/org/schabi/newpipe/player/old/PlayVideoActivity.java b/app/src/main/java/org/schabi/newpipe/player/old/PlayVideoActivity.java deleted file mode 100644 index 092f82aad..000000000 --- a/app/src/main/java/org/schabi/newpipe/player/old/PlayVideoActivity.java +++ /dev/null @@ -1,369 +0,0 @@ -package org.schabi.newpipe.player.old; - -import android.content.Context; -import android.content.Intent; -import android.content.SharedPreferences; -import android.content.pm.ActivityInfo; -import android.content.res.Configuration; -import android.media.AudioManager; -import android.media.MediaPlayer; -import android.net.Uri; -import android.os.Build; -import android.os.Bundle; -import android.os.Handler; -import android.support.v7.app.ActionBar; -import android.support.v7.app.AppCompatActivity; -import android.util.DisplayMetrics; -import android.util.Log; -import android.view.Display; -import android.view.KeyEvent; -import android.view.Menu; -import android.view.MenuInflater; -import android.view.MenuItem; -import android.view.View; -import android.view.WindowManager; -import android.widget.Button; -import android.widget.MediaController; -import android.widget.ProgressBar; -import android.widget.VideoView; - -import org.schabi.newpipe.R; - -/* - * Copyright (C) Christian Schabesberger 2015 - * PlayVideoActivity.java is part of NewPipe. - * - * NewPipe is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * NewPipe is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with NewPipe. If not, see . - */ - -public class PlayVideoActivity extends AppCompatActivity { - - //// TODO: 11.09.15 add "choose stream" menu - - private static final String TAG = PlayVideoActivity.class.toString(); - public static final String VIDEO_URL = "video_url"; - public static final String STREAM_URL = "stream_url"; - public static final String VIDEO_TITLE = "video_title"; - private static final String POSITION = "position"; - public static final String START_POSITION = "start_position"; - - private static final long HIDING_DELAY = 3000; - - private String videoUrl = ""; - - private ActionBar actionBar; - private VideoView videoView; - private int position; - private MediaController mediaController; - private ProgressBar progressBar; - private View decorView; - private boolean uiIsHidden; - private static long lastUiShowTime; - private boolean isLandscape = true; - private boolean hasSoftKeys; - - private SharedPreferences prefs; - private static final String PREF_IS_LANDSCAPE = "is_landscape"; - - @Override - protected void onCreate(Bundle savedInstanceState) { - super.onCreate(savedInstanceState); - - setContentView(R.layout.activity_play_video); - setVolumeControlStream(AudioManager.STREAM_MUSIC); - - //set background arrow style - getSupportActionBar().setHomeAsUpIndicator(R.drawable.ic_arrow_back_white_24dp); - - isLandscape = checkIfLandscape(); - hasSoftKeys = checkIfHasSoftKeys(); - - actionBar = getSupportActionBar(); - assert actionBar != null; - actionBar.setDisplayHomeAsUpEnabled(true); - Intent intent = getIntent(); - if(mediaController == null) { - //prevents back button hiding media controller controls (after showing them) - //instead of exiting video - //see http://stackoverflow.com/questions/6051825 - //also solves https://github.com/theScrabi/NewPipe/issues/99 - mediaController = new MediaController(this) { - @Override - public boolean dispatchKeyEvent(KeyEvent event) { - int keyCode = event.getKeyCode(); - final boolean uniqueDown = event.getRepeatCount() == 0 - && event.getAction() == KeyEvent.ACTION_DOWN; - if (keyCode == KeyEvent.KEYCODE_BACK) { - if (uniqueDown) - { - if (isShowing()) { - finish(); - } else { - hide(); - } - } - return true; - } - return super.dispatchKeyEvent(event); - } - }; - } - - position = intent.getIntExtra(START_POSITION, 0)*1000;//convert from seconds to milliseconds - - videoView = findViewById(R.id.video_view); - progressBar = findViewById(R.id.play_video_progress_bar); - try { - videoView.setMediaController(mediaController); - videoView.setVideoURI(Uri.parse(intent.getStringExtra(STREAM_URL))); - } catch (Exception e) { - e.printStackTrace(); - } - videoView.requestFocus(); - videoView.setOnPreparedListener(new MediaPlayer.OnPreparedListener() { - @Override - public void onPrepared(MediaPlayer mp) { - progressBar.setVisibility(View.GONE); - videoView.seekTo(position); - if (position <= 0) { - videoView.start(); - showUi(); - } else { - videoView.pause(); - } - } - }); - videoUrl = intent.getStringExtra(VIDEO_URL); - - Button button = findViewById(R.id.content_button); - button.setOnClickListener(new View.OnClickListener() { - @Override - public void onClick(View v) { - if(uiIsHidden) { - showUi(); - } else { - hideUi(); - } - } - }); - decorView = getWindow().getDecorView(); - decorView.setOnSystemUiVisibilityChangeListener(new View.OnSystemUiVisibilityChangeListener() { - @Override - public void onSystemUiVisibilityChange(int visibility) { - if (visibility == View.VISIBLE && uiIsHidden) { - showUi(); - } - } - }); - - if (android.os.Build.VERSION.SDK_INT >= 17) { - decorView.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN - | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION - | View.SYSTEM_UI_FLAG_LAYOUT_STABLE); - } - - prefs = getPreferences(Context.MODE_PRIVATE); - if(prefs.getBoolean(PREF_IS_LANDSCAPE, false) && !isLandscape) { - toggleOrientation(); - } - } - - @Override - public boolean onCreatePanelMenu(int featured, Menu menu) { - super.onCreatePanelMenu(featured, menu); - MenuInflater inflater = getMenuInflater(); - inflater.inflate(R.menu.video_player, menu); - - return true; - } - - @Override - public void onPause() { - super.onPause(); - videoView.pause(); - } - - @Override - public void onResume() { - super.onResume(); - } - - @Override - protected void onDestroy() { - super.onDestroy(); - prefs = getPreferences(Context.MODE_PRIVATE); - } - - @Override - public boolean onOptionsItemSelected(MenuItem item) { - int id = item.getItemId(); - switch(id) { - case android.R.id.home: - finish(); - break; - case R.id.menu_item_share: - Intent intent = new Intent(); - intent.setAction(Intent.ACTION_SEND); - intent.putExtra(Intent.EXTRA_TEXT, videoUrl); - intent.setType("text/plain"); - startActivity(Intent.createChooser(intent, getString(R.string.share_dialog_title))); - break; - case R.id.menu_item_screen_rotation: - toggleOrientation(); - break; - default: - Log.e(TAG, "Error: MenuItem not known"); - return false; - } - return true; - } - - @Override - public void onConfigurationChanged(Configuration config) { - super.onConfigurationChanged(config); - - if (config.orientation == Configuration.ORIENTATION_LANDSCAPE) { - isLandscape = true; - adjustMediaControlMetrics(); - } else if (config.orientation == Configuration.ORIENTATION_PORTRAIT){ - isLandscape = false; - adjustMediaControlMetrics(); - } - } - - @Override - public void onSaveInstanceState(Bundle savedInstanceState) { - super.onSaveInstanceState(savedInstanceState); - //savedInstanceState.putInt(POSITION, videoView.getCurrentPosition()); - //videoView.pause(); - } - - @Override - public void onRestoreInstanceState(Bundle savedInstanceState) { - super.onRestoreInstanceState(savedInstanceState); - position = savedInstanceState.getInt(POSITION); - //videoView.seekTo(position); - } - - private void showUi() { - try { - uiIsHidden = false; - mediaController.show(100000); - actionBar.show(); - adjustMediaControlMetrics(); - getWindow().clearFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN); - Handler handler = new Handler(); - handler.postDelayed(new Runnable() { - @Override - public void run() { - if ((System.currentTimeMillis() - lastUiShowTime) >= HIDING_DELAY) { - hideUi(); - } - } - }, HIDING_DELAY); - lastUiShowTime = System.currentTimeMillis(); - }catch(Exception e) { - e.printStackTrace(); - } - } - - private void hideUi() { - uiIsHidden = true; - actionBar.hide(); - mediaController.hide(); - if (android.os.Build.VERSION.SDK_INT >= 17) { - decorView.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN - | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION - | View.SYSTEM_UI_FLAG_FULLSCREEN - | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION - | View.SYSTEM_UI_FLAG_LAYOUT_STABLE); - } - getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, - WindowManager.LayoutParams.FLAG_FULLSCREEN); - } - - private void adjustMediaControlMetrics() { - MediaController.LayoutParams mediaControllerLayout - = new MediaController.LayoutParams(MediaController.LayoutParams.MATCH_PARENT, - MediaController.LayoutParams.WRAP_CONTENT); - - if(!hasSoftKeys) { - mediaControllerLayout.setMargins(20, 0, 20, 20); - } else { - int width = getNavigationBarWidth(); - int height = getNavigationBarHeight(); - mediaControllerLayout.setMargins(width + 20, 0, width + 20, height + 20); - } - mediaController.setLayoutParams(mediaControllerLayout); - } - - private boolean checkIfHasSoftKeys(){ - return Build.VERSION.SDK_INT >= 17 || - getNavigationBarHeight() != 0 || - getNavigationBarWidth() != 0; - } - - private int getNavigationBarHeight() { - if(Build.VERSION.SDK_INT >= 17) { - Display d = getWindowManager().getDefaultDisplay(); - - DisplayMetrics realDisplayMetrics = new DisplayMetrics(); - d.getRealMetrics(realDisplayMetrics); - DisplayMetrics displayMetrics = new DisplayMetrics(); - d.getMetrics(displayMetrics); - - int realHeight = realDisplayMetrics.heightPixels; - int displayHeight = displayMetrics.heightPixels; - return realHeight - displayHeight; - } else { - return 50; - } - } - - private int getNavigationBarWidth() { - if(Build.VERSION.SDK_INT >= 17) { - Display d = getWindowManager().getDefaultDisplay(); - - DisplayMetrics realDisplayMetrics = new DisplayMetrics(); - d.getRealMetrics(realDisplayMetrics); - DisplayMetrics displayMetrics = new DisplayMetrics(); - d.getMetrics(displayMetrics); - - int realWidth = realDisplayMetrics.widthPixels; - int displayWidth = displayMetrics.widthPixels; - return realWidth - displayWidth; - } else { - return 50; - } - } - - private boolean checkIfLandscape() { - DisplayMetrics displayMetrics = new DisplayMetrics(); - getWindowManager().getDefaultDisplay().getMetrics(displayMetrics); - return displayMetrics.heightPixels < displayMetrics.widthPixels; - } - - private void toggleOrientation() { - if(isLandscape) { - isLandscape = false; - setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT); - } else { - isLandscape = true; - setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE); - } - SharedPreferences.Editor editor = prefs.edit(); - editor.putBoolean(PREF_IS_LANDSCAPE, isLandscape); - editor.apply(); - } -} diff --git a/app/src/main/java/org/schabi/newpipe/player/playqueue/PlayQueueItemTouchCallback.java b/app/src/main/java/org/schabi/newpipe/player/playqueue/PlayQueueItemTouchCallback.java index 6edeff670..26be83b98 100644 --- a/app/src/main/java/org/schabi/newpipe/player/playqueue/PlayQueueItemTouchCallback.java +++ b/app/src/main/java/org/schabi/newpipe/player/playqueue/PlayQueueItemTouchCallback.java @@ -8,11 +8,13 @@ public abstract class PlayQueueItemTouchCallback extends ItemTouchHelper.SimpleC private static final int MAXIMUM_INITIAL_DRAG_VELOCITY = 25; public PlayQueueItemTouchCallback() { - super(ItemTouchHelper.UP | ItemTouchHelper.DOWN, 0); + super(ItemTouchHelper.UP | ItemTouchHelper.DOWN, ItemTouchHelper.RIGHT); } public abstract void onMove(final int sourceIndex, final int targetIndex); + public abstract void onSwiped(int index); + @Override public int interpolateOutOfBoundsScroll(RecyclerView recyclerView, int viewSize, int viewSizeOutOfBounds, int totalSize, @@ -44,9 +46,11 @@ public abstract class PlayQueueItemTouchCallback extends ItemTouchHelper.SimpleC @Override public boolean isItemViewSwipeEnabled() { - return false; + return true; } @Override - public void onSwiped(RecyclerView.ViewHolder viewHolder, int swipeDir) {} + public void onSwiped(RecyclerView.ViewHolder viewHolder, int swipeDir) { + onSwiped(viewHolder.getAdapterPosition()); + } } diff --git a/app/src/main/java/org/schabi/newpipe/player/resolver/VideoPlaybackResolver.java b/app/src/main/java/org/schabi/newpipe/player/resolver/VideoPlaybackResolver.java index 8f91f4886..ed0bf5ae5 100644 --- a/app/src/main/java/org/schabi/newpipe/player/resolver/VideoPlaybackResolver.java +++ b/app/src/main/java/org/schabi/newpipe/player/resolver/VideoPlaybackResolver.java @@ -10,9 +10,9 @@ import com.google.android.exoplayer2.source.MediaSource; import com.google.android.exoplayer2.source.MergingMediaSource; import org.schabi.newpipe.extractor.MediaFormat; -import org.schabi.newpipe.extractor.Subtitles; import org.schabi.newpipe.extractor.stream.AudioStream; import org.schabi.newpipe.extractor.stream.StreamInfo; +import org.schabi.newpipe.extractor.stream.SubtitlesStream; import org.schabi.newpipe.extractor.stream.VideoStream; import org.schabi.newpipe.player.helper.PlayerDataSource; import org.schabi.newpipe.player.helper.PlayerHelper; @@ -93,8 +93,8 @@ public class VideoPlaybackResolver implements PlaybackResolver { // Below are auxiliary media sources // Create subtitle sources - for (final Subtitles subtitle : info.getSubtitles()) { - final String mimeType = PlayerHelper.mimeTypesOf(subtitle.getFileType()); + for (final SubtitlesStream subtitle : info.getSubtitles()) { + final String mimeType = PlayerHelper.mimeTypesOf(subtitle.getFormat()); if (mimeType == null) continue; final Format textFormat = Format.createTextSampleFormat(null, mimeType, diff --git a/app/src/main/java/org/schabi/newpipe/settings/ContentSettingsFragment.java b/app/src/main/java/org/schabi/newpipe/settings/ContentSettingsFragment.java index 5c54fa735..82604f7da 100644 --- a/app/src/main/java/org/schabi/newpipe/settings/ContentSettingsFragment.java +++ b/app/src/main/java/org/schabi/newpipe/settings/ContentSettingsFragment.java @@ -17,6 +17,8 @@ import com.nononsenseapps.filepicker.Utils; import com.nostra13.universalimageloader.core.ImageLoader; import org.schabi.newpipe.R; +import org.schabi.newpipe.extractor.NewPipe; +import org.schabi.newpipe.extractor.utils.Localization; import org.schabi.newpipe.report.ErrorActivity; import org.schabi.newpipe.report.UserAction; import org.schabi.newpipe.util.FilePickerActivityHelper; @@ -106,6 +108,20 @@ public class ContentSettingsFragment extends BasePreferenceFragment { startActivityForResult(i, REQUEST_EXPORT_PATH); return true; }); + + Preference setPreferredLanguage = findPreference(getString(R.string.content_language_key)); + setPreferredLanguage.setOnPreferenceChangeListener((Preference p, Object newLanguage) -> { + Localization oldLocal = org.schabi.newpipe.util.Localization.getPreferredExtractorLocal(getActivity()); + NewPipe.setLocalization(new Localization(oldLocal.getCountry(), (String) newLanguage)); + return true; + }); + + Preference setPreferredCountry = findPreference(getString(R.string.content_country_key)); + setPreferredCountry.setOnPreferenceChangeListener((Preference p, Object newCountry) -> { + Localization oldLocal = org.schabi.newpipe.util.Localization.getPreferredExtractorLocal(getActivity()); + NewPipe.setLocalization(new Localization((String) newCountry, oldLocal.getLanguage())); + return true; + }); } @Override diff --git a/app/src/main/java/org/schabi/newpipe/util/ExtractorHelper.java b/app/src/main/java/org/schabi/newpipe/util/ExtractorHelper.java index 5a9911a67..3f6d82b9f 100644 --- a/app/src/main/java/org/schabi/newpipe/util/ExtractorHelper.java +++ b/app/src/main/java/org/schabi/newpipe/util/ExtractorHelper.java @@ -69,42 +69,37 @@ public final class ExtractorHelper { public static Single searchFor(final int serviceId, final String searchString, final List contentFilter, - final String sortFilter, - final String contentCountry) { + final String sortFilter) { checkServiceId(serviceId); return Single.fromCallable(() -> SearchInfo.getInfo(NewPipe.getService(serviceId), NewPipe.getService(serviceId) .getSearchQHFactory() - .fromQuery(searchString, contentFilter, sortFilter), - contentCountry)); + .fromQuery(searchString, contentFilter, sortFilter))); } public static Single getMoreSearchItems(final int serviceId, final String searchString, final List contentFilter, final String sortFilter, - final String pageUrl, - final String contentCountry) { + final String pageUrl) { checkServiceId(serviceId); return Single.fromCallable(() -> SearchInfo.getMoreItems(NewPipe.getService(serviceId), NewPipe.getService(serviceId) .getSearchQHFactory() .fromQuery(searchString, contentFilter, sortFilter), - contentCountry, pageUrl)); } public static Single> suggestionsFor(final int serviceId, - final String query, - final String contentCountry) { + final String query) { checkServiceId(serviceId); return Single.fromCallable(() -> NewPipe.getService(serviceId) .getSuggestionExtractor() - .suggestionList(query, contentCountry)); + .suggestionList(query)); } public static Single getStreamInfo(final int serviceId, @@ -165,19 +160,17 @@ public final class ExtractorHelper { public static Single getKioskInfo(final int serviceId, final String url, - final String contentCountry, boolean forceLoad) { return checkCache(forceLoad, serviceId, url, InfoItem.InfoType.PLAYLIST, Single.fromCallable(() -> - KioskInfo.getInfo(NewPipe.getService(serviceId), url, contentCountry))); + KioskInfo.getInfo(NewPipe.getService(serviceId), url))); } public static Single getMoreKioskItems(final int serviceId, - final String url, - final String nextStreamsUrl, - final String contentCountry) { + final String url, + final String nextStreamsUrl) { return Single.fromCallable(() -> KioskInfo.getMoreItems(NewPipe.getService(serviceId), - url, nextStreamsUrl, contentCountry)); + url, nextStreamsUrl)); } /*////////////////////////////////////////////////////////////////////////// diff --git a/app/src/main/java/org/schabi/newpipe/util/ListHelper.java b/app/src/main/java/org/schabi/newpipe/util/ListHelper.java index 871d0578f..8fc423837 100644 --- a/app/src/main/java/org/schabi/newpipe/util/ListHelper.java +++ b/app/src/main/java/org/schabi/newpipe/util/ListHelper.java @@ -110,7 +110,8 @@ public final class ListHelper { : context.getString(R.string.best_resolution_key); String maxResolution = getResolutionLimit(context); - if (maxResolution != null && compareVideoStreamResolution(maxResolution, resolution) < 1){ + if (maxResolution != null && (resolution.equals(context.getString(R.string.best_resolution_key)) + || compareVideoStreamResolution(maxResolution, resolution) < 1)) { resolution = maxResolution; } return resolution; diff --git a/app/src/main/java/org/schabi/newpipe/util/Localization.java b/app/src/main/java/org/schabi/newpipe/util/Localization.java index c1e5c9ed4..eed1a8ae2 100644 --- a/app/src/main/java/org/schabi/newpipe/util/Localization.java +++ b/app/src/main/java/org/schabi/newpipe/util/Localization.java @@ -69,10 +69,23 @@ public class Localization { return stringBuilder.toString(); } + public static org.schabi.newpipe.extractor.utils.Localization getPreferredExtractorLocal(Context context) { + SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(context); + + String languageCode = sp.getString(context.getString(R.string.content_language_key), + context.getString(R.string.default_language_value)); + + String countryCode = sp.getString(context.getString(R.string.content_country_key), + context.getString(R.string.default_country_value)); + + return new org.schabi.newpipe.extractor.utils.Localization(countryCode, languageCode); + } + public static Locale getPreferredLocale(Context context) { SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(context); - String languageCode = sp.getString(context.getString(R.string.search_language_key), context.getString(R.string.default_language_value)); + String languageCode = sp.getString(context.getString(R.string.content_language_key), + context.getString(R.string.default_language_value)); try { if (languageCode.length() == 2) { diff --git a/app/src/main/java/org/schabi/newpipe/util/NavigationHelper.java b/app/src/main/java/org/schabi/newpipe/util/NavigationHelper.java index 562dd7e49..4b93600ce 100644 --- a/app/src/main/java/org/schabi/newpipe/util/NavigationHelper.java +++ b/app/src/main/java/org/schabi/newpipe/util/NavigationHelper.java @@ -50,7 +50,6 @@ import org.schabi.newpipe.player.MainVideoPlayer; import org.schabi.newpipe.player.PopupVideoPlayer; import org.schabi.newpipe.player.PopupVideoPlayerActivity; import org.schabi.newpipe.player.VideoPlayer; -import org.schabi.newpipe.player.old.PlayVideoActivity; import org.schabi.newpipe.player.playqueue.PlayQueue; import org.schabi.newpipe.settings.SettingsActivity; @@ -118,26 +117,6 @@ public class NavigationHelper { context.startActivity(playerIntent); } - public static void playOnOldVideoPlayer(Context context, StreamInfo info) { - ArrayList videoStreamsList = new ArrayList<>(ListHelper.getSortedStreamVideosList(context, info.getVideoStreams(), null, false)); - int index = ListHelper.getDefaultResolutionIndex(context, videoStreamsList); - - if (index == -1) { - Toast.makeText(context, R.string.video_streams_empty, Toast.LENGTH_SHORT).show(); - return; - } - - VideoStream videoStream = videoStreamsList.get(index); - Intent intent = new Intent(context, PlayVideoActivity.class) - .addFlags(Intent.FLAG_ACTIVITY_NEW_TASK) - .putExtra(PlayVideoActivity.VIDEO_TITLE, info.getName()) - .putExtra(PlayVideoActivity.STREAM_URL, videoStream.getUrl()) - .putExtra(PlayVideoActivity.VIDEO_URL, info.getUrl()) - .putExtra(PlayVideoActivity.START_POSITION, info.getStartPosition()); - - context.startActivity(intent); - } - public static void playOnPopupPlayer(final Context context, final PlayQueue queue) { if (!PermissionHelper.isPopupEnabled(context)) { PermissionHelper.showPopupEnablementToast(context); diff --git a/app/src/main/java/us/shandian/giga/ui/adapter/MissionAdapter.java b/app/src/main/java/us/shandian/giga/ui/adapter/MissionAdapter.java index d5555c2be..bca8796b5 100644 --- a/app/src/main/java/us/shandian/giga/ui/adapter/MissionAdapter.java +++ b/app/src/main/java/us/shandian/giga/ui/adapter/MissionAdapter.java @@ -96,12 +96,12 @@ public class MissionAdapter extends RecyclerView.Adapter + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/res/layout-large-land/fragment_video_detail.xml b/app/src/main/res/layout-large-land/fragment_video_detail.xml new file mode 100644 index 000000000..73939d60a --- /dev/null +++ b/app/src/main/res/layout-large-land/fragment_video_detail.xml @@ -0,0 +1,491 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/res/layout/fragment_subscription.xml b/app/src/main/res/layout/fragment_subscription.xml index a40059455..f2137074e 100644 --- a/app/src/main/res/layout/fragment_subscription.xml +++ b/app/src/main/res/layout/fragment_subscription.xml @@ -11,7 +11,6 @@ android:layout_width="match_parent" android:layout_height="wrap_content" android:scrollbars="vertical" - app:layoutManager="LinearLayoutManager" android:visibility="gone" tools:listitem="@layout/list_channel_item" tools:visibility="visible"/> diff --git a/app/src/main/res/layout/list_channel_grid_item.xml b/app/src/main/res/layout/list_channel_grid_item.xml new file mode 100644 index 000000000..3fe642974 --- /dev/null +++ b/app/src/main/res/layout/list_channel_grid_item.xml @@ -0,0 +1,48 @@ + + + + + + + + + + diff --git a/app/src/main/res/layout/list_playlist_grid_item.xml b/app/src/main/res/layout/list_playlist_grid_item.xml new file mode 100644 index 000000000..949b1159b --- /dev/null +++ b/app/src/main/res/layout/list_playlist_grid_item.xml @@ -0,0 +1,72 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/list_stream_grid_item.xml b/app/src/main/res/layout/list_stream_grid_item.xml new file mode 100644 index 000000000..cf73bf9b1 --- /dev/null +++ b/app/src/main/res/layout/list_stream_grid_item.xml @@ -0,0 +1,69 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/list_stream_playlist_grid_item.xml b/app/src/main/res/layout/list_stream_playlist_grid_item.xml new file mode 100644 index 000000000..4b31a452e --- /dev/null +++ b/app/src/main/res/layout/list_stream_playlist_grid_item.xml @@ -0,0 +1,84 @@ + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/mission_item_linear.xml b/app/src/main/res/layout/mission_item_linear.xml index 21f637839..0133d0c3f 100644 --- a/app/src/main/res/layout/mission_item_linear.xml +++ b/app/src/main/res/layout/mission_item_linear.xml @@ -9,7 +9,7 @@ android:layout_width="match_parent" android:layout_margin="2dp" android:background="@color/bluegray"> - + - - + android:ellipsize="end" + android:padding="6dp" + android:text="XXX.xx" + android:textColor="@color/white" + android:textSize="16sp" + android:textStyle="bold" /> - - - - - - + + android:textColor="@color/white" + android:textSize="12sp" /> + \ No newline at end of file diff --git a/app/src/main/res/menu/mission.xml b/app/src/main/res/menu/mission.xml index b76d1a923..c1688ac5b 100644 --- a/app/src/main/res/menu/mission.xml +++ b/app/src/main/res/menu/mission.xml @@ -7,11 +7,7 @@ - - - + diff --git a/app/src/main/res/values-ar/strings.xml b/app/src/main/res/values-ar/strings.xml index fdb859609..d9bd02a43 100644 --- a/app/src/main/res/values-ar/strings.xml +++ b/app/src/main/res/values-ar/strings.xml @@ -28,13 +28,13 @@ خطأ في الشبكة الفيديو التالي لا يوجد مشغل فيديو. هل تريد تثبيت VLC ؟ - فتح في المتصفح + افتح في المتصفح الصوت تشغيل - تشغيل بواسطة Kodi + تشغيل بواسطة كودي التدوير بحث - اللغة الإفتراضية للمحتوى + اللغة الإفتراضية للمحتوى الإعدادات المظهر اخرى @@ -42,8 +42,8 @@ مشاركة مشاركة بواسطة عرض الفديوهات \'التالية\'و\'المماثلة\' - عرض خيار لتشغيل الفيديو بواسطة Kodi Media Center - عرض خيار التشغيل بواسطة Kodi + عرض خيار لتشغيل الفيديو بواسطة مشغل كودي + عرض خيار التشغيل بواسطة كودي السمة تم النشر يوم %1$s الرابط غير مدعوم @@ -66,30 +66,30 @@ ما الجديد - الخلفية + في الخلفية تشغيل تلقائي اسود التاريخ وذاكرة التخزين المؤقت - التاريخ و ذاكرة التخزين المؤقتة + التاريخ و التخزين المؤقت المحتوى التنزيلات التنزيلات الكل القناة - فيديو + الفيديو التنزيل عن التطبيق عن التطبيق التاريخ التاريخ - فتح في وضع النافذة المنبثقة + افتح في وضع النافذة المنبثقة "بعض الخيارات الدقة لن تحتوي على صوت عند تمكين هذا الخيار " وضع النوافذ المنبثقة NewPipe تم إلغاء الاشتراك في القناة تعذر تغيير حالة الاشتراك تعذر تحديث الاشتراك - نافذة + نافذة المنبثقة تشغيل مقطع الفيديو عند إستدعاء NewPipe من تطبيق آخر الدقة الافتراضية لنوافذ المنبثقة @@ -107,11 +107,11 @@ تتبع مقاطع الفيديو التي تمت مشاهدتها استئناف عند اكتساب التركيز متابعة التشغيل بعد المقاطعات (مثل المكالمات الهاتفية) - عرض\"عقد لإلحاق\"عنوان - عرض تلميح أو زر منبثق عند الضغط على خلفية على صفحة تفاصيل الفيديو + عرض تلميح \"اضغط للتجاهل\" + عرض تلميح على صفحة التفاصيل عند استخدام وضع مشغل الخلفية أو النافذة المنبثقة المشغل السلوك - المنبثق + الوضع المنبثق يتم التشغيل في الوضع المنبثق تم وضعه على قائمة الانتظار في مشغل الخلفية تم وضعه على قائمة الانتظار في مشغل النافذة المنبثقة @@ -165,8 +165,6 @@ الصوت إعادة المحاولة تم رفض إذن الوصول إلى التخزين - استخدام المشغل القديم - المشغل القديم المدمج في إطار Mediaframework ألف مليون @@ -177,9 +175,9 @@ صفر مشترِك %s مشترِك مشترِكان - %s مشترك + %s مشتركين %s مشترك - %s مشتركون + %s مشترك دون مشاهدات @@ -194,7 +192,7 @@ حسناً اسم الملف - الخيوط + التقسيم الخطأ الخادم غير معتمد الملف موجود مسبقا @@ -208,8 +206,8 @@ \nللفتح في وضع النافذة المنبثقة اختبار reCAPTCHA - الأحرف المسموح بها في أسماء الملفات - يتم استبدال الأحرف غير الصالحة بهذه القيمة + السماح بالرموز في أسماء الملفات + يتم استبدال الرموز غير المسموح بها بهذه القيمة استبدال الحرف الحروف والأرقام @@ -222,7 +220,7 @@ فتح الموقع المساهمون التراخيص - تطبيق حُر و خفيف لالتقاط البث على نظام الأندرويد. + تطبيق حُر و خفيف لتشغيل اليوتيوب على نظام الأندرويد. ساهم إذا كانت لديك أفكار؛ أو ترجمة، أو تغييرات تخص التصميم، أو تنظيف و تحسين الشفرة البرمجية ، أو تعديلات عميقة عليها، فتذكر أنّ مساعدتك دائما موضع ترحيب. وكلما أتممنا شيئا كلما كان ذلك أفضل ! عرض على GitHub @@ -258,17 +256,17 @@ حذف التفاصيل الإعدادات الصوتية - ابدء التشغيل هنا + تشغيل هنا تشغيل هنا في وضع النافذة المنبثقة تحدي ريكابتشا اضغط للإدراج في قائمة الانتظار - لاتوجد مشاهدة + بدون مشاهدات %s مشاهدة مشاهدتين - %s مشاهدات كثيرة - %s عدد المشاهدات - %s أقصى مشاهدات + %s مشاهدات + %s مشاهدات + %s مشاهدة @@ -289,7 +287,7 @@ الكشك إدراج في قائمة الانتظار في الخلفية إدراج في قائمة الانتظار على المنبثقة - ابدأ هنا في الخلفية + تشغيل في الخلفية المحتوى الإفتراضي حسب البلد تغيير الإتجاه الإنتقال إلى التشغيل في الخلفية @@ -375,7 +373,7 @@ تناسب مع الشاشة توليد تلقائي - إستيراد وتصدير + إستيراد او تصدير إستيراد إستعادة مِن تصدير إلى @@ -419,7 +417,7 @@ المشغل الخارجي لا يدعم هذه الأنواع من الروابط ملف غير صالح / محتوى غير صالح الملف غير موجود أو ليس لديك الإذن الكافي للقراءة أو الكتابة فيه - لا توجد تدفقات متاحة للتنزيل + لا يوجد بث متاح للتنزيل تم حذف عنصر واحد. @@ -438,7 +436,7 @@ مشغل الخلفية المشغل المنبثق - التصدير السابق + نسخة احتياطية تعذر استيراد الاشتراكات لا يمكن تصدير الاشتراكات diff --git a/app/src/main/res/values-b+ast/strings.xml b/app/src/main/res/values-b+ast/strings.xml index a8ee6260c..f9834119d 100644 --- a/app/src/main/res/values-b+ast/strings.xml +++ b/app/src/main/res/values-b+ast/strings.xml @@ -41,7 +41,7 @@ Videu siguiente Amosar vídeos siguientes y asemeyaos URL non sofitada - Llingua por defeutu del conteníu + Llingua por defeutu del conteníu Videu y audiu Aspeutu Otru diff --git a/app/src/main/res/values-be/strings.xml b/app/src/main/res/values-be/strings.xml index 8a1d35df3..d5c27ce48 100644 --- a/app/src/main/res/values-be/strings.xml +++ b/app/src/main/res/values-be/strings.xml @@ -95,7 +95,7 @@ URL не падтрымліваецца Краіна кантэнту па змаўчанні Сэрвіс - Мова кантэнту па змаўчанні + Мова кантэнту па змаўчанні Плэер Павядзенне Відэа і аўдыё diff --git a/app/src/main/res/values-bg/strings.xml b/app/src/main/res/values-bg/strings.xml index 5adc10a1d..11571f4e5 100644 --- a/app/src/main/res/values-bg/strings.xml +++ b/app/src/main/res/values-bg/strings.xml @@ -74,7 +74,7 @@ Показвай „следващ“ и „подобни“ Показвай съвет „задръж за добавяне“ Непознат URL - Език на съдържанието по подразбиране + Език на съдържанието по подразбиране Плейър Поведение Видео & Аудио @@ -288,7 +288,7 @@ Изтрива историята на възпроизвежданите стриймове Не са намерени видео стриймове Не са намерени аудио стриймове - "Какво:\\nЗаявка:\\nЕзик на съдържанието:\\nУслуга:\\nВреме по GMT:\\nПакет:\\nВерсия:\\nОС версия: " + Какво:\\nЗаявка:\\nЕзик на съдържанието:\\nУслуга:\\nВреме по GMT:\\nПакет:\\nВерсия:\\nОС версия: Миниатюра на видео Потребителски доклад Пренареди чрез плъзгане @@ -461,4 +461,5 @@ Потребители Възстанови + Стъпка diff --git a/app/src/main/res/values-bn-rBD/strings.xml b/app/src/main/res/values-bn-rBD/strings.xml index f9ec7a07a..3fb51af36 100644 --- a/app/src/main/res/values-bn-rBD/strings.xml +++ b/app/src/main/res/values-bn-rBD/strings.xml @@ -57,7 +57,7 @@ পরবর্তী ভিডিও পরবর্তী এবং অনুরূপ ভিডিওগুলি দেখাও URL সমর্থিত নয় - কন্টেন্ট এর জন্য পছন্দসই ভাষা + কন্টেন্ট এর জন্য পছন্দসই ভাষা ভিডিও এবং অডিও পপআপ অ্যাপিয়ারেন্স diff --git a/app/src/main/res/values-ca/strings.xml b/app/src/main/res/values-ca/strings.xml index df5ea0d87..20916ef45 100644 --- a/app/src/main/res/values-ca/strings.xml +++ b/app/src/main/res/values-ca/strings.xml @@ -177,7 +177,7 @@ Vídeo següent Mostra el vídeo següent i similars País per defecte dels continguts - Llengua per defecte dels continguts + Llengua per defecte dels continguts Emergent S\'està reproduint en segon pla S\'està reproduint en mode emergent diff --git a/app/src/main/res/values-cmn/strings.xml b/app/src/main/res/values-cmn/strings.xml index ca495f134..ccdf23c98 100644 --- a/app/src/main/res/values-cmn/strings.xml +++ b/app/src/main/res/values-cmn/strings.xml @@ -1,22 +1,22 @@ -点按搜索即可开始 - %1$s 意见 - 发布 %1$s - 找不到流播放器。你想安装VLC吗? - 找不到流播放器(您可以安装VLC播放它) +点击搜索按钮即可开始使用 + %1$s 次观看 + 发布于 %1$s + 找不到流媒体播放器。您想安装 VLC 吗? + 找不到流媒体播放器(您可以安装 VLC 来播放) 安装 取消 在浏览器中打开 - 在弹出模式下打开 + 在悬浮窗模式下打开 分享 下载 - 下载流文件. + 下载流媒体文件。 搜索 设置 - 你的意思是: %1$s ? - 与某人分享 + 您是不是要找: %1$s ? + 分享至 选择浏览器 - 回转 + 旋转 使用外部视频播放器 启用此选项时,某些分辨率将不会有音频 使用外部音频播放器 @@ -65,7 +65,7 @@ 黑色 记住弹出窗口的尺寸与位置 记住上一次弹出窗口的位置以及大小 - 清理照片内存 + 已清除图像缓存 最小化弹出播放器 @@ -120,4 +120,11 @@ 从主视频播放器切换到其他应用程序时的操作 - %s 没有 最小化背景播放器 + WebM — 自由视频格式 + 使用快速粗略定位 + 粗略定位功能允许播放器以略低的精确度为代价换取更快的定位速度 + 下载缩略图 + 清除缓存的元数据 + 移除所有缓存的网页数据 + 已清除缓存的元数据 diff --git a/app/src/main/res/values-cs/strings.xml b/app/src/main/res/values-cs/strings.xml index 5684c4756..d736a9e34 100644 --- a/app/src/main/res/values-cs/strings.xml +++ b/app/src/main/res/values-cs/strings.xml @@ -40,7 +40,7 @@ Další videa Zobrazovat \'další\' a \'podobná\' videa URL není podporováno - Preferovaný jazyk obsahu + Preferovaný jazyk obsahu Video a zvuk Vzhled Ostatní @@ -372,7 +372,7 @@ otevření ve vyskakovacím okně Náhled playlistu změněn Playlist nelze smazat - Žádné poznámky + Žádné titulky Přizpůsobit Vyplnit @@ -457,8 +457,8 @@ otevření ve vyskakovacím okně Preferovaná \'otevřít\' akce Výchozí chování při otevírání obsahu — %s - Poznámky - Upravuje velikost textu poznámek a styly pozadí. Změny se projeví po restartu aplikace + Titulky + Upravuje velikost textu titulků a styly pozadí. Změny se projeví po restartu aplikace K přehrání tohoto souboru chybí vhodná aplikace @@ -473,4 +473,31 @@ otevření ve vyskakovacím okně Jedna položka smazána. NewPipe je copyleft libre software: Můžete jej používat, sdílet a vylepšovat dle vaší vůle. Redistribuovat a/nebo upravovat lze za podmínek GNU General Public Licence zveřejňované nadací Free Software Foundation, a to buď za podmínek licence verze 3 nebo (dle vaší volby) jakékoli pozdější verze. - + kanály + Playlisty + Stopy + Uživatelé + Zásady ochrany soukromí v NewPipe + Projekt NewPipe bere vaše soukromí velice vážně. Proto aplikace neshromažďuje žádné údaje bez vašeho souhlasu. +\nZásady ochrany soukromí NewPipe podrobně vysvětlují, jaké údaje jsou odesílány a ukládány, když odešlete zprávu o pádu aplikace. + Přečíst zásady ochrany soukromí + Chcete také přenést nastavení? + + Zrychleně vpřed během ticha + Krok + Reset + + Abychom vyhověli Obecnému nařízení o ochraně osobních údajů (GDPR), upozorňujeme vás na zásady ochrany soukromí v NewPipe. Přečtěte si je prosím pozorně. +\nJe potřeba je odsouhlasit, abyste nám mohli odeslat hlášení chyb. + Přijmout + Odmítnout + + Bez omezení + Omezit rozlišení při použití mobilních dat + Minimalizovat při přepínání aplikací + Akce při přepínání aplikací z hlavního přehrávače videa - %s + Žádná + Minimalizovat přehrávač na pozadí + Minimalizovat přehrávač do vyskakovacího okna + + diff --git a/app/src/main/res/values-de/strings.xml b/app/src/main/res/values-de/strings.xml index 37f892b4b..f5bbfb3e0 100644 --- a/app/src/main/res/values-de/strings.xml +++ b/app/src/main/res/values-de/strings.xml @@ -10,7 +10,7 @@ Download Suchen Einstellungen - Meintest du: %1$s ? + Meintest du: %1$s\? Teilen mit Browser auswählen Drehen des Geräts @@ -29,7 +29,7 @@ \'Nächste\' und \'ähnliche\' Videos anzeigen URL wird nicht unterstützt Video & Audio - Bevorzugte Sprache des Inhalts + Bevorzugte Sprache des Inhalts Video-Vorschaubild Video-Vorschaubild Nutzerbild diff --git a/app/src/main/res/values-el/strings.xml b/app/src/main/res/values-el/strings.xml index 975ad4025..74dfbe229 100644 --- a/app/src/main/res/values-el/strings.xml +++ b/app/src/main/res/values-el/strings.xml @@ -42,7 +42,7 @@ Επόμενο βίντεο Εμφάνιση \"επόμενου\" και \"σχετικών\" βίντεο Δεν υποστηρίζεται η διεύθυνση URL - Προεπιλεγμένη γλώσσα περιεχομένου + Προεπιλεγμένη γλώσσα περιεχομένου Βίντεο & Ήχος Εμφάνιση Άλλα @@ -217,7 +217,7 @@ Μη έγκυρο URL Δε βρέθηκαν ροές βίντεο Δε βρέθηκαν ροές ήχου - Μη έγκυρη τοποθεσία + Μη έγκυρη διεύθυνση Μη έγκυρο αρχείο ή πηγή περιεχομένου Το αρχείο δεν υπάρχει ή δεν έχουμε επαρκή εξουσιοδότηση για να διαβάσουμε ή να γράψουμε σε αυτό Το όνομα αρχείου δεν μπορεί να είναι κενό @@ -301,7 +301,7 @@ Δεν ήταν δυνατή η φόρτωση της άδειας Περί Συνεισφέροντες - Ελέυθερη και ελαφριά εφαρμογή αναπαραγωγής ροών στο Android. + Ανοιχτού κώδικα, ελαφριά εφαρμογή του Android, για την αναπαραγωγή πολυμεσων από το ίντερνετ. Συνεισφέρετε Αν έχετε ιδέες για μετάφραση, αλλαγή σχεδιασμού, εκκαθάριση ή ριζικές αλλαγές κώδικα της εφαρμογής—η βοήθεια σας είναι πάντα ευπρόσδεκτη. Όσο περισσότερη έχουμε, τόσο καλύτεροι γινόμαστε! Δείτε το στο GitHub @@ -405,7 +405,7 @@ Τροποποίηση του μεγέθους και του φόντου των υπότιτλων. Απαιτεί επανεκκίνηση της εφαρμογής Ενεργοποίηση του LeakCanary - Η παρακολούθηση των διαρροών μνήμης μπορεί να κάνει την εφαρμογή να μην αποκρίνεται κατά το heap dumping + Η παρακολούθηση των διαρροών μνήμης μπορεί να προκαλέσει την διακοπή της εφαρμογής @@ -442,7 +442,7 @@ Τέμπο Τόνος Ενέργεια κατά τη μετάβαση σε άλλη εφαρμογή — %s - Σελίδαρ Ροής + Σελίδα Ροής Δημοφιλή Αναφορά σφαλμάτων εκτός κύκλου ζωής Το όνομα χρήστη σας, soundcloud.com/όνομαχρήστη @@ -450,7 +450,7 @@ Αποσύνδεση (μπορεί να προκαλέσει παραμόρφωση) Επιτάχυνση αναπαραγωγής κατά τη διάρκεια σιωπής Βήμα - Μηδενισμός + Επαναφορά Προς συμμόρφωση με τον Ευρωπαϊκό Γενικό Κανονισμό για την Προστασία Δεδομένων (GDPR), σας επιστούμε την προσοχή στην πολιτική προστασίας προσωπικών δεδομένων του NewPipe. Παραλούμε, διαβάστε την προσεκτικά. \nΘα πρέπει να την αποδεχτέιτε προκειμένου να μας αποστείλετε την αναφορά σφάλματος. diff --git a/app/src/main/res/values-eo/strings.xml b/app/src/main/res/values-eo/strings.xml index 78faeed8f..9ac81757f 100644 --- a/app/src/main/res/values-eo/strings.xml +++ b/app/src/main/res/values-eo/strings.xml @@ -28,7 +28,7 @@ Elŝuti Sekva video Ligilo ne subtenita - Preferata enhavlingvo + Preferata enhavlingvo Video kaj sono Apero Alia diff --git a/app/src/main/res/values-es/strings.xml b/app/src/main/res/values-es/strings.xml index 02a9924a5..9c06e228b 100644 --- a/app/src/main/res/values-es/strings.xml +++ b/app/src/main/res/values-es/strings.xml @@ -57,7 +57,7 @@ No se pudo descifrar la URL del vídeo No se pudo analizar el sitio web Mostrar vídeos \'siguientes\' y \'similares\' - Idioma del contenido por defecto + Idioma del contenido por defecto Vista previa del vídeo Vista previa del vídeo Me gusta diff --git a/app/src/main/res/values-et/strings.xml b/app/src/main/res/values-et/strings.xml index aa3afa7be..aef139cfa 100644 --- a/app/src/main/res/values-et/strings.xml +++ b/app/src/main/res/values-et/strings.xml @@ -92,7 +92,7 @@ URL pole toetatud Sisu vaikimisi riik Teenus - Sisu vaikimisi keel + Sisu vaikimisi keel Pleier Käitumine Heli ja pilt diff --git a/app/src/main/res/values-eu/strings.xml b/app/src/main/res/values-eu/strings.xml index 9ea87bd6d..72206774a 100644 --- a/app/src/main/res/values-eu/strings.xml +++ b/app/src/main/res/values-eu/strings.xml @@ -26,7 +26,7 @@ Hurrengo bideoa Erakutsi \'hurrengo\' eta \'antzeko\' bideoak URLak ez du euskarririk - Edukiaren hizkuntz lehenetsia + Edukiaren hizkuntz lehenetsia Bideoa eta Audioa Erreproduzitu diff --git a/app/src/main/res/values-fa/strings.xml b/app/src/main/res/values-fa/strings.xml index 71acd9c69..03f9a33a0 100644 --- a/app/src/main/res/values-fa/strings.xml +++ b/app/src/main/res/values-fa/strings.xml @@ -43,7 +43,7 @@ ویدیوی بعدی نماش ویدیوهای بعدی و مشابه نشانی اینترنتی پشتیبانی نمی‌شود - زبان محتوای ترجیحی + زبان محتوای ترجیحی ویدیو و صدا ظاهر دیگر @@ -117,4 +117,21 @@ در حافظه رونوشت شد. لطفاً یک شاخهٔ بارگیری موجود را برگزینید. - +هیچ پخش کننده استریمی پیدا نشد (شما می‌توانید برنامه وی‌ال‌سی را برای پخش آن نصب نمایید) + بارگیری پرونده جریان. + هنگامی که این گزینه فعال باشد، برخی از کیفیت‌ها فاقد صدا خواهند بود + اشتراک + مشترک شده + اشتراک کانال لغو شد + ناتوانی در تغییر وضعیت اشتراک + ناتوانی در به‌روزرسانی اشتراک + نمایش اطلاعات + + اصلی + اشتراک‌ها + نشان‌گذاری‌ها + + موارد جدید + + پس زمینه + diff --git a/app/src/main/res/values-fi/strings.xml b/app/src/main/res/values-fi/strings.xml index fc9c343b1..ec10422d8 100644 --- a/app/src/main/res/values-fi/strings.xml +++ b/app/src/main/res/values-fi/strings.xml @@ -42,7 +42,7 @@ Aseta sijainti minne äänitiedostot tallennetaan Automaattitoisto - Toistaa automaattisesti videon, kun NewPipe sovellusta kutsutaan toisesta sovelluksesta + Toistaa automaattisesti videon, kun NewPipe avataan toisesta ohjelmasta Oletusresoluutio Ponnahdusikkunan oletusresoluutio Näytä korkeampia resoluutioita @@ -66,18 +66,18 @@ Näytä ehdotuksia hakiessa Hakuhistoria Tallentaa hakutietokannan paikallisesti - Historia + Historia ja Välimuisti Pidä muistissa katsotut videot Jatka toistoa keskeytysten jälkeen (esim. puhelut) Lataus Seuraava video Näytä seuraavia ja samankaltaisia videoita URL ei tueta - Oletus-sisällon kieli + Oletus-sisällon kieli Soitin Käyttäytyminen Video & Ääni - Historia + Historia ja välimuisti Ponnahdusikkuna Ulkoasu Muu @@ -170,7 +170,7 @@ Ei videoita %s video - %s videota + %s videoita Aloita @@ -216,7 +216,7 @@ Tietoja Hyväntekijät Lisenssit - Vapaa kevyt Android YouTube-frontend. + Vapaa ja kevyt nettivideo- ja audiostriimitoistin Androidille. Näytä GitHub:ssa NewPipe:n Lisenssi Olkoon sinulla ideoita; käännöksistä, design muutoksista, koodin siivoamisesta tai raskaista koodimuutoksista—apu on aina tervetullutta. Mitä enemmän saadaan tehtyä, sen paremmaksi sovellus tulee! @@ -232,7 +232,7 @@ Historia pyyhitty Poistettu Haluatko poistaa tämän hakuhistoriasta? -Jatka toistoa +Jatka keskeytyksen jälkeen Info: Mikä:\\nPyyntö:\\nSisällön kieli:\\nPalvelu:\\nGMT Aika:\\nPaketti:\\nVersio:\\nOS versio: © %1$s %2$s %3$s alla @@ -255,7 +255,7 @@ Lisätty ikkunajonoon Toista kaikki - Toisto epäonnistui + Tätä ei voitu toistaa Palautuskelvoton soittimen virhe Palaudutaan soittimen virheestä @@ -265,7 +265,7 @@ Yksityiskohdat Ääniasetukset Pidä pohjassa lisätäksesi jonoon -Näytä vihje soittolistalle +"Näytä vihje soittolistaan lisäämiseen " [Tuntematon] Lisää taustatoistojonoon @@ -274,8 +274,192 @@ Aloita toisto taustalla Aloita toisto ikkunassa Lahjoita - NewPipe kehitetään vapaaehtoisten toimesta, jotka käyttävät vapaa-aikaansa tuottaakseen parhaimman kokemuksen sinulle. Nyt on aika antaa takaisin, jotta kehittäjät voivat tehdä NewPipe:sta vielä paremman nauttiessaan kupin kahvia! + NewPipe kehitetään vapaaehtoisten toimesta, jotka käyttävät vapaa-aikaansa tuottaakseen parhaan mahdollisen käyttökokemuksen sinulle. Nyt on aika antaa takaisin, jotta kehittäjät voivat tehdä NewPipe:sta vielä paremman nauttiessaan kupin kahvia! Anna takaisin Websivu - Käy verkkosivuillamme saadaksesi lisää tietoa ja uusimmat uutiset NewPipe:sta. - + Käy verkkosivuillamme saadaksesi lisää tietoa ja uusimmat uutiset NewPipe:stä. + Soitinta ei löytynyt (voit asentaa VLC:n toistaaksesi) + Lataa toistotiedosto. + Näytä lisätietoja + + Kirjanmerkit + + Lisää soittolistaan + + Käytä nopeampaa epätarkkaa pikakelausta + Epätarkka kelaus mahdollistaa videon kelauksen nopeammin, huonommalla tarkkuudella + Näytä videoiden pikkukuvat + Poista käytöstä lopettaaksesi kaikkien pikkukuvien lataus säästääksesi mobiilidataa ja muistinkäyttöä. Tämän asetuksen muuttaminen poistaa kaikki pikkukuvat välimuistista + Kuvavälimuisti tyhjennetty + Poista tallennettu metatieto + Poista kaikki tallennettu sivutieto + Metatiedot poistettu + Automaattisesti lisää seuraavan youtuben ehdottaman videon soittolistaan, sen viimeisen kappaleen soidessa (Youtuben Autoplay) + Sisällön oletusmaa + Palvelu + "Virheenkorjaus " + Kanavat + Soittolistat + Ääniraidat + Käyttäjät + Aina + Vain kerran + Tiedosto + + Muuta näytön suuntausta + Vaihda taustalle + Vaihda ponnahdusikkunatoistoon + Vaihda normaalitoistoon + + Tuo tietokanta + Vie tietokanta + Kirjoittaa yli tämänhetkisen historian ja tilaukset + Vie historia, tilaukset tai soittolistat + Poista katseluhistoria + Poistaa toistohistorian + Poista koko katseluhistoria. + Katseluhistoria onnistuneesti poistettu. + Poista hakuhistoria + Poistaa historian haetuista videoista + Poista koko hakuhistoria. + Hakuhistoria onnistuneesti poistettu. + Ulkoiset soittimet eivät tue tämänkaltaisia linkkejä + Viallinen osoite + Videojonoja ei löytynyt + Audiojonoja ei löytynyt + Virheellinen kansio + Virheellinen tiedosto/lähde + Tiedosta ei löydy tai sen kirjoittamiseen/lukemiseen ei ole lupaa + Tiedostonimi ei voi olla tyhjä + Hups! Tapahtui virhe: %1$s + Vedä järjestelläksesi + + Luo + Poista yksi + Poista kaikki + Hylkää + Nimeä uudelleen + + 1 poistettu. + + Ohjelmaa tämän toistamiseen ei ole asennettu + + NewPipen tietosuojakäytäntö + NewPipe ottaa yksityisyytesi tosissaan. Siksi se ei kerää sinulta mitään tietoja ilman lupaasi. NewPipen tietosuojakäytännössä selitetään tarkasti mitä tietoja lähetetään tai tallennetaan virheraportin yhteydessä. + Lue tietosuojakäytäntö + Automaattisesti lisää ehdotettu video soittolistaan + Videostriimejä ei löytynyt ladattavaksi + + NewPipe on vapaata softaa. Voit käyttää sitä, katsella sekä muokata sen koodia ja parannella sitä ilmaiseksi mielesi mukaan. Tarkemmin sanottuna, voit jakaa sitä edelleen ja/tai muokata sitä Free Software Foundationin julkaiseman GNU GPL:n, joko versio kolmosen (GPLv3), tai uudemman, ehdoilla. + Haluatko poistaa tämän katseluhistoriasta? + Oletko varma että haluat poistaa kaiken katseluhistoriasta? + Viimeksi toistettu + Eniten toistetut + + Vienti valmis + Tuonti valmis + Virheellinen ZIP-tiedosto + Varoitus: Ei voitu tuoda kaikkia tiedostoja. + Tämä nollaa nykyiset asetuksesi. + Haluatko myös tuoda asetukset? + + Avaa alasvetovalikko + Sulje alasvetovalikko + Tähän tulee jotain jossainvaiheessa ;D + + + Ensisijainen avaustapa + Oletustoiminto avatessa sisältöä — %s + + Videosoitin + Taustasoitin + Ponnahdusikkunasoitin + Kysy aina + + Haetaan infoa… + Ladataan pyydettyä sisältöä + + Luo uusi soittolista + Poista soittolista + Uudelleennimeä soittolista + Nimi + Lisää soittolistaan + Aseta soittolistan kuvakkeeksi + + Tallenna soittolista kirjanmerkkeihin + Poista kirjanmerkki + + Haluatko poistaa tämän soittolistan? + Soittolista luotu + Lisätty soittolistaan + Soittolistan kuvake muutettu + Soittolistaa ei voitu poistaa + + Ei tekstityksiä + + Sovita + Täytä + Suurenna + + Automaattisesti luotu + + Tekstitykset + Muokkaa tekstitysten kokoa ja taustaa. Asetusten päivittämiseksi sinun tulee käynnistää ohjelma uudelleen + + Laita päälle LeakCanary-muistivuodonpaljastin (virheenkorjausta varten) + Muistivuotojen valvonta voi aiheuttaa ohjelman hidastumisen virhetilanteissa + + Raportoi yhteensopimattomuusvirheitä jotka aiheutuvat vanhoista ohjelmista + Pakota raportointi kuljetuskelvottomille Rx-poikkeuksille jotka ovat muistisirpaleiden tai aktiviteettielämänkaaren ulkopuolella poiston jälkeen + + Tuo/Vie + Tuo + Tuo kohteesta + Vie kohteeseen + + Tuodaan… + Viedään… + + Tuo tiedosto + Edellinen vienti + + Tilauksia ei voitu tuoda + Tilauksia ei voitu viedä + + Tuo youtube-tilaukset lataamalla ensin tilauslistatiedostosi: +\n +\n1. Mene osoitteeseen: %1$s +\n2. Kirjaudu sisään kun niin vaaditaan +\n3. Latauksen pitäisi alkaa (se on se tiedosto) + Tuo SoundCloud-profiili kirjoittamalla joko osoite tai ID:si: +\n +\n1. Laita päälle työpöytämoodi selaimessasi (tai käytä tietokonetta, tämä sivu ei toimi mobiilisivuna) +\n2. Mene tähän osoitteeseen: %1$s +\n3. Kirjaudu sisään kysyttäessä. +\n4. Kopioi se nettiosoite johon sinut ohjattiin. + sinun käyttäjänimesi, soundcloud.com/<sinun käyttäjänimesi> + + Ota huomioon että tämä operaatio voi käyttää paljon dataa. +\nHaluatko jatkaa? + + Toiston nopeuden säätimet + Musiikkitempo + Sävelkorkeus + Irroita tempo ja nopeus toisistaan (saattaa aiheuttaa säröä äänessä) + Kelaa eteenpäin hiljaisissa kohdissa + Askel + Nollaa + + Jotta olisimme kelpoisia EU:n uuden yleisen tietosuoja-asetuksen (GDPR) kannalta, meidän pitää muistuttaa sinua lukemaan NewPipen tietosuojakäytäntö. Lue se oikeasti. Sinun pitää myös hyväksyä se jotta voit lähettää virheraportin. + Hyväksy + Hylkää + + Ei rajaa + Rajoita resoluutiota kun mobiilidata on käytössä + Pienennä vaihtaessa ohjelmaa + Toiminto kun vaihdetaan toiseen ohjelmaan päävideosoittimesta — %s + Ei koskaan + Pienennä taustasoittimeksi + Muuta ponnahdusikkunaksi + + diff --git a/app/src/main/res/values-fr/strings.xml b/app/src/main/res/values-fr/strings.xml index ef071c316..07deb1659 100644 --- a/app/src/main/res/values-fr/strings.xml +++ b/app/src/main/res/values-fr/strings.xml @@ -35,7 +35,7 @@ Miniature d’aperçu vidéo Je n’aime pas J’aime - Langue du contenu par défaut + Langue du contenu par défaut Miniature de l’avatar de l’utilisateur Utiliser un lecteur vidéo externe Utiliser un lecteur audio externe @@ -431,14 +431,12 @@ \n1. Suivez ce lien : %1$s \n2. Connectez-vous à votre compte lorsque ce sera demandé \n3. Un téléchargement va démarrer (ce sera celui du fichier nécessaire à l\'importation des abonnements)" - Pour importer vos abonnements SoundCloud, vous devez connaitre l\'URL de votre profil ou votre identifiant (id). Si vous le savez, tapez-le ci-dessous. + Importez un profil SoundCloud avec l\'URL de votre profil ou votre identifiant (id) : \n -\nSi vous ne le connaissez pas, veuillez suivre les étapes suivantes : -\n -\n1. Activer le \"mode bureau\" dans votre navigateur (le site n\'est pas accesible en mode mobile) +\n1. Activer le \"mode bureau\" dans votre navigateur (le site n\'est pas accessible en mode mobile) \n2. Suivez cette URL : %1$s \n3. Connectez-vous à votre compte -\n4. Copier l\'URL vers lequel vous venez d\'être redirigé (qui est l\'URL de votre profil) +\n4. Copier l\'URL vers lequel vous venez d\'être redirigé (qui est l\'URL de votre profil). votreID, soundcloud.com/votreid Cette opération peut consommer beaucoup de données mobiles. @@ -495,7 +493,7 @@ Minimiser lors du changement d\'application Action lors du changement d\'applications depuis le lecteur vidéo —%s Aucune - Lecture en arrière plan - Mettre en lecteur popup + Minimiser pour lire en arrière plan + Minimiser vers lecteur PopUp diff --git a/app/src/main/res/values-gl/strings.xml b/app/src/main/res/values-gl/strings.xml new file mode 100644 index 000000000..f137a092e --- /dev/null +++ b/app/src/main/res/values-gl/strings.xml @@ -0,0 +1,464 @@ + +Toque em «Procurar» para comezar + %1$s visualizacións + Publicado o día %1$s + Non foi encontrado ningún reprodutor. Desexa instalar o VLC? + Non foi encontrado ningún reprodutor (pode instalar o VLC para o reproducir) + Instalar + Cancelar + Abrir no navegador + Abrir no modo popup + Compartillar + Descarregar + Descarregar o ficheiro de emisión. + Procurar + Opcións + Non querería dicir «%1$s»? + Compartillar con + Escoller un navegador + rotación + Usar un reprodutor de vídeo externo + Podería NON haber audio con algunhas resolucións se esta opción estiver activa + Usar un reprodutor externo de audio + Modo popup do NewPipe + Subscribir + Subscrito + Xa non está subscrito ao canal + Non foi posíbel modificar a subscrición + Non foi posíbel actualizar a subscrición + Mostrar información + + Principal + Subscricións + Favoritos + + Novidades + + Segundo plano + Modo popup + Engadir a + + Ruta de descarga de vídeos + Ruta onde gardar os vídeos descarregados + Introduza a ruta de descarga de vídeos + + Ruta de descarga de audio + Ruta onde gardar o audio descarregado + Introduza a ruta de descarga dos ficheiros de audio + + Reproducir automaticamente + Reproducir o vídeo pedido cando o NewPipe sexa invocado por outro aplicativo + Resolución predeterminada + Resolución predeterminada do popup + Mostrar resolucións máis altas + Moitos dispositivos non permiten reproducir vídeos en 2K/4K + Reproducir co Kodi + O aplicativo Kore non foi encontrado. Desexa instalalo? + Mostrar a opción «Reproducir co Kodi» + Mostrar unha opción para reproducir o vídeo co Kodi Media Center + Audio + Formato de audio predeterminado + Formato de vídeo predeterminado + WebM — formato libre + M4A — mellor calidade + Tema + Claro + Escuro + Negro + Lembrar o tamaño e a posición do «popup» + Lembrar o tamaño e a posición anteriores do «popup» + Usar un salto inexacto mais inexacto + O salto inexacto permite saltar a posicións máis rápido, mais con menos precisión + Carregar miniaturas + Desactíveo para evitar a carga de miniaturas e poupar datos e memoria. Modificar esta opción limpa a caché de imaxes da memoria e do disco + A caché de imaxes foi limpada + Os metadatos da caché foron eliminados + Eliminar todos os datos de páxinas en caché + Os metadatos da caché foron eliminados + Colocar a seguinte emisión na cola automaticamente + Engadir automaticamente unha emisión ao reproducir a última emisión nunha cola sen repetición + Controis de xesto do reprodutor + Usar xestos para controlar o brillo e volume do reprodutor + Suxestións de procura + Mostrar suxestións ao procurar + Historial de procura + Gardar os termos de pesquisa localmente + Historial e caché + Gardar historial de vídeos vistos + Retormar o vídeo ao enfocar + Continuar a reprodución após interrupcións (como chamadas) + Descarregar + Vídeo seguinte + Mostrar vídeos «seguintes» e «semellantes» + Mostrar a suxestión «Manteña presionado para engadir á cola» + Mostrar unha suxestión ao premer o botón de segundo plano ou o de popup na páxina de detalles do vídeo + Este URL non está soportado + País predeterminado para o contido + Servizo + Idioma predeterminado do contido + Reprodutor + Comportamento + Vídeo e audio + Historial e caché + Popup + Aparencia + Outros + Depuración + Reproducindo en segundo plano + Reproducindo en modo «popup» + Na cola do reprodutor en segundo plano + Na cola do reprodutor popup + Reproducir + Contido + Mostrar contido con restrición de idade + Vídeo con restrición de idade. Pode permitir a reprodución deste material nas Opcións. + en directo + Descargas + Descargas + Relatorio de erro + Todo + Canal + Canais + Lista de reprodución + Listas de reprodución + Pistas + Usuarios + Si + Máis tarde + Desactivado + Filtro + Actualizar + Limpar + Redimensionando + Mellor resolución + Desfacer + Reproducilos todos + Sempre + Só unha vez + Ficheiro + + Notificación do NewPipe + Notificacións para o NewPipe e os reprodutores «popup» + + [Descoñecido] + + Mudar a orientación + Mudar para o segundo plano + Mudar para o «popup» + Mudar para principal + + Importar base de datos + Exportar base de datos + Isto vai sobreescribir o seu historial e as súas subscricións actuais + Exportar historial, subscricións e listas de reprodución + Limpar historial de reproducións + Elimina o historial de emisións reproducidas + Elimina todo o historial de reproducións. + O historial de reproducións foi eliminado. + Limpar o historial de procura + Elimina o historial de termos procurados + Elimina todo o historial de procura. + O historial de procuras foi eliminado. + Erro + Erro de rede + Non foi posíbel carregar todas as miniaturas + Non foi posíbel descifrar a asinatura do vídeo + Non foi posíbel procesar o sitio web + Non foi posíbel procesar o sitio web por completo + O contido non está dispoñíbel +\n + Bloqueado pola GEMA + Non foi posíbel configurar o menú de descargas + Isto é unha emisión en directo, polo que aínda non está soportado. + Non foi posíbel obter unha emisión + Non foi posíbel carregar a imaxe + O aplicativo pechouse + Non foi posíbel reproducir este vídeo + Ocorreu un erro irrecuperábel co reprodutor + Recuperándose dun erro do reprodutor + Os reprodutores externos non soportan estes tipos de ligazóns + URL inválido + Non foi encontrada ningunha emisión de vídeo + Non foi encontrada ningunha emisión de audio + Directorio inválido + A fonte do ficheiro ou contido é inválida + O ficheiro non existe ou non ten permisos suficientes para o ler ou escribir + O nome do ficheiro non pode estar vacío + Ocorreu un erro: %1$s + Non hai emisións para descargar + + Deculpe, isto non debería ter acontecido. + Informar do erro por correo electrónico + Desculpe, ocorreron algúns erros. + Relatorio + Información: + Que ocorreu: + Problema:\\nPetición:\\nIdioma do contido:\\nServizo:\\nHora GMT:\\nPaquete:\\nVersión:\\nVersión do SO: + O teu comentario (en inglés): + Detalles: + + + Miniatura do vídeo + Miniatura do vídeo + Miniatura do avatar do autor + Gosto + Non gosto + Usar o Tor + (Experimental) Redirixir o tráfico polo Tor para aumentar a privacidade (as emisións aínda non están soportadas). + Informar dun erro + Relatorio do usuario + Non hai resultados + Nada que ver + Arrastre para reordenar + + Non foi posíbel crear o directorio «%1$s» + O directorio de descargas «%1$s» foi creado + + Vídeo + Audio + Tentar de novo + A permisión de acceso ao almacenamento foi denegada + Usar o reprodutor antigo + Versión interna anticuada do reprodutor Mediaframework + + K + M + MM + + Ningún subscrito + + %s subscrito + %s subscritos + + + Ningunha visualización + + %s visualización + %s visualizacións + + + Ningún vídeo + + %s vídeo + %s vídeos + + + Comezar + Pausar + Reproducir + Crear + Eliminar + Eliminar un + Eliminalos todos + Suma de comprobación + Descartar + Renomear + + Nova misión + OK + + Nome do ficheiro + Fios + Erro + O servidor non está soportado + O ficheiro xa existe + O URL está mal formado ou a Internet non está dispoñíbel + Descarga do NewPipe + Toque para ver detalles + Por favor, agarde… + Copiado para o portarretallos + Por favor, seleccione o directorio para descargas + Esta permisión é necesaria +\npara abrir o vídeo no modo «popup» + 1 elemento foi eliminado. + + reCAPTCHA + Desafío reCAPTCHA + Desafío reCAPTCHA solicitado + + Descarregar + Caracteres permitidos nos nomes de ficheiros + Os caracteres inválidos serán substituídos por este valor + Carácter de substitución + + Letras e díxitos + A maioría dos caracteres especiais + + Non hai ningún aplicativo instalado para reproducir este ficheiro + + Sobre o NewPipe + Opcións + Sobre + Licenzas de terceiros + © %1$s de %2$s, so %3$s + Non foi posíbel carregar a licenza + Abrir o sitio web + Sobre + Colaboradores + Licenzas + Reprodutor lixeiro e libre para Android. + Colaborar + Se ten ideas de tradución, mudanzas ao deseño, limpeza de código ou mudanzas serias deste—a axuda sempre é benvida. Canto máis fixermos, tanto máis vai mellorar! + Ver no GitHub + Doar + O NewPipe é desenvolvido por voluntarios que empregan o seu tempo libre para lle ofrecer a mellor experiencia. Pode retribuír e así axudar os desenvolvedores a tornaren o NewPipe aínda mellor en canto desfrutan dunha cunca de café. + Retribuír + Sitio web + Visite o sitio web do NewPipe para saber máis e ver noticias sobre o proxecto. + Política de privacidade do NewPipe + O proxecto NewPipe dá moita importancia á súa privacidade. Por tanto, non recolle ningún dato sen o seu consentimento. +\nA política de privacidade do NewPipe explica con máis detalle que datos son enviados e gardados cando envía un relatorio de erros. + Ler a política de privacidade + Licenza do NewPipe + O NewPipe é software copyleft libre: pode usalo, estudalo, compartillalo e melloralo como quixer. En concreto, pode redistribuílo e/ou modificalo so os termos da Licenza Pública Xeral GNU, publicada pola Free Software Foundation, quer a versión 3 da Licenza, ou calquera outra versión posterior da súa escolla. + Ler a licenza + + + Historial + Procurado + Visto + O historial está desactivado + Historial + O historial está vacío + O historial foi limpado + O elemento foi eliminado + Desexa eliminar este elemento do historial de procura? + Desexa eliminar este elemento do historial de visualizacións? + Ten a certeza de querer eliminar todos os elementos do historial? + Última reprodución + Máis reproducido + + Contido da páxina principal + Páxina en branco + Páxina do «kiosk» + Páxina de subscricións + Páxina da fonte + Páxina do canal + Seleccione un canal + Non subscribiu ningún canal + Seleccione un «kiosk» + Exportación completa + Importación completada + Ficheiro ZIP inválido + Aviso: non todos os ficheiros foron importados. + Isto vai reescribir a súa configuración actual. + Desexa importar tamén as opcións? + + Kiosk + Tendencias + Top 50 + Novo e popular + Reprodutor en segundo plano + Reprodutor «popup» + Eliminar + Detalles + Opcións de audio + Manteña para colocar na cola + Colocar na cola de segundo plano + Colocar na cola de popup + Comezar a reprodución aquí + Comezar aquí en segundo plano + Comezar aquí en popup + + Abrir o menú + Fechar o menú + Algo vai xurdir aquí en breve ;D + + + Acción «abrir» preferida + Acción predeterminada ao abrir o contido — %s + + Reprodutor de vídeo + Reprodutor en segundo plano + Reprodutor en popup + Preguntar sempre + + Obtendo información… + Carregando o contido solicitado + + Crear unha nova lista de reprodución + Eliminar a lista de reprodución + Renomear a lista de reprodución + Nome + Engadir á lista de reprodución + Estabelecer como miniatura da lista de reprodución + + Gardar a lista de reprodución nos marcadores + Eliminar o marcador + + Desexa eliminar esta lista de reprodución? + A lista de reprodución foi creada + O vídeo foi engadido á lista de reprodución + A miniatura da lista de reprodución foi modificada + Non foi posíbel eliminar a lista de reprodución + + Sen lenda + + Axustar + Encher + Zoom + + Xerado automaticamente + + Lenda + Modificar a escala de texto da lenda e os estilos de segundo plano do reprodutor. Para ter efecto, é preciso reiniciar o aplicativo + + Activar LeakCanary + A monitorización de fugas de memoria pode facer que o aplicativo deixe de responder cando hai vertedura da pila + + Informar de erros de fóra do ciclo de vida + Forzar a comunicación de excepcións Rx non entregábeis fóra do ciclo de vida do fragmento ou actividade após o descarte + + Importar/Exportar + Importar + Importar de + Exportar a + + Importando… + Exportando… + + Importar un ficheiro + Exportación anterior + + Non foi posíbel importar as subscricións + Non foi posíbel exportar as subscricións + + Pode importar as súas subscricións de YouTube descarregando o ficheiro de exportacións: +\n +\n1. Acceda ao URL %1$s +\n2. Inicie a sesión cando lle for solicitado +\n3. Ha comezar unha descarga (a do ficheiro de exportación) + Pode importar un perfil do SoundCloud escribindo o URL ou o seu ID: +\n +\n1. Active o «modo desktop» nun navegador da Internet (o sitio non está dispoñíbel para dispositivos móbiles) +\n2. Acceda ao URL %1$s +\n3. Inicie a sesión cando lle for solicitado +\n4. Copie o URL de perfil a que foi redirixido. + oseuID, soundcloud.com/oseuid + + Teña en conta que esta operación pode consumir moitos recursos de rede. +\n +\nDesexa continuar? + + Controis de velocidade da reprodución + Tempo + Ton + Desvincular (pode causar distorsión) + Avanzar rápido durante os momentos de silencio + Paso + Reiniciar + + Para cumprirmos co Regulamento Xeral Europeo de Protección de Datos (GDPR), chamamos a súa atención sobre a nova política de privacidade do NewPipe. Por favor, léao con coidado. +\nDebe aceptalo para nos enviar un relatorio de erro. + Aceptar + Recusar + + Sen límite + Limitar a resolución ao usar datos móbiles + Minimizar ao mudar de aplicativo + Acción ao mudar de aplicativo desde o reprodutor orixinal — %s + Ningunha + Minimizar ao reprodutor en segundo plano + Minimizar o reprodutor popup + + diff --git a/app/src/main/res/values-he/strings.xml b/app/src/main/res/values-he/strings.xml index 21e944ea8..3ba9bbd09 100644 --- a/app/src/main/res/values-he/strings.xml +++ b/app/src/main/res/values-he/strings.xml @@ -59,7 +59,7 @@ הסרטון הבא הראה את הסרטונים הבאים וסרטונים דומים כתובת URL לא נתמכת - שפת התוכן המועדפת + שפת התוכן המועדפת סרטים ושמע חלון צץ תצוגה diff --git a/app/src/main/res/values-hi/strings.xml b/app/src/main/res/values-hi/strings.xml index 22e90ac25..bca7a62cc 100644 --- a/app/src/main/res/values-hi/strings.xml +++ b/app/src/main/res/values-hi/strings.xml @@ -104,7 +104,7 @@ \"संलग्न करने के लिए पकड़ें रहे\" दिखाए जब बैकग्राउंड और पॉपअप बटन विडियो के विवरण पन्ने में दबाई जाए तो tip को दिखाए ये वाला URL इसमें नहीं चलेगा - डिफ़ॉल्ट विषय की भाषा + डिफ़ॉल्ट विषय की भाषा प्लेयर चाल चलन पॉपअप @@ -247,7 +247,7 @@ %2$s के द्वारा © %1$s जो %3$s के अधीन आते है लाइसेंस load नहीं हो रहा सहयोगकर्ता - एंड्राइड के लिए हल्का और मुफ्त स्ट्रीमिंग। + एंड्राइड के लिए हल्का और मुफ्त स्ट्रीमिंग एप्लिकेशन| अगर आपके पास कोई सुझाव हो जैसे -अनुवाद , डिजाईन में बदलाव ,code को साफ़ रखना , या फिर code में जायदा बदलाव लाना हो तो - साहयता के लिए आपका स्वागत है . जितना ज्यादा होगा उतना बेहतर होगा ! क्या आप इसको खोज इतिहास के मिटाना चाहते है ? @@ -295,7 +295,7 @@ डेटाबेस आयात करें डेटाबेस निर्यात करें आपके वर्तमान इतिहास और सब्सक्रिप्शन को ओवरराइड करेगा - इतिहास, सब्सक्रिप्शन और प्लेलिस्ट निर्यात करें । + इतिहास, सब्सक्रिप्शन और प्लेलिस्ट निर्यात करें एक्सटर्नल प्लेयर इन प्रकार के लिंक सपोर्ट नहीं करता अमान्य URL कोई वीडियो स्ट्रीम नहीं मिला @@ -383,7 +383,7 @@ सभी कैश किए गए वेबपृष्ठ डेटा हटाएं मेटाडाटा कैश मिटा दिया गया अगली स्ट्रीम को स्वचालित रूप से जोड़ें - गैर-दोहराने वाली कतार में अंतिम स्ट्रीम चलाते समय संबंधित स्ट्रीम को स्वतः संलग्न करें। + गैर-दोहराने वाली कतार में अंतिम स्ट्रीम चलाते समय संबंधित स्ट्रीम को स्वतः संलग्न करें फाइल चेनल्स @@ -416,7 +416,7 @@ क्या आप सेटिंग्स भी आयात करना चाहते है? पसंदीदा \'खोलने पर\' करवाई - सामग्री खोलते समय डिफ़ॉल्ट कारवाही + सामग्री खोलते समय डिफ़ॉल्ट कारवाही — %s केप्सन प्लेयर केप्शन के शब्दों का परिमाण और पृष्ठभूमि शैलियो को बदले। लागू करने के लिए ऐप को पुनः प्रारम्भ करना जरूरी है। diff --git a/app/src/main/res/values-hr/strings.xml b/app/src/main/res/values-hr/strings.xml index 8e73cdf4f..a6a532975 100644 --- a/app/src/main/res/values-hr/strings.xml +++ b/app/src/main/res/values-hr/strings.xml @@ -42,7 +42,7 @@ Unesi put za preuzimanje zvučne datoteke Auto. reprod. kada je NewPipe pozvan iz druge apl. - Automatski reproduciraj videozapis kad je NewPipe pozvan iz druge aplikacije + Reproducira videozapis kad je NewPipe pozvan iz druge aplikacije Zadana razlučivost Zadana razlučivost skočnog prozora Prikaži veće razlučivosti @@ -77,7 +77,7 @@ Sljedeći videozapis Prikaži sljedeće i slične videozapise URL nije podržan - Zadani jezik sadržaja + Zadani jezik sadržaja Video i zvuk Skočni prozor Izgled @@ -116,7 +116,7 @@ Nije moguće dobaviti stream Nije moguće učitati sliku Aplikacija/UI se srušio - Oprostitee, ovo se nije trebalo dogoditi. + Oprostite, ovo se nije trebalo dogoditi. Prijavi pogrešku putem e-maila Oprostite, neke greške su se dogodile. PRIJAVI @@ -284,7 +284,7 @@ Web stranica Ovdje započni reprodukciju Ovdje započni repr. u pozadini - Dadaj na red čekanja u pozadini + Dodaj na red čekanja u pozadini Dodaj na red u skočnom prozoru Započni ovdje u Skočnom prozoru @@ -333,4 +333,109 @@ Monitoring curenja memorije može uzrokovati greške u radu aplikacije prilikom odlaganje gomile Izvijestite o pogreškama izvan životnog ciklusa + Prikaži informacije + + Oznake + + Dodaj u + + Učitaj slike + Slikovna predmemorija obrisana + Obriši predmemorijsku metupodataka + Usluga + Kanali + Playliste + Pjesme + Korisnici + Uvijek + Samo jednom + Datoteka + + Prijeđi na pozadinu + Prijeđi na skočni prozor + Prijeđi na glavni + + Uvoz baze podataka + Izvoz baze podataka + Poništava vašu trenutnu povijest i pretplate + Izvoz povijesti, pretplata i playlisti + Očisti povijest gledanja + Briše povijest reproduciranih streamova + Obriši cijelu povijest gledanja. + Povijest gledanja izbrisana. + Obriši povijest pretraživanja + Obriši cijelu povijest pretraživanja. + Povijest pretraživanja obrisana. + Neispravan URL + Nevažeći direktorij + Naziv datoteke ne može biti prazan + Dogodila se greška: %1$s + Povucite za promjenu redoslijeda + + Stvori + Izbriši jedan + Izbriši sve + Odbaci + Preimenuj + + 1 stavka izbrisana. + + Nijedna aplikacija nije instalirana za reprodukciju te datoteke + + Vrati + Posjetite web stranicu NewPipe za više informacija i vijesti. + NewPipeova pravila o privatnosti + Pročitajte pravila o privatnosti + Želite li izbrisati ovu stavku iz povijesti gledanja? + Jeste li sigurni da želite izbrisati sve stavke iz povijesti? + Zadnje svirano + Najviše svirano + + Izvoz završen + Uvoz završen + Nema važeće ZIP datoteke + Upozorenje: Nije moguće uvesti sve datoteke. + Ovo će poništiti vaše trenutne postavke. + Želite li također uvesti postavke? + + Uvoz/Izvoz + Uvoz + Uvoz iz + Izvoz u + + Uvoz… + Izvoz… + + Uvoz datoteke + Prethodni izvozi + + Nije moguće uvesti pretplatnike + Nije moguće izvesti pretplatnike + + Uvezite YouTube pretplatnike preuzimanjem izvozne datoteke: +\n +\n1. Idite na ovaj URL: %1%s +\n2. Ulogirajte se +\n3. Preuzimanje bi trebalo početi (to je izvozna datoteka) + vašID, soundcloud.com/vašID + + Uzmite u obzir da ova operacija može uzrokovat veliku potrošnju prometa. +\n +\nŽelite li nastaviti? + + Kontrole brzine reprodukcije + Premotaj naprijed tijekom šutnje + Korak + Resetiraj + + Prihvati + Odbij + + Bez ograničenja + Ograniči rezoluciju tijekom korištenja mobilnih podataka + Nijedan + Reproduktor za stream nije pronađen (možete instalirati VLC za reprodukciju) + Preuzmite datoteku za stream. + Koristi brzo netočno premotavanje + Netočno premotavanje omogućava reproduktoru da premota na mjesto brže uz manju preciznost diff --git a/app/src/main/res/values-hu/strings.xml b/app/src/main/res/values-hu/strings.xml index f4687149a..2b811d53b 100644 --- a/app/src/main/res/values-hu/strings.xml +++ b/app/src/main/res/values-hu/strings.xml @@ -2,7 +2,7 @@ %1$s megtekintés Közzétéve: %1$s - Nem található megfelelő lejátszó. Feltelepíti a VLC lejátszót? + Nem található megfelelő lejátszó. Telepíted a VLC lejátszót? Telepítés Mégse Megnyitás böngészőben @@ -15,22 +15,24 @@ Válasszon böngészőt forgatás Videófájlok letöltési helye - Útvonal a letöltött videók tárolásához. + Útvonal a letöltött videók tárolásához Adja meg a videófájlok letöltési helyét Alapértelmezett felbontás Lejátszás Kodi-val - A Kore alkalmazás nem található. Feltelepíti a Kore lejátszót? + A Kore alkalmazás nem található. Telepíted a Kore lejátszót? \"Lejátszás Kodi-val\" opció mutatása - Mutat egy opciót a videók Kodi médiaközponttal való lejátszására. + Opció mutatása a videók Kodi médiaközponttal való lejátszására Hang Alapértelmezett hang formátum + WebM — szabad formátum + M4A — jobb minőség Letöltés Következő videó A webcím nem támogatott Külső videólejátszó használata Külső hanglejátszó használata - Adja meg a hangfájlok letöltési helyét. + Add meg a hangfájlok letöltési helyét Tor használata (Kísérleti) Adatforgalom Tor-on keresztüli kényszerítése a biztonság fokozása érdekében (a videó stream-elés még nem támogatott). @@ -41,7 +43,7 @@ Lejátszás háttérben Videó és audio Megjelenés - Tartalom preferált nyelve + Tartalom preferált nyelve További beállítások Következő hasonló videók mutatása Sötét @@ -60,12 +62,12 @@ Tartalom Korhatáros tartalom mutatása Hiba - A tartalom nem elérhető. - GEMA által blokkolt. - Ez egy élö közvetités. Még nem támogatva. - Automatikus lejátszás külső indítás esetén - Videók automatikus lejátszása a NewPipe külső indításakor. - A video korhatáros. A megtekintéséhez engedélyezze a korhatáros videókat. + A tartalom nem elérhető + GEMA által blokkolt + Ez egy élő közvetítés, amely még nem támogatott. + Automatikus lejátszás + Videók automatikus lejátszása, ha a NewPipe egy másik alkalmazásból lett indítva + Korhatáros videó. A megtekintéséhez engedélyezze a korhatáros videókat a Beállításokban. élő JELENTÉS @@ -76,11 +78,11 @@ Sajnos hiba történt. - Ennek nem kellett volna megtörténnie. - Hibajelentés emailben - A stream nem elérhető. - Nem sikerült a letöltés menü beállítása. - Nem sikerült a video url aláírás azonosítása. + Elnézést, ennek nem kellett volna megtörténnie. + Hibajelentés e-mailben + A stream nem elérhető + Nem sikerült a letöltés menü beállítása + Nem sikerült a videó URL aláírás azonosítása Háttértárhoz való hozzáférés megtagadva Újra Hibajelentés @@ -90,21 +92,21 @@ Audio A kezdéshez koppints a keresésre Nem sikerült az összes előnézeti kép betöltése - Nem sikerült a weblap betöltése. - Nem sikerült a weblap teljes betöltése. + Nem sikerült a weblap betöltése + Nem sikerült a weblap teljes betöltése Letöltések Letöltések Hibabejelentés Indít Szünet - Megtekintés + Lejátszás Törlés Ellenőrző összeg - Ok + Rendben - Filenév + Fájlnév Threadek Hiba A file már létezik @@ -146,12 +148,12 @@ Keresési javaslatok Mutasson javaslatokat keresés közben Keresési előzmények - Előzmények + Előzmények és gyorsítótár Megnézett videók nyomon követése "Lejátszás folytatása félbeszakítás után (pl.: telefonhívás) " Lejátszó Működés - Előzmények + Előzmények és gyorsítótár Felugró ablak Hibaelhárítás Lejátszás felugró ablakban @@ -180,7 +182,7 @@ Adatbázis importálása Adatbázis exportálása Felül fogja írni a jelenlegi előzményeket és feliratkozásokat - Előzmények,Feliratkozások és lejátszási listák exportálása. + Előzmények, feliratkozások és lejátszási listák exportálása Kép betöltése sikertelen Alkalmazás/Kezelő felület összeomlott Videó lejátszása sikertelen @@ -192,4 +194,242 @@ Mi:\\nKérés:\\nTartalom nyelve:\\nSzolgáltatás:\\nGMT Idő:\\nCsomag:\\nVerzió:\\nOperációs Rendszer verzió: Nincs találat Régi lejátszó használata - + Adatfolyam fájl letöltése. + Hozzáadás + + Gyorsabb, de pontatlan tekerés használata + A pontatlan tekerés lehetővé teszi, hogy gyorsabban ugorjon a pozíciókra, de kevesebb pontossággal + Bélyegképek betöltése + Kapcsold ki, hogy a bélyegképek ne legyenek betöltve és mentve, így csökkentve az adat és memória használatot. Ennek az értéknek a megváltoztatása törli a memóriában és a meghajtón lévő bélyegkép gyorsítótárat + A bélyegkép gyorsítótár törölve + Gyorsítótárazott metaadat törlése + Minden gyorsítótárazott weboldal adat törlése + A metaadat gyorsítótár törölve lett + Következő videó automatikus lejátszása + Keresési előzmények tárolása az eszközön + Szolgáltatás + Csatornák + Lejátszási listák + Zeneszámok + Felhasználók + Fájl + + Folytatás a háttérben + Folytatás felugró ablakban + Megtekintési előzmények törlése + Eltávolítja a megtekintési előzményeket + Összes megtekintési előzmény törlése. + Megtekintési előzmények törölve. + Keresési előzmények törlése + Eltávolítja a kereséshez használt kifejezéseket az előzményekből + Összes keresési előzmény törlése. + Keresési előzmények törölve. + Lejátszási hiba történt + Lejátszási hiba helyreállítása + Érvénytelen könyvtár + Érvénytelen fájl vagy tartalom forrás + A fájl nem létezik vagy jogosultsági hiba lépett fel + A fájl neve nem lehet üres + Hiba történt: %1$s + Nincs letölthető adatforrás + + Itt nincs semmi + Húzza az átrendezéshez + + Régi beépített Mediaframework lejátszó + + e + M + Mrd + + Nincs feliratkozó + + %s feliratkozó + %s feliratkozó + + + Nincs megtekintés + + %s megtekintés + %s megtekintés + + + Nincs videó + + %s videó + %s videó + + + Létrehozás + Egy törlése + Összes törlése + Átnevezés + + Ez az engedély szükséges a felugró ablakban történő megnyitáshoz + 1 elem törölve. + + reCAPTCHA + reCAPTCHA rejtvény + reCAPTCHA rejtvény igényelve + + Letöltés + Fájlnevekben engedélyezett karakterek + Érvénytelen karakterek ezzel az értékkel kerülnek helyettesítésre + Csere karakter + + Betűk és számok + Legtöbb speciális karakter + + Nincs a fájl lejátszásához szükséges alkalmazás telepítve + + A NewPipe alkalmazásról + Beállítások + Az alkalmazásról + Engedély betöltése sikertelen + Honlap megnyitása + Az alkalmazásról + Közreműködők + Engedélyek + Ingyenes, egyszerű streamelés Androidon. + Közreműködés + Legyen ötleted a fordítással, a megjelenéssel, a forrás kód tisztításával vagy komolyabb átszervezésével kapcsolatban, bármilyen segítséget szívesen fogadunk. Járulj hozzá az alkalmazás fejlesztéséhez! + Megtekintés GitHubon + Adományozás + A NewPipe alkalmazást önkéntesek fejlesztik szabadidejükben, hogy a lehető legjobb élményt hozzák el neked. Járulj hozzá a fejlesztők kávéjához, hogy tovább dolgozhassanak az alkalmazáson! + Hozzájárulás + Honlap + Látogasd meg a NewPipe honlapját további információkért és hírekért! + A NewPipe adatvédelmi irányelvei + A NewPipe projekt komolyan veszi az adataid védelmét. Az alkalmazás nem gyűjt semmilyen adatot a beleegyezésed nélkül. +\nA NewPipe adatvédelmi irányelve részletesen elmagyarázza, mely adatok kerülnek elküldésre és tárolásra az alkalmazás összeomlásának jelentésekor. + Az adatvédelmi irányelvek elolvasása + A NewPipe engedélye + Engedély elolvasása + + + Előzmények + Keresési előzmények + Megtekintési előzmények + Előzmények kikapcsolva + Előzmények + Nincsenek előzmények + Előzmények törölve + Elem törölve + Törölni kívánja ezt az elemet a keresési előzmények közül\? + Törölni kívánja ezt az elemet a megtekintési előzmények közül\? + Biztosan törölni kíván minden elemet az előzmények közül\? + Utoljára lejátszott + Legtöbbet lejátszott + + Főoldal tartalma + Üres oldal + Újságárus oldal + Feliratkozási oldal + Feed oldal + Csatorna oldal + Csatorna választása + Még nincs csatorna feliratkozás + Újságárus választása + Sikeres export + Sikeres import + Nem érvényes ZIP fájl + Figyelmeztetés: nem sikerült az összes fájl importálása. + Ez felül fogja írni a jelenlegi beállításokat. + A beállításokat is importálni kívánja\? + + Újságárus + Felkapott + Top 50 + Új és friss + Felugró ablak lejátszó + Eltávolítás + Részletek + Hang beállítások + Itt hamarosan megjelenik valami :) + + + Alapértelmezett tevékenység „%s” típusú tartalom megnyitásakor + + Videólejátszó + Lejátszás háttérben + Felugró ablakos lejátszás + Mindig kérdezz rá + + Információk gyűjtése… + Kért tartalom betöltése + + Új lejátszási lista létrehozása + Lejátszási lista törlése + Lejátszási lista átnevezése + Név + Lejátszási listához adás + Beállítás lejátszási lista előképeként + + Könyvjelző törlése + + Kívánja törölni ezt a lejátszási listát\? + Lejátszási listsa létrehozva + Lejátszási listához hozzáadva + Lejátszási lista előképe megváltozott + Nem sikerült a lejátszási lista törlése + + Felirat kikapcsolva + + Illeszkedés + Kitöltés + Közelítés + + Automatikusan létrehozott + + Feliratok + Feliratok méretének és hátterének stílusbeli módosítása. A módosítások életbelépésehez az alkalmazás újraindítása szükséges. + + LeakCanary bekapcsolása + Import/Export + Import + Importálás a következőből + Exportálás a következőbe + + Importálás… + Exportálás… + + Fájl importálása + Előző exportálás + + Sikertelen a feliratkozások importálása + Sikertelen a feliratkozások exportálása + + Importálja YouTube feliratkozásait az export fájl letöltésével: +\n +\n1. Navigáljon erre az oldalra: %1$s +\n2. Jelentkezzen be +\n3. Ekkor az export fájl letöltése megkezdődik + Importálja SoundCloud profilját az URL vagy az azonosítójának begépelésével: +\n +\n1. Az oldal mobileszközökön nem elérhető, így „asztali böngésző mód” szükséges +\n2. Navigáljon erre az oldalra: %1$s +\n3. Jelentkezzen be +\n4. Másolja ki a profil URL-t, ahova át lett irányítva. + azonosítód, soundcloud.com/azonosítód + + Ez a művelet adatforgalom igényes lehet. +\n +\nFolytatni kívánja\? + + Ütem + Hangmagasság + Előrepörgetés csend alatt + Lépés + Helyreállítás + + Elfogadás + Elutasítás + + Nincs korlát + Felbontás korlátozása mobilinternet használata esetén + Művelet alkalmazás váltásakor a fő videólejátszóról — %s + Ne tegyen semmit + Lejátszás folytatása a háttérben + Lejátszás folytatása felugró ablakban + + diff --git a/app/src/main/res/values-id/strings.xml b/app/src/main/res/values-id/strings.xml index 467580fd8..1eef0ffca 100644 --- a/app/src/main/res/values-id/strings.xml +++ b/app/src/main/res/values-id/strings.xml @@ -40,7 +40,7 @@ Video berikutnya Tampilkan video \'berikutnya\' dan \'serupa\' URL tidak didukung - Bahasa konten baku + Bahasa konten baku Video & Audio Tampilan Lainnya diff --git a/app/src/main/res/values-it/strings.xml b/app/src/main/res/values-it/strings.xml index e7c0dc1ee..fbc1c058a 100644 --- a/app/src/main/res/values-it/strings.xml +++ b/app/src/main/res/values-it/strings.xml @@ -10,7 +10,7 @@ Scarica Cerca Impostazioni - Intendevi: %1$s ? + Intendevi %1$s? Condividi con Scegli il browser rotazione @@ -28,7 +28,7 @@ Prossimo video Mostra \'prossimi\' video e video \'simili\' URL non supportato - Lingua predefinita per i contenuti + Lingua predefinita per i contenuti Video e Audio Miniatura anteprima video @@ -74,7 +74,7 @@ Mostra contenuti vietati ai minori Questo video è riservato ad un pubblico maggiorenne. Per accedervi, abilita \"Mostra contenuti vietati ai minori\" nelle impostazioni. - Tocca cerca per iniziare + Tocca Cerca per iniziare Riproduzione automatica Riproduci i video quando NewPipe viene aperto da un\'altra app in diretta @@ -147,7 +147,7 @@ Apri in modalità popup - NewPipe modalità popup + Modalità popup di NewPipe Riproduzione in modalità popup Disattivato diff --git a/app/src/main/res/values-ja/strings.xml b/app/src/main/res/values-ja/strings.xml index ceee62fa9..b73d150e3 100644 --- a/app/src/main/res/values-ja/strings.xml +++ b/app/src/main/res/values-ja/strings.xml @@ -25,14 +25,14 @@ デフォルトの音楽形式 保存 次の動画 - \"次の動画\"と\"関連動画\"を表示します + 「次の動画」と「関連動画」を表示 URLは使用できません - 優先言語 + 優先言語 動画と音楽 %1$s ビュー 動画 プレビュー サムネイル 動画 プレビュー サムネイル - アップローダー サムネイル + 投稿者アイコンのサムネイル 低評価 高評価 外部プレイヤーを使用する @@ -43,9 +43,9 @@ Torを使用する (実験的) 強制的に Tor を経由した経路で保存して、匿名性を高めます(動画の同時再生は未だ対応していません)。 - 外観 - - + テーマ + ダーク + ライト 外観 その他 @@ -59,26 +59,26 @@ 保存場所 \'%1$s\' を作成しました エラー 全てのサムネイルを読み込むことができません - 動画のURL署名を復号できませんでした + 動画の URL 署名を復号できませんでした Webサイトを解析できませんでした コンテンツが利用できません - GEMA によって阻止されました + GEMA にブロックされました 保存メニューを設定できませんでした - 生放送には対応していません + 生放送にはまだ対応していません - 内容 + コンテンツ 年齢制限のあるコンテンツを表示する この動画には年齢制限があります。視聴するには設定から制限を解除して下さい。 - Webサイトを完全には解析できませんでした + ウェブサイトを完全には解析できませんでした 動画を取得できませんでした - 申し訳ありません。発生すべきではありませんでした。 + 申し訳ありません。発生すべきでものではありませんでした。 メールで不具合を報告 - 複数の不具合が発生しました + 申し訳ありません。いくつかのエラーが発生しました。 報告 情報: 何が起こりましたか: @@ -91,7 +91,7 @@ 再試行 ストレージへのアクセスが拒否されました 自動再生 - NewPipeが他のアプリから呼び出された際に、自動的に動画を再生します。 + NewPipe が他のアプリから呼び出された時、動画を再生します。 不具合を報告 利用者報告 @@ -100,7 +100,7 @@ 開始するには検索をタップ 開始 一時停止 - 表示 + 再生 削除 チェックサム @@ -117,7 +117,7 @@ タップして詳細を表示 お待ちください… クリップボードにコピーしました - 利用可能な保存場所を選択して下さい + ダウンロードフォルダを選択して下さい 保存 保存 @@ -126,13 +126,13 @@ 画像を読み込みできません アプリ/UI がクラッシュしました - 何:\\n提案:\\nコンテンツ言語:\\nサービス:\\nGMT 時間:\\nパッケージ:\\nバージョン:\\nOS バージョン: + 何:\\\\n提案:\\\\nコンテンツ言語:\\\\nサービス:\\\\nGMT 時間:\\\\nパッケージ:\\\\nバージョン:\\\\nOSバージョン: reCAPTCHA reCAPTCHA の要求 reCAPTCHA を要求しました - + ブラック すべて チャンネル @@ -161,7 +161,7 @@ デフォルトのポップアップ解像度 高い解像度で表示 - 一部のデバイスのみ 2K/4K ビデオの再生をサポートしています + 2K/4K ビデオの再生は一部のデバイスのみサポートしています 背景 ポップアップ @@ -175,7 +175,7 @@ ポップアップ サイズを変更 - このオプションが有効になっているとき、一部の解像度では音声がありません。 + このオプションが有効になっているとき、一部の解像度では音声がありません プレーヤーのジェスチャー コントロール ジェスチャーを使用してプレーヤーの明るさと音量をコントロールする 検索候補 @@ -193,12 +193,12 @@ このアプリについて 貢献者 ライセンス - Android向けの無料で軽量なYouTubeフロントエンド。 - Github で表示 + Android 向けの自由で軽量なプレイヤー + GitHub で表示 NewPipe のライセンス 翻訳、デザインの変更、コードの整理、動作の重いコードの変更など、アイデアをお持ちではありませんか?ヘルプはいつでも歓迎します。より良いものを一緒に作り上げましょう! ライセンスを読む - 貢献 + 貢献する チャンネル登録 チャンネル登録しました チャンネル登録を解除しました @@ -212,14 +212,14 @@ 検索履歴 検索履歴をローカルに保存します - 再生履歴 + 再生履歴とキャッシュ 再生した動画を記録します フォーカスで再開 電話などによる中断の後、再生を再開します プレーヤー 動画の詳細ページで背景、またはポップアップボタンが押されたときにヒントを表示する 動作 - 履歴 + 履歴とキャッシュ 再生リスト 元に戻す すべて再生 @@ -227,7 +227,7 @@ NewPipeの通知 [不明] - 動画の再生に失敗しました + 動画の再生ができませんでした 回復不能な再生エラーが発生しました 何も見つかりませんでした チャンネル登録なし @@ -241,9 +241,9 @@ ほとんどの特殊文字 寄付 - NewPipeはあなたに最高の経験をもたらすため、自由時間を費やしたボランティアによって開発されています。カップのコーヒー(Java)を楽しんでいる間に、開発者がNewPipeをより良いものにすることが出来るよう、今度はお返しをする時間です! + NewPipe は、あなたに最高の体験を味わってもらうために、ボランティアが自分たちの時間を使って開発しています。開発者たちがコーヒーを飲みながら NewPipe を継続的に改良できるよう、あなたのご支援をお願いします。 Webサイト - NewPipeに関する詳しい情報や最新のニュースについては、我々のWebサイトをご覧ください。 + NewPipe の詳しい情報や最新情報については、ウェブサイトをご覧ください。 履歴 検索履歴 再生履歴 @@ -285,13 +285,13 @@ データベースのインポート データベースのエクスポート 既存の履歴と購読リストは上書きされます - 履歴や購読リスト、プレイリストをエクスポートします。 + 履歴や購読リスト、プレイリストをエクスポートします 再生エラーからの回復中 外部プレーヤーは、これらのタイプのリンクをサポートしていません 無効なURL エクスポートが完了しました インポートが完了しました - 有効なZipファイルがありません + 有効な ZIP ファイルではありません 警告: すべてのファイルをインポートできませんでした。 これにより、現在の設定が上書きされます。 @@ -307,7 +307,7 @@ 常に尋ねる 情報を取得しています… - 要求したコンテンツを読み込んでいます + コンテンツを読み込んでいます 動画ファイルをダウンロード 情報を表示 @@ -353,10 +353,10 @@ ブックマークを削除 このプレイリストを削除しますか? - プレイリストが正常に作成されました + プレイリストが作成されました プレイリストに追加しました プレイリストのサムネイルを変更しました - プレイリストの削除に失敗しました + プレイリストが削除できませんでした 字幕なし @@ -372,8 +372,8 @@ ファイルからインポート 前回のエクスポート - 購読リストのインポートに失敗しました - 購読リストのエクスポートに失敗しました + 購読リストがインポートできませんでした + 購読リストがエクスポートできませんでした テンポ 音程 @@ -381,14 +381,92 @@ バックグラウンド再生リストに追加されました ポップアップ再生リストに追加されました 再生履歴を消去 - 再生した動画の履歴を削除します。 + 再生した動画の履歴を削除します 再生履歴を削除しました。 検索履歴を消去 - 検索キーワードの履歴を削除します。 + 検索キーワードの履歴を削除します 検索履歴を削除しました。 このファイルを再生するためのアプリがインストールされていません 設定をインポートしますか? 字幕 - + チャンネル + プレイリスト + ユーザー + NewPipe プライバシーポリシー + プライバシーポリシーを確認 + おおまかなシーク + おおまかなシークを使用すると、正確さ下がりますが、高速なシークが可能になります + すべてのサムネイルの読み込みと保存を無効化します。このオプションを切り替えるとメモリおよびディスク上の画像キャッシュがクリアされます + 繰り返しでないキューの最後の動画を再生時、関連動画を自動的にキューに追加する + すべての再生履歴を削除します + すべての検索履歴を削除します + ファイル/コンテンツのソースが無効です + + 登録者数 %s 人 + + + 視聴なし + + 視聴回数 %s 回 + + + + %s 本の動画 + + + 1 つのアイテムが削除されました + + 支援する + NewPipe プロジェクトはあなたのプライバシーを非常に大切にしています。あなたの同意がない限り、アプリはいかなるデータも収集しません。NewPipe のプライバシー・ポリシーでは、クラッシュリポート送信時にどのような種類のデータが送信・記録されるかを詳細に説明しています。 + NewPipe は著作権が自由のソフトウェアです。自由であるとは、あなたは自分の自由意志で、ソフトウェアを自由に使ったり、自由に研究したり、自由に改良することができるということです。あなたは、GNU フリーソフトウェア財団が公開する GNU General Public ライセンス バージョン3以降の下に、自由に再配布・修正を行うことができます。 + 最終再生日時 + 最も再生した動画 + + ズーム + + 追加... + + 「長押しして追加」のヒントを表示 + トラック + NewPipe バックグラウンドおよびポップアップのプレーヤーの通知 + + 新しい & ホット + 長押ししてキューに入れる + バックグラウンド時にキューに入れる + ポップアップ時にキューに入れる + ポップアップ時にここから開始 + + すぐにここに表示されます;D + + + お好みの \'開く\' アクション + コンテンツを開くときのデフォルト動作 — %s + + フィット + 埋める + 自動生成 + + プレーヤーのキャプション文字スケールと背景スタイルを変更します。有効にするにはアプリの再起動が必要です + + 何もありません + 保存したエクスポートファイルからYoutubeの購読をインポート: +\n +\n1. このURLを開きます: %1$s +\n2. ログインしていなければログインします +\n3. ダウンロードが始まります (これがエクスポートファイルです) + リセット + + 同意する + 拒否 + + 制限なし + モバイルデータ使用時の解像度の制限 + アプリ切り替え時の最小化 + プレーヤーから他アプリに切り替え時の動作 — %s + 何もしない + バックグラウンドに変更 + ポップアップに変更 + + diff --git a/app/src/main/res/values-ko/strings.xml b/app/src/main/res/values-ko/strings.xml index d00ee12ea..34eb53c8a 100644 --- a/app/src/main/res/values-ko/strings.xml +++ b/app/src/main/res/values-ko/strings.xml @@ -28,7 +28,7 @@ 다음 비디오 다음 및 유사한 비디오 표시 지원하지 않는 URL 입니다 - 기본 컨텐츠 언어 + 기본 컨텐츠 언어 비디오 & 오디오 비디오 미리보기 썸네일 @@ -60,7 +60,7 @@ 다운로드 디렉토리를 만들었습니다 \'%1$s\' 검색 버튼을 눌러서 시작하세요 자동으로 재생 - NewPipe가 다른 앱으로부터 호출되었을 경우 비디오를 자동으로 재생합니다 + NewPipe가 다른 앱으로부터 호출되었을 때 동영상을 재생합니다 컨텐츠 나이 제한이 있는 컨텐츠를 표시 연령 제한 비디오입니다. 설정 메뉴에서 시청 허용 여부를 변경하실 수 있습니다. @@ -130,7 +130,7 @@ 검색 중에 제안을 표시합니다 검색 기록 검색 기록을 기기에 저장합니다 - 기록 + 기록 및 캐시 관리 시청했던 비디오 기록을 저장 초점 복원시 재생 재개 전화 통화 등으로 인해 재생이 중단된 이후에 다시 재생을 시작합니다 @@ -165,7 +165,7 @@ 이미지를 불러올 수 없습니다 앱/UI 충돌 - 이 스트림을 재생할 수 없습니다 + 이 스트림을 재생할 수 없습니다. 복구할 수 없는 플레이어 오류가 발생했습니다 플레이어 오류로부터 복구 중 @@ -234,7 +234,7 @@ 뉴파이프 기여자 라이센스 - 안드로이드를 위한 개방/자유/무료 유튜브 프론트엔드 입니다. + 가볍고 빠른 자유 안드로이드 스트리밍 앱입니다. 기여 번역, 디자인, 코딩 등 다양한 기여를 언제나 환영합니다. 향상에 참여해주세요! GitHub에서 보기 @@ -293,7 +293,7 @@ 정확하지는 않지만 빠른 탐색 정확하지 않은 탐색은 빠르게 위치로 탐색할 수 있지만 정확도는 떨어집니다 다음 스트림을 자동으로 재생열에 추가하기 - 전 스트림이 무한 반복 재생 큐가 아닐 때 관련된 스트림 자동 재생하기. + 이전 스트림이 무한 반복 재생 큐가 아닐 경우, 관련 스트림을 자동 재생합니다. 기본 콘텐츠 국가 서비스 디버그 @@ -309,7 +309,7 @@ 데이터베이스 가져오기 데이터베이스 내보내기 현재 시청 기록 및 구독 목록을 덮어쓰기 됩니다 - 시청 기록, 구독 목록, 재생목록 내보내기. + 시청 기록, 구독 목록과 재생목록을 내보냅니다. 외부 플레이어는 이러한 종류의 링크를 지원하지 않습니다 잘못된 URL 발견된 비디오 스트림 없음 @@ -359,7 +359,7 @@ 북마크 제거하기 이 재생목록을 삭제하시겠습니까? - 재생목록 생성 성공 + 재생목록 생성 완료 재생목록에 추가됨 재생목록 썸내일이 바뀜 재생목록 삭제 실패 @@ -379,9 +379,9 @@ 동기화 LeakCanary 할성화 - 메모리 누수 모니터링은 힙 덤핑시 앱이 불안정할 수 있습니다 + 힙 덤프 중 메모리 누수 점검으로 앱이 불안정해질 수 있습니다 - Out-of-Lifecycle 에러 보고 + Out-of-Lifecycle 오류 보고 프래그먼트 또는 버려진 액티비티 주기 밖에서 일어나는 전달할 수 없는 Rx 예외를 강제적으로 보고하기 파일 @@ -410,21 +410,21 @@ \n1. 이곳으로 가세요: $1$s \n2. 로그인이 필요하면 하세요 \n3. 다운로드가 곧 시작 됩니다 (이 파일이 내보내기 파일 입니다) - SoundCloud 팔로잉 목록을 가져오려면 당신의 프로필 URL 및 ID를 알아야 합니다. 알고 있다면 아래에 있는 빈칸에 입력해 주세요. + SoundCloud 프로필을 가져오시려면 URL 및 ID를 입력해주세요. +\n +\n프로필 URL을 찾으시려면 다음 과정을 따라해 주세요. \n -\n만약 모르신다면, 다음을 참고하세요: -\n -\n1. 모바일 환경이시면 브라우저 설정에서 데스크탑 모드를 활성화해주세요. Chrome 모바일에서는 오른쪽 … 클릭시 아래쪽에 있습니다. \n2. 이 주소로 가세요: %1$s -\n3. 로그인이 필요하면 하세요. +\n3. 로그인이 필요하면 하세요. \n4. 리디렉트된 곳의 URL을 복사하세요. (이 URL이 당신의 프로필 URL 입니다) 프로필ID, soundcloud.com/프로필ID - 경고: 데이터 소모량이 늘어날 수 있습니다. -\n -\n진행하시겠습니까? + 경고: 데이터 소모량이 늘어날 수 있습니다. +\n +\n계속하시겠습니까? 썸내일 로드하기 - 모든 썸내일의 로드와 데이터에 저장하기를 멈춥니다. 이것은 메모리와 이미지 캐시를 지울 것입니다. + 동영상 썸네일을 로드하지 않으며, 데이터와 메모리 사용을 최대한 줄입니다. 이 옵션을 +\n선택 시, 모든 메모리 캐시와 저장소 캐시를 삭제합니다. 이미지 캐시 지워짐 캐시된 메타데이터 지우기 캐시된 모든 웹페이지 데이터 지우기 @@ -432,12 +432,12 @@ 재생 속도 조절 템포 피치 - 후크 취소 (소리가 깨질수 있음) + 영상과 소리 분리 (소리가 깨질 수 있음) 나이트코어 기본 다운로드 가능한 스트림이 없습니다 - 이 파일을 위한 플레이어가 발견되지 않았습니다 + 이 파일을 재생할 수 있는 플레이어 앱이 없습니다. 선호하는 열기 동작 컨텐츠를 열 때 사용할 기본 동작 — %s @@ -445,4 +445,29 @@ 자막 플레이어 자막 텍스트 크기와 배경 스타일을 변경합니다. 효과를 적용하려면 앱을 재시작 해야합니다. + 채널만 + 재생 목록만 + 시청 기록 삭제하기 + 동영상 시청 기록을 삭제합니다. + \'삭제\' 버튼을 누르면 모든 시청 기록이 삭제됩니다. + 동영상 시청 기록이 삭제되었습니다. + 검색 기록 삭제 + 검색 기록을 모두 삭제합니다. + \'삭제\' 버튼을 누르면 모든 검색 기록이 삭제됩니다. + 검색 기록이 삭제되었습니다. + 뉴파이프 개인정보 보호 정책 + 뉴파이프 프로젝트는 사용자의 개인 정보 보호를 최우선으로 생각하며, 동의 없이 어떠한 정보도 수집하지 않습니다. +\n뉴파이프 개인정보 보호 정책에서는 오류 보고 시 어떠한 정보가 수집되고 저장되는지 자세히 명시되어 있습니다. + 개인정보 보호 정책 읽기 + 뉴파이프는 카피레프트 자유 소프트웨어입니다. 사용자는 이 앱을 사용, 공유, 또는 수정하는 것이 가능하고, 수정 후 재배포 시 자유 소프트웨어 재단의 GNU 라이센스 버전 +\n3 또는 그 이상의 버전을 포함해야 합니다. + 앱 설정을 가져오시겠습니까? + + 무음 구간 스킵 + 유럽 연합 일반 데이터 보호 규정 (GDPR) 에 따라, 사용자는 뉴파이프 개인정보 보호 정책을 읽고 꼼꼼히 확인해야 합니다. 버그 리포트를 보내시려면 개인정보 보호 정책에 동의해주세요. + 동의 + 동의하지 않음 + + 데이터 제한 없음 + 모바일 데이터 사용 시 화질 제한 diff --git a/app/src/main/res/values-lt/strings.xml b/app/src/main/res/values-lt/strings.xml index af2ff5a7a..4ffcd26d6 100644 --- a/app/src/main/res/values-lt/strings.xml +++ b/app/src/main/res/values-lt/strings.xml @@ -57,7 +57,7 @@ Kitas vaizdo įrašas Rodyti kitus panašius vaizdo įrašus URL nepalaikoma - Numatytoji tūrinio kalba + Numatytoji tūrinio kalba Vaizdas ir garsas Iššokantis langas Išvaizda diff --git a/app/src/main/res/values-mk/strings.xml b/app/src/main/res/values-mk/strings.xml index b6e79dbd4..812bd1534 100644 --- a/app/src/main/res/values-mk/strings.xml +++ b/app/src/main/res/values-mk/strings.xml @@ -93,7 +93,7 @@ Неподдржана URL врска Земја на прикажани видеа Услуга - Претпочитан јазик на видеата + Претпочитан јазик на видеата Плеер Однесување Видео и Звук diff --git a/app/src/main/res/values-nb-rNO/strings.xml b/app/src/main/res/values-nb-rNO/strings.xml index da4f099cd..4bb790b1b 100644 --- a/app/src/main/res/values-nb-rNO/strings.xml +++ b/app/src/main/res/values-nb-rNO/strings.xml @@ -40,7 +40,7 @@ Neste video Vis \"neste\" og \"lignende\" videoer Nettadressen støttes ikke - Foretrukket innholdsspråk + Foretrukket innholdsspråk Video og lyd Utseende Annet @@ -377,7 +377,7 @@ Mindre skrift Normal skrift Større skrift -Bruk raskt unøyaktig søk +Bruk raskt unøyaktig blafring Feilretting Fil @@ -434,7 +434,7 @@ Søkehistorikk slettet. Ett element slettet. - Inget program installert for avspilling av denne filen. + Inget program installert for avspilling av denne filen Undertekster Endre undertekststørrelse og bakgrunnsstiler. Krever omstart av programmet for å tre i effekt diff --git a/app/src/main/res/values-nl-rBE/strings.xml b/app/src/main/res/values-nl-rBE/strings.xml index 18b23120d..9f1d796fd 100644 --- a/app/src/main/res/values-nl-rBE/strings.xml +++ b/app/src/main/res/values-nl-rBE/strings.xml @@ -93,7 +93,7 @@ URL wordt niet ondersteund Standaardinhoudsland Dienst - Standaardtaal voor inhoud + Standaardtaal voor inhoud Speler Gedrag Video & audio diff --git a/app/src/main/res/values-nl/strings.xml b/app/src/main/res/values-nl/strings.xml index c4bb1e7d1..32a361205 100644 --- a/app/src/main/res/values-nl/strings.xml +++ b/app/src/main/res/values-nl/strings.xml @@ -5,38 +5,38 @@ Geen speler met streamondersteuning gevonden. Wil je VLC installeren? Installeren Annuleren - In browser openen + Openen in browser Delen Downloaden Zoeken Instellingen - Bedoelde je: %1$s ? + Bedoelde je: %1$s\? Delen met Kies een browser - rotatie + draaiing Downloadlocatie voor video\'s Locatie om gedownloade video\'s in op te slaan Voer downloadlocatie in voor video\'s Standaardresolutie Afspelen met Kodi Kore-app niet gevonden. Installeren? - Toon \"Afspelen met Kodi\"-optie - Toont een optie om een video op een Kodi media center af te spelen + \"Afspelen met Kodi\"-optie tonen + Toont een optie om een video af te spelen op een Kodi-mediastation Audio Standaardaudioformaat Downloaden Volgende video URL wordt niet ondersteund ‘volgende’ en ‘vergelijkbare’ video’s weergeven - Standaardtaal voor inhoud + Standaardtaal voor inhoud Externe videospeler gebruiken Externe audiospeler gebruiken - Video & audio + Audio en video Videovoorbeeldminiatuur Videovoorbeeldminiatuur - Avatarminiatuur van uploader - Duimpjes omlaag + Gebruikersafbeelding van uploader + Vind-ik-niet-leuks Downloadlocatie voor audio Locatie om gedownloade muziek in op te slaan Voer downloadlocatie voor audiobestanden in @@ -46,38 +46,38 @@ Licht Uiterlijk - Overige - Speelt af in achtergrond + Overig + Speelt af op achtergrond Afspelen Inhoud - Toon inhoud met leeftijdsbeperking - Video heeft leeftijdsbeperking. Leeftijdsbeperkte video\'s kunnen ingeschakeld worden in de instellingen. + Inhoud met leeftijdsbeperking tonen + De video heeft een leeftijdsbeperking. Toestaan van dit soort video\'s kan worden ingeschakeld in de instellingen. Fout Netwerkfout - Kon niet alle miniaturen laden - Kon video-URL-ondertekening niet ontsleutelen - Kon website niet verwerken + Kan niet alle miniatuurvoorbeelden laden + Kan video-URL-ondertekening niet ontsleutelen + Kan website niet verwerken Inhoud niet beschikbaar Geblokkeerd door GEMA - Kon downloadmenu niet instellen - Dit is een LIVESTREAM, deze worden nog niet ondersteund. + Kan downloadmenu niet instellen + Dit is een LIVESTREAM; deze worden nog niet ondersteund. - Duimpjes omhoog - Gebruik Tor + Vind-ik-leuks + Tor gebruiken (Experimenteel) Dwing downloadverkeer door Tor voor verhoogde privacy (streamen van video\'s wordt nog niet ondersteund). - Kan downloadmap \'%1$s\' niet aanmaken - Downloadmap \'%1$s\' aangemaakt - Kon de website niet volledig inlezen - Kon geen streams vinden - Sorry, dit zou niet mogen gebeuren. + Kan downloadmap \'%1$s\' niet creëren + Downloadmap \'%1$s\' gecreëerd + Kan website niet volledig verwerken + Kan geen streams vinden + Sorry, dit had niet mogen gebeuren. Fout melden via e-mail Sorry, er traden enkele fouten op. MELDEN - Info: - Wat is er gebeurd: + Informatie: + Wat er is gebeurd: Je opmerking (in het Engels): Details: @@ -85,7 +85,7 @@ Video Geluid Opnieuw proberen - Tik op zoeken om te beginnen + Druk op zoeken om te beginnen Automatisch afspelen Speelt video’s af als NewPipe vanuit een andere app wordt geopend live @@ -93,7 +93,7 @@ Downloads Foutrapport - Kon afbeelding niet laden + Kan afbeelding niet laden App/UI gecrasht Wat:\\nVerzoek:\\nTaal van inhoud:\\nDienst:\\nTijd in GMT:\\nPakket:\\nVersie:\\nVersie van besturingssysteem: Meld een probleem @@ -115,9 +115,9 @@ Fout Server wordt niet ondersteund Bestand bestaat al - Verkeerde URL of internet niet beschikbaar + Onjuiste URL of geen internetverbinding NewPipe is aan het downloaden - Tik voor meer informatie + Druk voor meer informatie Even geduld… Gekopieerd naar klembord Kies een beschikbare downloadmap @@ -140,21 +140,21 @@ M B - Deze toestemming is vereist om -te openen in pop-upmodus + Deze machtiging is vereist om te +\nopenen in pop-upmodus NewPipe-pop-upmodus Speelt af in pop-upmodus - Gebruik oude speler + Oude speler gebruiken Verouderde ingebouwde Mediaframework-speler - Standaardvideoformaat + Standaard videoformaat Uitgeschakeld - Standaardresolutie voor pop-up - Hogere resoluties weergeven - Video\'s afspelen in 2K/4K wordt maar op sommige apparaten ondersteund + Standaardresolutie van pop-up + Hogere resoluties tonen + 2K-/4K-video\'s worden slechts op sommige apparaten ondersteund Achtergrond Pop-up @@ -166,9 +166,9 @@ te openen in pop-upmodus Onthoud laatste grootte en positie van pop-up Pop-up - Bezig met schalen + Bezig met wijzigen van grootte - Sommige resoluties zullen geen geluid hebben als deze optie is ingeschakeld + Sommige resoluties hebben GEEN geluid hebben als deze optie is ingeschakeld Zoeksuggesties Toon suggesties bij zoeken @@ -179,9 +179,9 @@ te openen in pop-upmodus Over NewPipe Instellingen Over - Derdepartijlicenties + Licenties van derde partijen © %1$s door %2$s, uitgebracht onder de %3$s - Kon licentie niet laden + Kan licentie niet laden Website openen Over Bijdragers @@ -189,7 +189,7 @@ te openen in pop-upmodus Vrij en licht streamen voor Android. Bekijken op GitHub Licentie van NewPipe - Hulp is altijd welkom, of je nu nieuwe ideeën hebt, vertalingen kan bijdragen, wijzigingen in het ontwerp, opschonen van of grote wijzigingen in de code. Hoe meer hulp, hoe beter het wordt! + Hulp is altijd welkom. Of je nu nieuwe ideeën hebt, vertalingen kan aanleveren, wijzigingen in het ontwerp kan verrichten, code kan opschonen of van grote wijzigingen voorzien. Hoe meer hulp, hoe beter het wordt! Licentie lezen Bijdragen Download @@ -198,15 +198,15 @@ te openen in pop-upmodus Vervangend teken Letters en cijfers - Meeste speciale tekens + Speciaalste tekens - Abonneer + Abonneren Geabonneerd - Abonnement opgezegd - Kan het abonnement niet veranderen - Kan het abonnement niet vernieuwen + Gedeabonneerd + Kan abonnement niet wijzigen + Kan abonnement niet bijwerken - Start + Startpagina Abonnementen Nieuw @@ -224,7 +224,7 @@ te openen in pop-upmodus Geschiedenis Gezocht - Gekeken + Bekeken Geschiedenis is uitgeschakeld Geschiedenis De geschiedenis is leeg @@ -232,12 +232,12 @@ te openen in pop-upmodus Speler Gedrag - Geschiedenis & Cache + Geschiedenis en cache Afspeellijst Ongedaan maken Geen resultaten - Niets te zien + Niets, maar dan ook niets te zien Geen abonnees @@ -258,29 +258,29 @@ te openen in pop-upmodus Item verwijderd -Wil je dit item uit je zoekgeschiedenis verwijderen? -Tip weergeven voor ingedrukt houden om toe te voegen - Toon tip wanneer achtergrond- of pop-upknop is ingedrukt op de video-detailpagina +Wil je dit item verwijderen uit je zoekgeschiedenis? +Tip tonen voor ingedrukt houden om toe te voegen + Toon tip als achtergrond- of pop-upknop wordt ingedrukt op de videogegevenspagina Toegevoegd aan wachtrij voor achtergrondspeler Toegevoegd aan wachtrij voor pop-upspeler Alles afspelen Deze stream kan niet worden afgespeeld Onherstelbare spelerfout opgetreden - Aan het herstellen van spelerfout + Bezig met herstellen na spelerfout - Content van hoofdpagina - Blanke Pagina + Inhoud van hoofdpagina + Blanco pagina Kioskpagina Abonnementenpagina Feedpagina Kanaalpagina - Selecteer een kanaal + Kies een kanaal Nog niet geabonneerd op een kanaal - Selecteer een kiosk + Kies een kiosk Kiosk - Trending + Populair Top 50 Nieuw en populair Achtergrondspeler @@ -293,28 +293,28 @@ te openen in pop-upmodus Toevoegen aan wachtrij in achtergrond Toevoegen aan wachtrij in pop-up - Hier beginnen spelen - Hier beginnen in achtergrond - Hier beginnen in pop-up + Begin hier met afspelen + Begin hier met afspelen op achtergrond + Begin hier met afspelen in pop-up Doneren NewPipe wordt door vrijwilligers in hun vrije tijd ontwikkeld om jou de beste ervaring te brengen. Geef wat terug zodat onze ontwikkelaars NewPipe nóg beter kunnen maken terwijl ze van hun kopje koffie genieten. Teruggeven Website Bezoek de website van NewPipe voor meer informatie en het laatste nieuws. - Standaardinhoudsland + Standaard inhoudsland Dienst Oriëntatie wijzigen Verplaatsen naar achtergrond Verplaatsen naar pop-up - Verplaatsen naar normaal + Verplaatsen naar hoofdvenster Menu openen Menu sluiten - Geen speler met streamondersteuning gevonden (je kan VLC installeren om het af te spelen) + Geen speler met streamondersteuning gevonden (je kan VLC installeren om af te spelen) Altijd Eenmalig - Externe spelers ondersteunen deze soorten koppelingen niet + Externe spelers ondersteunen dit soort links niet Ongeldige URL Geen videostreams gevonden Geen audiostreams gevonden @@ -324,20 +324,20 @@ te openen in pop-upmodus Pop-upspeler Altijd vragen - Info ophalen… + Bezig met ophalen van informatie… Bezig met laden van gevraagde inhoud -Database importeren - Database exporteren - Dit zal je huidige geschiedenis en abonnementen overschrijven - Exporteer geschiedenis, abonnementen en speellijsten - Export voltooid - Import voltooid +Databank importeren + Databank exporteren + Dit overschrijft je huidige geschiedenis en abonnementen + Exporteer geschiedenis, abonnementen en afspeellijsten + Exporteren voltooid + Importeren voltooid Geen geldig ZIP-bestand - Opgelet: kon niet alle bestanden importeren. - Dit zal je huidige configuratie overschrijven. + Let op: niet alle bestanden konden worden geïmporteerd. + Dit overschrijft je huidige configuratie. Streambestand downloaden. - Info tonen + Informatie tonen Bladwijzers @@ -345,22 +345,22 @@ te openen in pop-upmodus Versleep om de volgorde te wijzigen - Aanmaken - Één verwijderen + Creëren + Eén verwijderen Alles verwijderen Sluiten - Hernoemen + Naam wijzigen - Wil je dit item uit je kijkgeschiedenis verwijderen? - Wil je alle items uit je geschiedenis verwijderen? + Wil je dit item verwijderen uit je kijkgeschiedenis? + Wil je alle items verwijderen uit je geschiedenis? Laatst afgespeeld Meest afgespeeld Altijd vragen - Nieuwe afspeellijst aanmaken + Nieuwe afspeellijst creëren Afspeellijst verwijderen - Afspeellijst hernoemen + Afspeellijstnaam wijzigen Naam Toevoegen aan afspeellijst Instellen als miniatuur voor afspeellijst @@ -376,7 +376,7 @@ te openen in pop-upmodus Geen bijschriften - Passen + Inpassen Opvullen Inzoomen @@ -404,8 +404,8 @@ te openen in pop-upmodus Ongeldige map Ongeldig bestand/Ongeldige inhoudsbron - Het bestand bestaat niet of u beschikt niet over voldoende machtiging om het te lezen/er naar te schrijven - De bestandsnaam mag niet leeg zijn + Het bestand bestaat niet of je bent onvoldoende gemachtigd om het te lezen/er naar te schrijven + De bestandsnaam mag niet blanco zijn Er is een fout opgetreden: %1$s Importeren/Exporteren @@ -435,7 +435,7 @@ te openen in pop-upmodus \n4. Kopieer de koppeling van de pagina waar je op terechtkomt (dat is je profiel-URL). jouwID, soundcloud.com/jouwid - Let op: deze actie kan veel MB’s van je netwerk gebruiken. + Let op: deze actie kan veel MB’s van je mobiele netwerk gebruiken. \n \nWil je doorgaan? Miniatuurvoorbeelden laden @@ -456,7 +456,7 @@ te openen in pop-upmodus Geen streams beschikbaar voor downloaden Bijschriften - Bijschriftgrootte en achtergrondstijlen wijzigen. Vereist een herstart van de app + Bijschriftgrootte en -achtergrondstijlen wijzigen. Vereist een herstart van de app Er is geen app geïnstalleerd die dit bestand kan afspelen @@ -464,22 +464,22 @@ te openen in pop-upmodus Verwijdert de geschiedenis van afgespeelde streams Verwijdert de gehele kijkgeschiedenis. - Kijkgeschiedenis verwijderd. + Kijkgeschiedenis gewist. Zoekgeschiedenis wissen Verwijdert de gebruikte zoektermen Verwijdert de gehele geschiedenis. - Zoekgeschiedenis verwijderd. + Zoekgeschiedenis gewist. 1 item verwijderd. NewPipe is vrije software: je kan het gebruiken, bestuderen, delen en verbeteren zoveel je maar wil. Je kan het opnieuw uitgeven en/of aanpassen volgens de voorwaarden van de GNU General Public License, gepubliceerd door de Free Software Foundation, versie 3 van de licentie, of (indien gewenst) om het even welke latere versie. Wil je ook de instellingen importeren? NewPipe\'s privacybeleid - Het NewPipe-project neemt privacy serieus. Daarom verzamelt de app geen gegevens zonder jouw toestemming. -\nNewPipe\'s privacybeleid legt gedetailleerd uit welke gegevens verstuurd en opgeslagen worden als je een crashrapport verstuurd. + Het NewPipe-project neemt privacy serieus. Daarom verzamelt de app geen gegevens zonder jouw toestemming. +\nNewPipe\'s privacybeleid legt gedetailleerd uit welke gegevens verstuurd en opgeslagen worden als je een crashrapport verstuurt. Privacybeleid lezen - Om de Europese Algemene Verordening Gegevensbescherming (ook wel: AVG of GDPR) na te leven, wijzen we je op het nieuwe privacybeleid van NewPipe. Lees dit zorgvuldig. -\nJe moet het beleid accepteren om ons het bugrapport te kunnen sturen. + Om de Europese Algemene Verordening Gegevensbescherming (ook wel: AVG of GDPR) na te leven, wijzen we je op het nieuwe privacybeleid van NewPipe. Lees dit zorgvuldig. +\nJe moet het beleid accepteren om ons het foutrapport te kunnen sturen. Accepteren Weigeren Ongelimiteerd diff --git a/app/src/main/res/values-pa/strings.xml b/app/src/main/res/values-pa/strings.xml index 560284f6a..c307caead 100644 --- a/app/src/main/res/values-pa/strings.xml +++ b/app/src/main/res/values-pa/strings.xml @@ -13,9 +13,19 @@ ਡਾਊਨਲੋਡ ਸਟਰੀਮ ਫਾਈਲ. ਖੋਜੋ ਸੇਟਿੰਗਾਂ - ਕੀ ਤੁਹਾਡਾ ਮਤਲਬ: %1$s ? + ਕੀ ਤੁਹਾਡਾ ਮਤਲਬ: %1$s\? ਭੇਜੋ Browser ਚੁਣੋ ਉਲਟਾਨਾ - ਹੋਰ ਪਲੇਅਰ ਵਰਤਣਾ + ਹੋਰ ਪਲੇਅਰ ਵਰਤਤੋ + ਕੁਝ ਵੀਡੀਓ ਰੈਸੋਲੂਸ਼ਨ ਚੁਣਨ ਨਾਲ ਆਡੀਓ ਮੌਜੂਦ ਨਹੀਂ ਹੋਵੇਗੀ + ਬਾਹਰੀ ਆਡੀਓ ਪਲੇਅਰ ਦੀ ਵਰਤੋਂ ਕਰੋ + NewPipe ਪੋਪਉਪ ਮੋਡ + ਸਅਬਸਕਰਾਇਬ + ਮੈਂਬਰ ਬਣਏ + ਚੈਨਲ ਸਦੱਸਤਾ ਰੱਦ ਕੀਤੀ ਗਈ + ਸਦੱਸਤਾ ਨੂੰ ਬਦਲਣ ਵਿਚ ਅਸਮਰੱਥ ਹੈ + ਜਾਣਕਾਰੀ + + ਮੁੱਖ diff --git a/app/src/main/res/values-pl/strings.xml b/app/src/main/res/values-pl/strings.xml index fa885e51b..d25acce8d 100644 --- a/app/src/main/res/values-pl/strings.xml +++ b/app/src/main/res/values-pl/strings.xml @@ -43,7 +43,7 @@ Następny film Pokaż \'następne\' i \'podobne\' filmy URL nieobsługiwany - Domyślny język zawartości + Domyślny język zawartości Wideo i audio Wygląd Inne @@ -144,7 +144,7 @@ Kanał Tak Później - Wyłączone + Wyłączony Filtr Odśwież Wyczyść @@ -481,4 +481,18 @@ Brak limitu Limit przy użyciu danych mobilnych - + Kanały + Playlisty + Utwory + Użytkownicy + Przewiń w przód podczas ciszy + Krok + Zresetuj + + Zminimalizuj podczas przełączenia aplikacji + "Akcja podczas przełączenia do innej aplikacji z głównego odtwarzacza — %s" + Zminimalizuj + Zminimalizuj do odtwarzania w tle + Zminimalizuj do odtwarzania w okienku + + diff --git a/app/src/main/res/values-pt-rBR/strings.xml b/app/src/main/res/values-pt-rBR/strings.xml index 4e08f4ee5..82a54c90c 100644 --- a/app/src/main/res/values-pt-rBR/strings.xml +++ b/app/src/main/res/values-pt-rBR/strings.xml @@ -57,7 +57,7 @@ Reportar um erro Tentar novamente Rotação - Idioma de conteúdo preferido + Idioma de conteúdo preferido Configurações Aparência Outros @@ -254,7 +254,7 @@ abrir em modo popup Em Alta Top 50 Novos e tendências -"Mostrar dica \"mantenha pressionado\" para enfileirar" +"Mostrar dica \"mantenha pressionado para enfileirar\"" Mostrar dica quando o botão de plano de fundo ou de popup for pressionado na página de detalhes do vídeo Adicionado a fila do reprodutor em plano de fundo Adicionado a fila no reprodutor popup @@ -291,7 +291,7 @@ abrir em modo popup Alterar a orientação Alterar para Plano de Fundo Alterar para Popup - Aletar para principal + Alterar para o Principal Reprodutores externos não suportam estes tipos de links URL inválida diff --git a/app/src/main/res/values-pt/strings.xml b/app/src/main/res/values-pt/strings.xml index d8ca1a265..b27715fa3 100644 --- a/app/src/main/res/values-pt/strings.xml +++ b/app/src/main/res/values-pt/strings.xml @@ -30,7 +30,7 @@ Vídeo seguinte Mostrar vídeos \'seguintes\' e \'semelhantes\' URL não suportado - Idioma padrão do conteúdo + Idioma padrão do conteúdo Vídeo e áudio Miniatura de vídeos @@ -184,7 +184,7 @@ Sobre Colaboradores Licenças - Aplicação leve, simples e grátis de YouTube para Android. + Aplicação leve livre de YouTube para Android. Ver no GitHub Licença do NewPipe Se tem ideias de tradução, alterações de design, limpeza de código ou alterações de código pesado—ajuda é sempre bem-vinda. Quanto mais se faz melhor fica! @@ -293,7 +293,7 @@ Importar base de dados Exportar base de dados Irá sobrepor o seu histórico atual e subscrições - Exportar histórico, subscrições e listas de reprodução. + Exportar histórico, subscrições e listas de reprodução Em lista de espera no reprodutor em segundo plano Em lista de espera no reprodutor popup Mudar para segundo plano @@ -318,7 +318,7 @@ Utilizar pesquisa rápida A pesquisa rápida permite que a pesquisa seja mais rápida mas diminui a qualidade da precisão Carregar miniaturas - Desative para parar o carregamento das miniaturas e poupar dados e memória. Se alterar esta opção limpa a cache de memória e do disco. + Desative para parar o carregamento das miniaturas e poupar dados e memória. Se alterar esta opção limpa a cache de memória e do disco Cache de imagens limpa País padrão para o conteúdo Depuração @@ -333,7 +333,7 @@ Descartar Site - Para obter mais informações e saber as novidades do NewPipe, aceda ao nosso site. + Visite ao website NewPipe para obter mais informações e saber as novidades. Página \"kiosk\" Página da fonte Exportação terminada @@ -364,7 +364,7 @@ Perguntar sempre A obter informação… - O conteúdo requisitado está a carregar + O conteúdo requisitado está carregando Criar Nova Lista de Reprodução Apagar Lista de Reprodução @@ -379,7 +379,7 @@ Thumbnail da Lista de Reprodução modificada Sem Legenda - ZOOM + Zoom Gerado automaticamente @@ -398,24 +398,47 @@ Importação de subscrições falhou Exportação de subscrições falhou - Para importar as tuas subscrições do Google vais precisar do ficheiro de exportação, que pode ser descarregado com auxílio destas instruções: -\n -\n1. Vai a esta hiperligação: %1$s -\n2. Inicia a tua sessão quando requisitado -\n3. O descarregamento deve começar (esse é o ficheiro de exportação) - Para importar as contas que segue no SoundCloud, terá que saber o link ou id do seu perfil. Se souber, basta escrever um deles no campo abaixo e estará tudo pronto. + Para importar as tuas subscrições do Youtube vais precisar do ficheiro de exportação, que pode ser descarregado com auxílio destas instruções: \n -\nSe não souber, pode seguir estas etapas: +\n1. Vai a esta hiperligação: %1$s +\n2. Inicia a tua sessão quando requisitado +\n3. O descarregamento deve começar (esse é o ficheiro de exportação) + Para importar as contas SoundCloud, vais precisar do link ou id do seu perfil que pode ser descarregado com auxílio destas instruções: \n \n1. Ative \"modo desktop\" num navegador da internet (o site não está disponível para dispositivos móveis) \n2. Vá a este url: %1$s \n3. Inicie sessão na sua conta quando solicitado -\n4. Copie o link para o qual foi redirecionado (este é o link do seu perfil) - seuid, soundcloud.com/seuid +\n4. Copie o link para o qual foi redirecionado. + seuID, soundcloud.com/seuID Controlo de velocidade de reprodução Tempo Nightcore Predefinido Limpar histórico de exibição + Auto anexar um fluxo relacionado quando jogar o último fluxo em uma fila não repetitiva + Mostrar dica \"mantenha pressionado para enfileirar\" + Mostrar dica quando o botão de plano de fundo ou de popup for pressionado na página de detalhes do vídeo + Canais + Listas de reprodução + Faixas + Utilizadores + Deleta o histórico de videos já reproduzidos + Deleta o histórico de videos já reproduzidos. + Histórico de já assistidos deletado. + Deleta histórico de pesquisa + Deleta histórico de palavras chave pesquisadas + Deleta histórico de pesquisa completo. + Histórico de pesquisa deletado. + 1 elemento deletado. + + Nehum aplicativo instalada para reproduzir este arquivo + + NewPipe é desenvolvido por voluntários que usam seu tempo para trazer a melhor experiência para você. Retribua para ajudar os desenvolvedores a tornarem o NewPipe ainda melhor enquanto desfrutam uma xícara de café. + Retribuir + Política de privacidade do NewPipe + O projeto NewPipe leva a sua privacidade muito a sério. Sendo assim, o aplicativo não coleta nenhum dado sem seu consentimento. +\nA polícia de privacidade do NewPipe explica em detalhes qual dado é enviado e salvo quando você envia um relatório de erros. + Ler a política de privacidade + Próximo stream automaticamente em lista de espera diff --git a/app/src/main/res/values-ro/strings.xml b/app/src/main/res/values-ro/strings.xml index a45b48199..cf7b5510a 100644 --- a/app/src/main/res/values-ro/strings.xml +++ b/app/src/main/res/values-ro/strings.xml @@ -41,7 +41,7 @@ Următorul videoclip Arată videoclipurile care urmează URL nesuportat - Limba dorită a conținutului + Limba dorită a conținutului Video & Audio Aspect Altele diff --git a/app/src/main/res/values-ru/strings.xml b/app/src/main/res/values-ru/strings.xml index 12de382ea..3fad6b288 100644 --- a/app/src/main/res/values-ru/strings.xml +++ b/app/src/main/res/values-ru/strings.xml @@ -30,7 +30,7 @@ Следующее видео URL не поддерживается \"Следующее\" и \"Похожие\" видео - Язык контента по умолчанию + Язык контента по умолчанию Видео и аудио Внешний вид Другое @@ -470,7 +470,7 @@ Удалить историю запросов поиска Удалить историю воспроизведённых потоков Вся история поиска будет удалена. - История поиска удалена + История поиска удалена. 1 элемент удалён. NewPipe — свободное программное обеспечение: вы можете использовать, изучать и улучшать его по своему усмотрению. В частности, вы можете распространять и/или изменять его в соответствии с условиями GNU General Public License, опубликованной Free Software Foundation, либо версии 3, либо (по вашему выбору) любой более поздней версии. @@ -490,6 +490,7 @@ Предел разрешения в мобильной сети Каналы Плейлисты + Видео Дорожки Пользователи Проматывать тишину @@ -502,4 +503,26 @@ Фоновый плеер Плеер в окне + Вид списка + Список + Сетка + Автоматически + + Менять яркость плеера жестом + Жест яркости + Загрузка на внешний накопитель невозможна. Сбросить расположение папки загрузки? + Внешний накопитель недоступен + Вкладки, видимые на главной странице + По умолчанию + Хотите восстановить умолчания? + Ошибка чтения сохранённых вкладок. Используются вкладки по умолчанию + Выбор + Количество подписчиков недоступно + Переключить вид + Выберите вкладку + Новая вкладка + Отписаться + Менять громкость плеера жестом + Жест громкости + diff --git a/app/src/main/res/values-sk/strings.xml b/app/src/main/res/values-sk/strings.xml index 0fefdd04e..a7359b0d7 100644 --- a/app/src/main/res/values-sk/strings.xml +++ b/app/src/main/res/values-sk/strings.xml @@ -29,7 +29,7 @@ Prehrať cez Kodi Aplikácia Kore nie je nainštalovaná. Chcete ju nainštalovať? Zobraziť možnosť \"Prehrať cez Kodi\" - Zobrazovať možnosť prehrať video cez mediálne centrum Kodi + Zobrazovať možnosť prehrať video cez multimediálne centrum Kodi Zvuk Predvolený zvukový formát Téma @@ -40,7 +40,7 @@ Ďalšie video Ukázať \'ďalšie\' a \'podobné\' videá URL nie je podporovaná - Preferovaný jazyk obsahu + Preferovaný jazyk obsahu Video & Zvuk Vzhľad Iné @@ -309,10 +309,10 @@ Premenovať Prispieť - Aplikácia NewPipe je vyvíjaná dobrovoľníkmi vo voľnom čase. Ak sa vám aplikácia páči a chceli by ste odmeniť vývojárov, teraz je ten najlepši čas. Podporte vývojárov aby mohli NewPipe zlepšovať a zároveň si pochutnávať na šálke kávy! + Aplikácia NewPipe je vyvíjaná dobrovoľníkmi vo voľnom čase. Ak sa vám aplikácia páči, odmeňte vývojárov aby mohli NewPipe naďalej vylepšovať. Určite ich poteší napríklad šálka dobrej kávy. Daruj Webstránka - Ak chcete získať ďalšie informácie a novinky o NewPipe navštívte naše webové stránky. + "Pre viac informácií a noviniek navštívte webstránku NewPipe." Chcete odstrániť túto položku z histórie vyhľadávania? Chcete odstrániť túto položku z histórie pozretých videí? Ste si istý, že chcete vymazať všetky položky z histórie? @@ -377,7 +377,7 @@ Miniatúra zoznamu skladieb bola zmenená Nemožno odstrániť zoznam skladieb - Bez popisu + Bez titulkov Prispôsobiť Vyplniť @@ -417,14 +417,14 @@ Automaticky vygenerované - Nastavenie titulkov + Titulky Upravte mierku textu titulkov a štýly pozadia. Vyžaduje reštart prehrávača Povoliť službu LeakCanary Monitorovanie pretečenia pamäte môže spôsobiť, že aplikácia nebude reagovať Nahlásiť mimo-cyklické chyby - Vynútenie hlásenia nedodržateľných výnimiek Rx, ktoré sa vyskytnú mimo časového cyklu fragmentu alebo aktivity po zlikvidovaní + Vynútiť hlásenie výnimiek nedoručiteľných Rx mimo časového cyklu fragmentov alebo aktivity po zneškodnení Import/Export \n @@ -449,16 +449,13 @@ \n2. Po výzve sa prihláste do svojho účtu \n3. Sťahovanie by malo začať (to je exportovaný zoznam) \n - "Importovať SoundCloud profil zadaním URL adresy alebo vášho ID: -\n -\nAk nepoznáte ani URL ani ID vašeho profilu, môžete postupovať nasledovne: -\n -\n1. V niektorom prehliadači povoľte režim \"desktop\" (web nie je dostupný pre mobilné zariadenia) -\n2. Prejdite na túto adresu URL: %1$s + "Importovať SoundCloud profil zadaním URL adresy alebo vášho ID: +\n +\n1. Prepnite režim na \"desktop\" (web nie je dostupný pre mobilné zariadenia) +\n2. Prejdite na túto URL adresu: %1$s \n3. Po výzve sa prihláste do svojho účtu -\n4. Skopírujte adresu URL, na ktorú ste boli presmerovaní (to je adresa vášho profilu). -\n" - ID,soundcloud.com/ID +\n4. Skopírujte adresu URL, na ktorú ste boli presmerovaní. " + vašeID, soundcloud.com/vašeid Operácia môže byť náročná na počet prenesených dát. \n @@ -467,7 +464,7 @@ Ovládanie rýchlosti prehrávania Rýchlosť Výška - "Zvoľnenie (môže spôsobovať skreslenie)" + "Spomalenie (môže spôsobovať skreslenie)" Nightcore režim Predvolené Vymazať históriu pozretí @@ -493,4 +490,18 @@ Bez limitu Limitovať rozlíšenie pri použití mobilných dát - + Kanály + Zoznamy skladieb + Skladby + Používatelia + Pretáčať tiché pasáže + Krok + Vynulovať + + Minimalizovať pri prepnutí aplikácie + Akcia pri prepnutí na inú aplikáciu z hlavného prehrávača videa — %s + Nič + Prehrávať na pozadí + Prehrávať v okne + + diff --git a/app/src/main/res/values-sl/strings.xml b/app/src/main/res/values-sl/strings.xml index d2d6d4343..ec2a0bea5 100644 --- a/app/src/main/res/values-sl/strings.xml +++ b/app/src/main/res/values-sl/strings.xml @@ -29,7 +29,7 @@ Naslednji video Pokaži naslednji video in podobne posnetke Zapis naslova URL ni podprt. - Privzeti jezik vsebine + Privzeti jezik vsebine Video in Zvok Sličica predogleda videa Sličica predogleda videa @@ -91,7 +91,7 @@ Opomba (v angleščini): Dovoljenje za dostop do shrambe je zavrnjeno Samodejno predvajanje - Samodejno predvaja vsebino, če je NewPipe klican iz drugega programa + Predvaja vsebino, če je program zagnan iz drugega programa Pošlji poročilo o napaki Poročilo uporabnika @@ -320,4 +320,5 @@ odpiranje v pojavnem načinu Opusti Preimenuj + Naloži sličice diff --git a/app/src/main/res/values-sq/strings.xml b/app/src/main/res/values-sq/strings.xml index 86d15b020..ec31c4a97 100644 --- a/app/src/main/res/values-sq/strings.xml +++ b/app/src/main/res/values-sq/strings.xml @@ -30,7 +30,7 @@ Shkarko Videoja tjetër Shërbimi - Gjuha e dëshiruar e përmbajtjeve + Gjuha e dëshiruar e përmbajtjeve Aplikacioni për video Sjellja Video & Audio diff --git a/app/src/main/res/values-sr/strings.xml b/app/src/main/res/values-sr/strings.xml index 60f99e254..fa3011936 100644 --- a/app/src/main/res/values-sr/strings.xml +++ b/app/src/main/res/values-sr/strings.xml @@ -28,7 +28,7 @@ Следећи видео УРЛ није подржан Прикажи следећи и слични видео - Подразумевани језик садржаја + Подразумевани језик садржаја Видео и аудио Остало Сличица видео прегледа diff --git a/app/src/main/res/values-sv/strings.xml b/app/src/main/res/values-sv/strings.xml index ed426cc13..ddf3888f5 100644 --- a/app/src/main/res/values-sv/strings.xml +++ b/app/src/main/res/values-sv/strings.xml @@ -10,10 +10,10 @@ Ladda ner Sök Inställningar - Menade du: %1$s ? + Menade du: %1$s\? Dela med Välj webbläsare - rotering + rotation Använd extern videospelare Några upplösningar kommer INTE ha ljud när det här alternativet är aktiverat Använd extern ljudspelare @@ -57,7 +57,7 @@ Nästa video Visa \'nästkommande\' och \'liknande\' videor Webbadressen stöds inte - Standard innehållsspråk + Standard innehållsspråk Video & Ljud Popup-ruta Utseende @@ -109,7 +109,7 @@ %1$s visningar Prenumerera Prenumererad - Prenumerationen togs bort + Prenumeration avslutad Kunde inte ändra prenumeration Kunde inte uppdatera prenumeration @@ -286,10 +286,10 @@ Bokmärken - Lägga till + Lägg till Använda snabb inexakt sökning - Ladda miniatyrer + Ladda miniatyrbilder Inaktivera för att stoppa alla miniatyrbilder från att ladda och spara på data och minnesanvändning. Ändring av detta kommer att rensa cache-minnet Bild cacheminnet var rensad Tjänst @@ -396,7 +396,7 @@ Vill du ta bort den här spellistan? Spellistan skapades Tillagad i spellistan - "Spellistans miniatyrbild förändrades " + Spellistans miniatyrbild förändrades Kunde inte ta bort spellistan Ingen textning @@ -449,7 +449,7 @@ Uppspelningshastighet Kontroller Tempo - Pitch + Tonhöjd Avlänka (kan orsaka förvrängning) Snabbspola vid frånvaro av ljud Steg diff --git a/app/src/main/res/values-te/strings.xml b/app/src/main/res/values-te/strings.xml index dc14446e7..b566977d5 100644 --- a/app/src/main/res/values-te/strings.xml +++ b/app/src/main/res/values-te/strings.xml @@ -53,7 +53,7 @@ తదుపరి వీడియో మరియు ఇలాంటి వీడియో చిట్కాను అనుబంధించడానికి హోల్డ్ను చూపు Url మద్దతు లేదు - డిఫాల్ట్ భాష + డిఫాల్ట్ భాష ప్లేయర్ ప్రవర్తన వీడియో & ఆడియో diff --git a/app/src/main/res/values-tr/strings.xml b/app/src/main/res/values-tr/strings.xml index e7715d545..bffad3ed8 100644 --- a/app/src/main/res/values-tr/strings.xml +++ b/app/src/main/res/values-tr/strings.xml @@ -11,7 +11,7 @@ İndir Ara Ayarlar - Bunu mu demek istediniz: %1$s ? + Bunu mu demek istediniz: %1$s\? Şununla paylaş Tarayıcı seç döndürme @@ -42,7 +42,7 @@ Sonraki video \'Sonraki\' ve \'benzer\' videoları göster URL desteklenmiyor - Öntanımlı içerik dili + Öntanımlı içerik dili Ses Video ve Ses Görünüm @@ -65,7 +65,7 @@ Web sitesi tümüyle ayrıştırılamadı İçerik kullanılabilir değil GEMA tarafından engellendi - Bu, henüz desteklenmeyen, bir CANLI AKIŞ. + Bu, henüz desteklenmeyen bir CANLI AKIŞ. Herhangi bir akış alınamadı Resim yüklenemedi Uygulama/arayüz çöktü @@ -254,7 +254,7 @@ Geçmiş temizlendi Öge silindi Bu içeriği arama geçmişinden silmek istiyor musunuz? -\"Kuyruğa almak İçin bas\" ipucunu göster +\"Kuyruğa almak için basılı tut\" ipucunu göster Video ayrıntıları sayfasında arka plan veya açılır oynatıcı düğmesine basıldığında ipucu göster Arka plan oynatıcıda kuyruğa eklendi Açılır oynatıcıda kuyruğa eklendi @@ -272,7 +272,7 @@ Abonelik Sayfası Besleme Sayfası Kanal Sayfası - Bir kanal seç + Kanal seç Henüz abone olunan kanal yok Köşk seç @@ -285,7 +285,7 @@ Kaldır Ayrıntılar Ses Ayarları - Kuyruğa Almak İçin Bas + Kuyruğa Almak İçin Basılı Tut Arka Planda Kuyruğa Al Açılır Oynatıcıda Kuyruğa Al Burada Oynatmaya Başla @@ -334,9 +334,9 @@ Akış dosyasını indir. Bilgileri göster - Yer imleri + Yer İmleri - Şuna Ekle + Listeye Ekle Yeniden sıralamak için sürükle @@ -380,7 +380,7 @@ Normal yazı tipi Daha büyük yazı tipi Hata Ayıklama - Yakında burada bir şeyler görünecek ;D + Yakında burada bir şeyler görünecek :) Kendiliğinden Üretilmiş @@ -435,7 +435,7 @@ \n \nDevam etmek istiyor musunuz? Küçük resimleri yükle - Küçük resimlerin hepsinin yüklenmesini engellemek ve bellek ve veri kullanımını azaltmak için devre dışı bırakın. Bunu değiştirmek, hem bellekteki hem de diskteki resim önbelleğini temizler + Küçük resimlerin tümünün yüklenmesini engellemek, bellek ve veri kullanımını azaltmak için devre dışı bırakın. Bunu değiştirmek, hem bellekteki hem de diskteki resim önbelleğini temizler Resim önbelleği temizlendi Önbelleklenmiş üst veriyi temizle Önbelleklenmiş tüm web sayfası verisini kaldır diff --git a/app/src/main/res/values-uk/strings.xml b/app/src/main/res/values-uk/strings.xml index 084c85920..1dccd25cf 100644 --- a/app/src/main/res/values-uk/strings.xml +++ b/app/src/main/res/values-uk/strings.xml @@ -10,7 +10,7 @@ Завантажити Шукати Налаштування - Чи ви мали на увазі: %1$s ? + Чи ви мали на увазі: %1$s\? Поділитись з Оберіть переглядач обертання @@ -44,7 +44,7 @@ Наступний відеозапис Являти \"наступні\" й \"схожі\" відео URL не підтримується - Переважна мова контенту + Переважна мова контенту Відео та Авдіо Зовнішній вигляд Інше @@ -483,8 +483,12 @@ До тлового програвача Зменшити до віконного програвачу -Канали + Канали Плейлисти Стежки Користувачі - + + Вигляд списку + Список + Сiтка + diff --git a/app/src/main/res/values-vi/strings.xml b/app/src/main/res/values-vi/strings.xml index a55f01085..b5203fbc0 100644 --- a/app/src/main/res/values-vi/strings.xml +++ b/app/src/main/res/values-vi/strings.xml @@ -28,14 +28,14 @@ Đường dẫn để lưu trữ âm thanh đã tải xuống Nhập đường dẫn tải xuống cho tệp âm thanh - Tự động phát khi được gọi từ một ứng dụng khác - Tự động phát một video khi NewPipe được gọi từ một ứng dụng khác + Tự động phát + Phát video khi NewPipe được gọi từ một ứng dụng khác Độ phân giải mặc định Độ phân giải popup mặc định Hiển thị độ phân giải cao hơn Chỉ một số thiết bị hỗ trợ chơi các video 2K / 4K Phát với Kodi - Ứng dụng Kore không tìm thấy. Cài đặt Kore? + Không tìm thấy ứng dụng Kore. Cài đặt nó? Hiển thị tùy chọn \"Phát với Kodi\" Hiển thị tùy chọn để phát video qua trung tâm media Kodi Âm thanh @@ -47,7 +47,7 @@ Tối Đen Nhớ kích thước và vị trí bật lên - Nhớ kích thước và vị trí cuối cùng được đặt vào cửa sổ bật lên + Nhớ kích thước và vị trí bật lên cuối cùng Điều khiển cử chỉ trình phát Sử dụng cử chỉ để kiểm soát độ sáng và âm lượng của trình phát Đề xuất tìm kiếm @@ -56,7 +56,7 @@ Tải về Video tiếp theo - Hiển thị các video tiếp theo và tương tự + Hiển thị video \'tiếp theo\' và \'tương tự\' URL không được hỗ trợ Hiển thị Khác @@ -65,7 +65,7 @@ Phát Nội dung Hiển thị nội dung bị hạn chế độ tuổi - Video bị giới hạn về tuổi. Bật chế độ cho phép hiển thị video bị hạn chế về độ tuổi ở trong cài đặt trước. + Video giới hạn độ tuổi người xem. Cho phép các tài liệu đó có thể từ Cài đặt. Trực tiếp Tải xuống Tải xuống @@ -84,20 +84,20 @@ Lỗi Lỗi kết nối mạng Không thể tải tất cả các thumbnails - Không thể giải mã chữ ký URL của video. - Không thể phân tích trang web. - Không thể phân tích trang web hoàn toàn. - Nội dung không có sẵn. - Chặn bởi GEMA. - Không thể thiết lập trình đơn tải xuống. - Đây là một video phát trực tiếp. Chúng chưa được hỗ trợ. - Không thể lấy bất kỳ luồng nào. + Không thể giải mã chữ ký URL video + Không thể phân tích cú pháp trang web + Không thể phân tích cú pháp hoàn toàn trang web + Nội dung không khả dụng + Chặn bởi GEMA + Không thể thiết lập menu tải xuống + Đây là STREAM LIVE, chưa được hỗ trợ. + Không thể lấy bất kỳ luồng nào Không thể tải hình ảnh Ứng dụng / Giao diện người dùng bị lỗi Xin lỗi, điều đó không nên xảy ra. Báo lỗi qua email Xin lỗi, một số lỗi đã xảy ra. - BÁo CÁO + BÁO CÁO Thông tin: Chuyện gì đã xảy ra: Gì: \\nRequest:\\nContent Lang:\\nService:\\nGMT Time:\\nPackage:\\nVersion:\\nOS version: @@ -123,7 +123,7 @@ Thử lại Quyền truy cập vào bộ nhớ đã bị từ chối Sử dụng trình phát cũ - Máy nghe nhạc Mediaframework tích hợp sẵn. + Máy nghe nhạc Mediaframework tích hợp sẵn ngàn @@ -132,7 +132,7 @@ Bắt đầu Dừng - Xem + Chơi Xóa checksum @@ -148,7 +148,7 @@ NewPipe đang tải xuống Chạm để biết chi tiết Vui lòng đợi … - Sao chép vào clipboard. + Sao chép vào clipboard Hãy chọn một thư mục tải về có sẵn. Sự cho phép này là cần thiết để \nMở trong chế độ bật lên @@ -168,17 +168,17 @@ Cộng tác viên Giấy phép Giao diện trực quan nhẹ cho Android. - Xem trên Github + Xem trên GitHub Giấy phép của NewPipe Cho dù bạn có ý tưởng, dịch, thay đổi thiết kế, làm sạch mã hoặc thay đổi mã, sự trợ giúp luôn được hoan nghênh. Càng làm nhiều thì càng tốt! Đọc giấy phép Sự đóng góp Quay - Ngôn ngữ nội dung ưu tiên + Ngôn ngữ nội dung ưu tiên Video & Âm thanh - Bật lên - Lịch sử - Lịch sử + Cửa sổ + Lịch sử & bộ nhớ cache + Lịch sử & bộ nhớ cache Danh sách Không tìm thấy Theo dõi @@ -187,4 +187,276 @@ Không thể thay đổi tình trạng theo dõi Không thể cập nhật tình trạng theo dõi - + Không tìm thấy trình phát luồng nào (bạn có thể cài đặt VLC để phát) + Tải xuống tệp luồng. + Hiển thị thông tin + + main + Đăng ký + Dấu trang + + Có gì mới + + Thêm vào + + Sử dụng tìm kiếm không chính xác nhanh + Tìm kiếm không chính xác cho phép người chơi tìm kiếm vị trí nhanh hơn với độ chính xác giảm + Tải hình thu nhỏ + Vô hiệu hóa để ngăn chặn tất cả các hình thu nhỏ tải và lưu dữ liệu và sử dụng bộ nhớ. Thay đổi điều này sẽ xóa bộ nhớ cache hình ảnh trong bộ nhớ và trên đĩa + Đã xóa bộ nhớ cache hình ảnh + Xóa siêu dữ liệu đã lưu vào bộ nhớ cache + Xóa tất cả dữ liệu trang web được lưu trong bộ nhớ cache + Đã xóa bộ nhớ cache siêu dữ liệu + Tự động phát tiếp theo theo hàng + Tự động thêm một luồng có liên quan khi phát luồng cuối cùng trong hàng đợi không lặp lại + Lịch sử tìm kiếm + Lưu trữ truy vấn tìm kiếm cục bộ + Theo dõi các video đã xem + Tiếp tục lấy tiêu điểm + Tiếp tục phát sau khi bị gián đoạn (ví dụ: cuộc gọi điện thoại) + Hiển thị mẹo \"giữ để nối thêm\" + Hiển thị mẹo khi nhấn nút nền hoặc bật lên trên trang chi tiết video + Quốc gia nội dung mặc định + Dịch vụ + Phát + Hành vi + Gỡ lỗi + Đã xếp hàng đợi trên trình phát nền + Xếp hàng đợi trên trình phát bật lên + Kênh + Danh sách phát + Bản nhạc + Người dùng + Hủy bỏ + Chơi tất cả + Luôn luôn + Chỉ một lần + Tập tin + + Thông báo NewPipe + Thông báo cho nền mới và Trình phát Popup + + [Không xác định] + + Chuyển đổi hướng màn hình + Chuyển sang nền + Chuyển sang Popup + Chuyển sang Main + + Nhập cơ sở dữ liệu + Xuất cơ sở dữ liệu + Sẽ ghi đè lịch sử và đăng ký hiện tại của bạn + Xuất lịch sử, đăng ký và danh sách phát + Xóa lịch sử xem + Xóa lịch sử của các luồng đã phát + Xóa toàn bộ lịch sử xem. + Đã xóa lịch sử xem. + Xóa lịch sử tìm kiếm + Xóa lịch sử của từ khóa tìm kiếm + Xóa toàn bộ lịch sử tìm kiếm. + Đã xóa lịch sử tìm kiếm. + Không thể phát luồng này + Đã xảy ra lỗi trình phát không thể khôi phục + Phục hồi từ lỗi trình phát + Người chơi bên ngoài không hỗ trợ các loại liên kết này + URL không hợp lệ + Không tìm thấy luồng video nào + Không tìm thấy luồng âm thanh nào + Thư mục không hợp lệ + Nguồn tệp / nội dung không hợp lệ + Tệp không tồn tại hoặc không đủ quyền đọc hoặc ghi vào tệp + Tên tệp không được để trống + Đã xảy ra lỗi: %1$s + Không có luồng nào để tải xuống + + Không có gì ở đây Nhưng dế + Kéo để sắp xếp lại + + Không có người đăng ký + + %s người đăng kí + + + Không có lượt xem nào + + %s lượt xem + + + Không có video nào + + %s video + + + Tạo nên + Xóa một + Xóa hết + Bỏ qua + Đổi tên + + Đã xóa 1 mục. + + Tải về + Các ký tự được cho phép trong tên tệp + Ký tự không hợp lệ được thay thế bằng giá trị này + Ký tự thay thế + + Chữ cái và chữ số + Hầu hết các ký tự đặc biệt + + Không có ứng dụng nào được cài đặt để phát tệp này + + Đóng góp + NewPipe được phát triển bởi các tình nguyện viên dành thời gian mang lại cho bạn những trải nghiệm tốt nhất. Hãy trở lại để giúp các nhà phát triển làm cho NewPipe thậm chí còn tốt hơn trong khi thưởng thức một tách cà phê. + Trả lại + Trang mạng + Truy cập trang web NewPipe để biết thêm thông tin và tin tức. + Chính sách bảo mật của NewPipe + Dự án NewPipe rất coi trọng quyền riêng tư của bạn. Do đó, ứng dụng không thu thập bất kỳ dữ liệu nào mà không có sự đồng ý của bạn. +\nChính sách bảo mật của NewPipe giải thích chi tiết dữ liệu nào được gửi và lưu trữ khi bạn gửi báo cáo sự cố. + Đọc chính sách bảo mật + NewPipe là phần mềm miễn phí copyleft: Bạn có thể sử dụng, chia sẻ nghiên cứu và cải thiện nó theo ý muốn của bạn. Cụ thể bạn có thể phân phối lại và / hoặc sửa đổi nó theo các điều khoản của Giấy phép Công cộng GNU như được xuất bản bởi Quỹ Phần mềm Tự do, hoặc phiên bản 3 của Giấy phép, hoặc (tùy chọn của bạn) bất kỳ phiên bản nào sau này. + Lịch sử + Đã tìm kiếm + Đã xem + Lịch sử bị tắt + Lịch sử + Lịch sử trống + Đã xóa lịch sử + Đã xóa mục + Bạn có muốn xóa mục này khỏi lịch sử tìm kiếm không? + Bạn có muốn xóa mục này khỏi lịch sử xem không? + Bạn có chắc chắn muốn xóa tất cả các mục khỏi lịch sử không? + Lần chơi cuối + Hầu hết phát + + Nội dung trang chính + Trang trống + Trang chủ + Trang đăng ký + Trang nguồn cấp dữ liệu + Trang kênh + Chọn kênh + Chưa có kênh nào được đăng ký + Chọn Trang chủ + Xuất xong + Nhập hoàn tất + Không có tệp ZIP hợp lệ + Cảnh báo: Không thể nhập tất cả các tệp. + Thao tác này sẽ ghi đè cài đặt hiện tại của bạn. + Bạn cũng muốn nhập cài đặt? + + Trang chủ + Xu hướng + Mới & hot + Trình phát nền + Trình phát Popup + Tẩy xoá + Chi tiết + Cài đặt âm thanh + Giữ để Enqueue + Phát trên nền + Phát qua cửa sổ + Bắt đầu chơi ở đây + Bắt đầu ở đây trên nền + Bắt đầu ở đây trên Popup + + Mở ngăn kéo + Đóng ngăn + Một cái gì đó sẽ xuất hiện ở đây sớm ;D + + + Hành động \'mở\' được ưu tiên + Hành động mặc định khi mở nội dung — %s + + Trình phát video + Trình phát nền + Trình phát Popup + Luôn luôn hỏi + + Đang nhận thông tin… + Đang tải nội dung được yêu cầu + + Tạo danh sách mới + Xóa danh sách phát + Đổi tên danh sách phát + Tên + Thêm vào danh sách phát + Đặt làm Hình thu nhỏ của danh sách phát + + Đánh dấu trang danh sách phát + Xóa dấu trang + + Bạn có muốn xóa danh sách phát này không? + Đã tạo danh sách phát + Đã thêm vào danh sách phát + Đã thay đổi hình thu nhỏ của danh sách phát + Không thể xóa danh sách phát + + Không có phụ đề + + Phù hợp + Lấp đầy + Thu phóng + + Tự động tạo ra + + Phụ đề + Sửa đổi tỷ lệ văn bản chú thích của người chơi và kiểu nền. Yêu cầu khởi động lại ứng dụng để có hiệu lực + + Bật LeakCanary + Theo dõi rò rỉ bộ nhớ có thể khiến ứng dụng trở nên không phản hồi khi đổ xô đống + + Báo cáo lỗi ngoài vòng đời + Buộc báo cáo ngoại lệ Rx không thể gửi được bên ngoài vòng đời của mảnh hoặc hoạt động sau khi xử lý + + Nhập khẩu/xuất khẩu + Nhập + Nhập từ + Xuất sang + + Đang nhập… + Đang xuất … + + Nhập tệp + Xuất trước + + Không thể nhập đăng ký + Không thể xuất đăng ký + + Nhập đăng ký YouTube bằng cách tải xuống tệp xuất: +\n +\n1. Truy cập URL này: %1$s +\n2. Đăng nhập khi được hỏi +\n3. Quá trình tải xuống sẽ bắt đầu (đó là tệp xuất) + Nhập hồ sơ SoundCloud bằng cách nhập URL hoặc ID của bạn: +\n +\n1. Bật \"chế độ màn hình\" trong trình duyệt web (trang web không khả dụng cho thiết bị di động) +\n2. Truy cập URL này: %1$s +\n3. Đăng nhập khi được hỏi +\n4. Sao chép URL tiểu sử mà bạn đã được chuyển hướng đến. + Hãy nhớ rằng hoạt động này có thể là mạng đắt tiền. +\n +\nBạn có muốn tiếp tục? + + Điều khiển tốc độ phát lại + Speed + Chiều cao + Hủy liên kết (có thể gây méo) + Tua đi nhanh trong khi im lặng + Tiếp theo + Cài lại + + Để tuân thủ Quy định bảo vệ dữ liệu chung của châu Âu (GDPR), chúng tôi sẽ thu hút sự chú ý của bạn đến chính sách bảo mật của NewPipe. Vui lòng đọc kỹ. +\nBạn phải chấp nhận nó để gửi cho chúng tôi báo cáo lỗi. + Chấp nhận + Từ chối + + Không giới hạn + Giới hạn độ phân giải khi sử dụng dữ liệu di động + Giảm thiểu trên công tắc ứng dụng + Hành động khi chuyển sang ứng dụng khác từ trình phát video chính — %s + không ai + Thu nhỏ xuống trình phát nền + Thu nhỏ trình phát bật lên + + diff --git a/app/src/main/res/values-zh-rCN/strings.xml b/app/src/main/res/values-zh-rCN/strings.xml index 39dfefe48..55cfad9ef 100644 --- a/app/src/main/res/values-zh-rCN/strings.xml +++ b/app/src/main/res/values-zh-rCN/strings.xml @@ -34,7 +34,7 @@ 即将播放 显示下一部和相似的视频 不支援此网址 - 默认内容语言 + 默认内容语言 视频和音频 外观 其他 diff --git a/app/src/main/res/values-zh-rHK/strings.xml b/app/src/main/res/values-zh-rHK/strings.xml index a8e847694..506705536 100644 --- a/app/src/main/res/values-zh-rHK/strings.xml +++ b/app/src/main/res/values-zh-rHK/strings.xml @@ -30,7 +30,7 @@ 下一部影片 顯示下一部及相關的影片 不支援此網址 - 預設內容語言 + 預設內容語言 影片及聲音 外觀 其他 @@ -55,7 +55,7 @@ 未能建立下載路徑「%1$s」 已建立下載路徑「%1$s」 - 內容被 GEMA 封鎖。 + 內容被 GEMA 封鎖 按一下搜尋按鈕以開始操作 自動撥放 當其他應用程式要求播放影片時,NewPipe 將會自動播放 @@ -69,9 +69,9 @@ 無法為影片地址的簽署解碼。 無法讀取網站。 無法完全讀取網站。 - 無法設定下載清單。 + 無法設定下載清單 此內容是一個直播串流,所以暫時未能播放。 - 無法取得任何串流。 + 無法取得任何串流 抱歉,這是不應該發生的。 透過電郵彙報問題 抱歉,程式出現了問題。 @@ -114,7 +114,7 @@ NewPipe 正在下載 按一下以查看詳情 請稍候… - 已複製至剪貼板。 + 已複製至剪貼板 請選擇下載資料夾。 在畫中畫模式開啟 @@ -130,7 +130,7 @@ 所有 頻道 - 稍候 + 稍後 無法取得圖片 應用程式或介面出現問題 事件:\\n請求:\\n內容語言:\\n服務:\\nGMT 時間:\\nPackage:\\n版本:\\n作業系統版本: @@ -165,7 +165,7 @@ 最佳解像度 調整大小 - 使用舊的內置 Mediaframework 播放器。 + 使用舊的內置 Mediaframework 播放器 B 關於 NewPipe @@ -179,7 +179,7 @@ 貢獻者 特許 在 Android 上運作自由輕便的 Youtube 前端。 - 檢視我們的 Github + 檢視我們的 GitHub NewPipe 的特許 無論您僅想分享您對 NewPipe 的一些構思,還是願意設計和翻譯程式介面,甚至想幫我們整理或重新編寫原始碼,我們都無任歡迎。貢獻更多,應用程式便會變得更好! 檢閱特許 diff --git a/app/src/main/res/values-zh-rTW/strings.xml b/app/src/main/res/values-zh-rTW/strings.xml index 8c4466a2e..e8a9e714c 100644 --- a/app/src/main/res/values-zh-rTW/strings.xml +++ b/app/src/main/res/values-zh-rTW/strings.xml @@ -1,11 +1,11 @@ - 點播%1$s次 - %1$s發布 - 找不到串流播放器,您要安裝VLC吗? + 點播 %1$s 次 + %1$s 發布 + 找不到串流播放器,您要安裝 VLC 嗎? 安裝 取消 - 用瀏覽器開啟 + 以瀏覽器開啟 分享 下載 搜尋 @@ -20,11 +20,11 @@ 已下載影片的存放路徑 輸入影片下載路徑 預設解析度 - 用Kodi播放 - 顯示用Kodi媒體中心播放影片的選項 + 用 Kodi 播放 + 顯示用 Kodi 媒體中心播放影片的選項 聲音 - 找不到Kore,您要安裝Kore嗎? - 顯示「用Kodi播放」的選項 + 找不到 Kore ,您要安裝 Kore 嗎? + 顯示「用 Kodi 播放」的選項 預設音訊格式 主題 灰暗 @@ -34,11 +34,11 @@ 下一部影片 顯示「下一部」與「相關」的影片 不支援此網址 - 預設內容語言 + 預設內容語言 影片和音訊 外觀 其他 - 在背景播放 + 背景播放中 播放 網路錯誤 @@ -48,37 +48,37 @@ 喜歡 不喜歡 使用 Tor - (實驗性功能)強制使用 Tor 下載(暫時不支援串流影片)。 + (實驗性) 強迫下載流量繞經 Tor 以加強隱私 (暫未支援串流影片)。 音訊下載路徑 已下載音訊的存放路徑 輸入音訊檔案的下載路徑 無法建立下載目錄「%1$s」 已建立下載目錄「%1$s」 -輕觸搜尋按鈕開始使用NewPipe +輕觸搜尋按鈕開始使用 NewPipe 以懸浮視窗開啟 勾選後,部分解析度的影片將沒有聲音 - NewPipe懸浮視窗模式 + NewPipe 懸浮視窗模式 背景播放 自動播放 - NewPipe 被其他應用程式呼叫時播放影片 + 當 NewPipe 被其他應用程式呼叫時播放影片 懸浮視窗預設解析度 顯示更高的解析度 - 只有部分裝置能播2K及4K影片 + 只有部分裝置能播 2K 及 4K 影片 預設影片格式 純黑 記住懸浮視窗大小和位置 - 記住上次懸浮視窗的大小和位置 + 記住上次使用時懸浮視窗的大小和位置 播放器手勢控制 - 使用手勢來控制亮度及播放器的音量 + 使用手勢來控制播放器的亮度及音量 搜尋建議 - 在搜尋時顯示搜尋建議 + 搜尋時顯示搜尋建議 懸浮視窗 - 在懸浮視窗中播放 + 以懸浮視窗播放中 內容 - 顯示受年齡限制的內容 - 此影片具有年齡限制,請先在設定中關閉年齡限制。 + 顯示具有年齡限制的內容 + 有年齡限制的影片。可於設定中選擇允許此種內容。 下載 下載 錯誤回報 @@ -92,7 +92,7 @@ 清除 最佳解析度 - 重新設定大小 + 調整大小 錯誤 無法載入所有縮圖 無法解析影片 URL 簽章 @@ -105,7 +105,7 @@ 無法取得串流 無法載入圖片 應用程式或界面已停止運作 - 抱歉,這不應該發生的。 + 抱歉,這是不該發生的。 使用電子郵件回報錯誤 抱歉,發生了一些問題。 回報 @@ -123,8 +123,8 @@ 音訊 重試 無法存取儲存空間 - 使用舊的播放器 - 舊型內建媒體播放器 + 使用舊式播放器 + 舊型內建 Mediaframework 播放器 @@ -147,7 +147,7 @@ 檔案已存在 錯誤的網址或網路無法使用 NewPipe 下載中 - 輕觸顯示詳細資訊 + 輕觸以顯示詳細資訊 請稍候… 已複製至剪貼簿 請選擇下載資料夾 @@ -167,7 +167,7 @@ 無法更新訂閱 主頁 - 訂閱 + 訂閱清單 新鮮事 @@ -175,7 +175,7 @@ 在本機儲存搜尋紀錄 歷史紀錄與快取 記錄觀看過的影片 - 在取得視窗焦點時繼續播放 + 取得視窗焦點時繼續播放 在干擾結束後繼續播放(例如有來電) 播放器 行為 @@ -222,10 +222,10 @@ 關於 貢獻者 授權條款 - Android 上開放且輕巧的 YouTube 串流應用程式。 + Android 上自由且輕巧的 YouTube 串流播放器。 在 GitHub 上檢視 NewPipe 使用的授權條款 - 不管你有什麼點子,翻譯、設計、程式碼整理,或者程式碼撰寫,我們永遠歡迎你來幫忙。完成的越多,NewPipe 也會更好! + 不管你有什麼點子——翻譯、設計、程式碼整理,或者程式碼撰寫——我們永遠歡迎你來幫忙。完成的越多,NewPipe 也會更好! 閱讀授權條款 貢獻 @@ -238,12 +238,12 @@ 已清除歷史紀錄 項目已刪除 確定要刪除此項搜尋紀錄嗎? -找不到串流播放器(您可以安裝 VLC播放) - 顯示「鎖定到附加」提示 +找不到串流播放器(您可以安裝 VLC 播放) + 顯示「長按以新增」提示 預設內容國家 服務 - 在背景播放器上等候 - 在懸浮視窗播放器上等候 + 已新增至背景播放佇列 + 已新增至懸浮視窗播放佇列 全部播放 總是 僅一次 @@ -257,9 +257,9 @@ 無法播放此串流 發生無法復原的播放器錯誤 - 從播放器錯誤中恢復 - 在背景或是影片詳細資訊頁面上按下浮模按鈕時顯示提示 - 外部播放器不支援這類型的連結 + 正在從播放器錯誤中復原 + 在影片詳細資訊頁按下背景播放或懸浮視窗按鈕時顯示提示 + 外部播放器不支援此類型連結 無效的 URL 找不到影片串流 找不到音訊串流 @@ -270,8 +270,8 @@ 匯出資料庫 將覆蓋您目前的歷史記錄和訂閱 匯出歷史記錄、訂閱和播放清單 - 返回 - 欲了解更多關於 NewPipe 的資訊和新聞,請造訪我們的網站。 + 回饋 + 如欲了解更多有關 NewPipe 的資訊和新聞,請造訪我們的網站。 首頁內容 空白頁面 互動導覽頁面 @@ -279,10 +279,10 @@ 提要頁面 頻道頁面 選擇頻道 - 尚未訂閱頻道 + 尚未訂閱任何頻道 選擇互動導覽 - 匯出完成 - 匯入完成 + 匯出已完成 + 匯入已完成 無有效的 ZIP 檔案 警告:無法匯入所有檔案。 這將覆蓋您目前的設定。 @@ -296,20 +296,20 @@ 移除 詳細資訊 音訊設定 - 在背景佇列 - 在懸浮視窗佇列 - 在此開始播放 - 在背景這裡開始 - 在懸浮視窗這裡開始 + 新增至背景佇列 + 新增至懸浮視窗佇列 + 從這裡開始播放 + 從這裡開始以背景播放 + 從這裡開始以懸浮視窗播放 - 維持在佇列 - NewPipe 由志願者所開發,他們花費了空閒時間將獲得的最佳體驗帶給您。現在是時候回過頭來,讓我們的開發人員可以能夠在享受一杯咖啡的同時,讓 NewPipe 變得更好。 + 長按以新增至佇列 + NewPipe 由志願者所開發,他們耗費時間務求為您帶來最佳體驗。現在是時候回過頭來,讓我們的開發人員能夠在使 NewPipe 更臻完美的同時,享受一杯咖啡。 打開抽屜 關閉抽屜 - 影片播放 - 背景播放 - 懸浮視窗播放 + 影片播放器 + 背景播放器 + 懸浮視窗播放器 總是詢問 正在取得資訊… @@ -321,16 +321,16 @@ 新增至 - 拖曳重新排序 + 拖曳以重新排序 建立 - 刪除一個 + 刪除 全部刪除 退出 - 更改名稱 + 重新命名 - 您是否要從觀看記錄中刪除這個項目嗎? - 您確實要刪除歷史記錄中的所有項目嗎? + 您是否要刪除此項觀看記錄? + 您確定要刪除歷史記錄中的所有項目嗎? 上一次播放 最常播放 @@ -338,23 +338,23 @@ 建立新的播放清單 刪除播放清單 - 重命名播放清單 + 重新命名播放清單 名稱 - 增加至播放清單 + 新增至播放清單 設為播放清單縮圖 - 書簽播放清單 - 移除書簽 + 將播放清單加入書籤 + 移除書籤 您是否要刪除此播放清單? 已建立播放清單 - 加入到播放清單 + 已新增至播放清單 播放清單縮圖已更改 無法刪除播放清單 沒有字幕 - 適合的 + 合適的 填滿 縮放 @@ -363,7 +363,7 @@ 正常字體 加大字體 - 某些東西很快就會出現 ;D + 某些東西即將在此出現 ;D 監測流失 @@ -378,9 +378,9 @@ 強制報告在處理完片段或活動週期外發生的無法傳遞的 Rx 異常 使用粗略但快速的尋找 - 粗略尋找讓播放器更快找到影片的進度位置 - 自動播放隊列中下一部影片 - 在非重複播放佇列中的最後一個串流上開始播放時,自動附上相關串流 + 粗略的尋找能讓播放器以降低的精確度更快找到影片的進度位置 + 自動將下一部影片新增至佇列 + 在非重複播放佇列中最後一個串流開始播放時,自動新增相關串流 同步 檔案 @@ -388,12 +388,12 @@ 無效的目錄 無效的檔案/內容來源 檔案名稱不能留空 - 發生錯誤:%1$s + 發生錯誤: %1$s 匯入/匯出 匯入 - 匯入來自 - 匯出到 + 匯入自 + 匯出至 正在匯入… 正在匯出… @@ -404,75 +404,75 @@ 之前的匯出 - 檔案不存在或沒有足夠的權限讀取或寫入 + 檔案不存在或權限不足以讀取或寫入該檔案 透過下載匯出檔案來匯入您的 YouTube 訂閱: \n -\n1. 轉到此網址:%1$s -\n2. 當被詢問時登入您的帳戶 +\n1. 移至此網址:%1$s +\n2. 當被詢問時登入 \n3. 下載應該開始 ( 這就是匯出的檔案 ) yourID, soundcloud.com/yourid - 請記住,此操作可能會造成網路昂貴花費。 -\n -\n您想繼續嗎? -透過輸入 URL 或您的 ID 來匯入 SoundCloud 檔案: + 請記住,此操作可造成昂貴網路花費。 \n -\n1. 在一些瀏覽器中啟用「桌面模式」(該網站不適用於行動裝置) -\n2. 移至此網址:%1$s -\n3. 詢問時登入到您的帳號 -\n4. 複製您被重新導向到的網址。 +\n您是否希望繼續? +透過輸入 URL 或您的 ID 來匯入 SoundCloud 個人設定檔: +\n +\n1. 在瀏覽器中啟用「桌面模式」(該網站不適用於行動裝置) +\n2. 移至此網址: %1$s +\n3. 當被詢問時登入 +\n4. 複製您被重新導向到的個人設定檔網址。 載入縮圖 - 停用後,NewPipe將不再載入縮圖,減少數據使用與騰空儲存空間,亦會清除記憶體和磁碟上的縮圖快取 + 停用後 NewPipe 將不再載入縮圖,減少數據和儲存空間的用量。改變此選項時將清除記憶體和磁碟上的縮圖快取 已清除圖片快取 - 抹除快取中介資料 + 清除快取中介資料 移除所有網頁的快取資料 已清除中介資料快取 播放速度控制 - 節拍 - 間距 + 節奏 + 音高 解除連結(可能導致失真) Nightcore 預設 偏好的「開啟」動作 - 開起內容時的預設動作 — %s + 開啟內容時的預設動作 — %s 沒有可供下載的串流 字幕 - 調整播放器字幕大小與背景樣式。必須重新啟動應用程式才會生效 + 調整播放器字幕文字大小與背景樣式。必須重新啟動應用程式才會生效 未安裝可播放此檔案的應用程式 清除觀看歷史 刪除播放過的串流歷史 - 刪除全部的觀看歷史。 + 刪除所有觀看歷史。 觀看歷史已刪除。 清除搜尋歷史 刪除搜尋關鍵字的歷史 - 刪除全部的搜尋歷史。 + 刪除所有搜尋歷史。 搜尋歷史已刪除。 已刪除 1 個項目。 - NewPipe 是一個 Copyleft 的自由軟體:您可以隨意使用、研究、分享並改進它。您可以在遵守由自由軟體基金會所發佈的 GNU 通用公共授權條款的狀況下自由地再散佈及/或修改它,授權條款預設使用第三版,但您也可以選擇更新的版本。 - 您是否同時的匯入設定? + NewPipe 是一個 Copyleft 的自由軟體:您可以隨意使用、研究、分享並改進它。在遵守由自由軟體基金會所發佈的 GNU 通用公共授權條款的狀況下,您可以自由地再散佈及/或修改它;授權條款預設使用第三版,但您也可以選擇更新的版本。 + 您是否要同時匯入設定? NewPipe 的隱私政策 - NewPipe 專案非常重視您的隱私。因此,未經您的同意應用程式不會收集任何的資料。 -\nNewPipe 的隱私權政策,詳細說明了當您發送錯誤回報時,什麼資料才會進行傳送及儲存。 + NewPipe 專案非常重視您的隱私。因此,未經您同意此程式不會收集任何資料。 +\nNewPipe 的隱私權政策詳細說明了當您發送錯誤回報時,什麼資料會被傳送及儲存。 閱讀隱私政策 - 為了符合歐洲通用資料保護條例 ( GDPR ) ,我們請您注意 NewPipe 的隱私政策。請您務必仔細閱讀。 + 為配合歐洲通用資料保護條例 ( GDPR ) ,我們在此請您注意 NewPipe 的隱私政策。請務必仔細閱讀。 \n您必須接受它才能向我們發送錯誤報告。 接受 - 下降 + 拒絕 沒有限制 - 當您使用行動網路時限制解析度 - 在應用程式切換時最小化 - 當從主影片播放器切換到其他應用程式時要進行的動作 — %s + 使用行動網路時限制解析度 + 切換應用程式時最小化 + 從主影片播放器切換到其他應用程式時要執行的動作 — %s 最小化為背景播放器 最小化為彈出式播放器 -在靜音時快轉 +靜音時快轉 步進 重設 diff --git a/app/src/main/res/values/dimens.xml b/app/src/main/res/values/dimens.xml index e7af3231e..229c00533 100644 --- a/app/src/main/res/values/dimens.xml +++ b/app/src/main/res/values/dimens.xml @@ -12,6 +12,8 @@ 124dp 70dp + 164dp + 92dp 94dp diff --git a/app/src/main/res/values/settings_keys.xml b/app/src/main/res/values/settings_keys.xml index 1a56e2d40..0b7f46e67 100644 --- a/app/src/main/res/values/settings_keys.xml +++ b/app/src/main/res/values/settings_keys.xml @@ -17,9 +17,9 @@ use_external_video_player use_external_audio_player autoplay_through_intent - use_oldplayer - player_gesture_controls + volume_gesture_control + brightness_gesture_control resume_on_audio_focus_gain popup_remember_size_pos_key use_inexact_seek_key @@ -105,6 +105,8 @@ last_orientation_landscape_key + last_resize_mode + debug_pref_screen_key allow_heap_dumping_key @@ -139,7 +141,7 @@ show_hold_to_append en GB - search_language + content_language content_country show_age_restricted_content use_tor @@ -372,8 +374,8 @@ Andorra Angola Anguilla - Antarctica - Antiguaand Barbuda + Antartica + Antigua and Barbuda Argentina Armenia Aruba @@ -391,9 +393,9 @@ Bermuda Bhutan Bolivia - Bosniaand Herzegovina + Bosnia and Herzegovina Botswana - BouvetIsland + Bouvet Island Brazil British Virgin Islands British Indian Ocean Territory @@ -404,23 +406,23 @@ Cambodia Cameroon Canada - CapeVerde + Cape Verde Cayman Islands Central African Republic Chad Chile China - HongKong, China - Macao,China + Hong Kong (China) + Macao (China) Christmas Island - Cocos(Keeling) Islands + Cocos (Keeling) Islands Colombia Comoros - Congo(Brazzaville) - Congo, (Kinshasa) + Brazzaville (Congo) + Kinshasa (Congo) Cook Islands - CostaRica - Côted\'Ivoire + Costa Rica + Côte d\'Ivoire Croatia Cuba Cyprus @@ -431,8 +433,8 @@ Dominican Republic Ecuador Egypt - ElSalvador - EquatorialGuinea + El Salvador + Equatorial Guinea Eritrea Estonia Ethiopia @@ -461,8 +463,8 @@ Guinea-Bissau Guyana Haiti - Heardand Mcdonald Islands - HolySee (Vatican City State) + Heard and McDonald Islands + Holy See (Vatican City State) Honduras Hungary Iceland @@ -471,7 +473,7 @@ Iran Iraq Ireland - Isleof Man + Isle of Man Israel Italy Jamaica @@ -481,8 +483,8 @@ Kazakhstan Kenya Kiribati - Korea(North) - Korea(South) + North Korea + South Korea Kuwait Kyrgyzstan Lao @@ -501,7 +503,7 @@ Maldives Mali Malta - MarshallIslands + Marshall Islands Martinique Mauritania Mauritius @@ -533,7 +535,7 @@ Oman Pakistan Palau - Palestinian Territory + Palestine Panama Papua New Guinea Paraguay @@ -542,71 +544,71 @@ Pitcairn Poland Portugal - PuertoRico + Puerto Rico Qatar Réunion Romania Russian Federation Rwanda - Saint-Barthélemy + Saint Barthélemy Saint Helena - Saint KittsandNevis - SaintLucia - Saint-Martin(Frenchpart) - SaintPierreandMiquelon - Saint Vincentand Grenadines + Saint Kitts and Nevis + Saint Lucia + Saint Martin + Saint Pierre and Miquelon + Saint Vincent and Grenadines Samoa San Marino - Sao Tomeand Principe - SaudiArabia + Sao Tome and Principe + Saudi Arabia Senegal Serbia Seychelles - SierraLeone + Sierra Leone Singapore Slovakia Slovenia - SolomonIslands + Solomon Islands Somalia - SouthAfrica - South Georgiaandthe South Sandwich Islands + South Africa + South Georgia and South Sandwich Islands South Sudan Spain Sri Lanka Sudan Suriname - Svalbardand Jan Mayen Islands + Svalbard and Jan Mayen Islands Swaziland Sweden Switzerland - Syrian ArabRepublic(Syria) - Taiwan, Republicof China + Syrian Arab Republic (Syria) + Taiwan Tajikistan Tanzania Thailand - Timor-Leste + Timor Leste Togo Tokelau Tonga - Trinidadand Tobago + Trinidad and Tobago Tunisia Turkey Turkmenistan - Turksand Caicos Islands + Turks and Caicos Islands Tuvalu Uganda Ukraine United Arab Emirates United Kingdom - USA + United States Minor Outlying Islands Uruguay Uzbekistan Vanuatu - Venezuela (BolivarianRepublic) - VietNam - Virgin Islands, - Wallisand Futuna Islands + Venezuela (Bolivarian Republic) + Vietnam + Virgin Islands + Wallis and Futuna Islands Western Sahara Yemen Zambia @@ -879,5 +881,18 @@ 144p + list_view_mode + auto - \ No newline at end of file + + auto + list + grid + + + @string/auto + @string/list + @string/grid + + + diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 354778e6d..0f85963a5 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -5,7 +5,7 @@ %1$s views Published on %1$s No stream player found. Do you want to install VLC? - No stream player found (you can install VLC to play it) + No stream player found (you can install VLC to play it). Install Cancel https://f-droid.org/repository/browse/?fdfilter=vlc&fdid=org.videolan.vlc @@ -13,28 +13,29 @@ Open in popup mode Share Download - Download stream file. + Download stream file Search Settings - Did you mean: %1$s ? + Did you mean: %1$s\? Share with Choose browser rotation Use external video player - Some resolutions will NOT have audio when this option is enabled + Removes audio at SOME resolutions Use external audio player NewPipe popup mode RSS Subscribe Subscribed + Unsubscribe Channel unsubscribed - Unable to change subscription - Unable to update subscription + Could not change subscription + Could not update subscription Show info Main Subscriptions - Bookmarks + Bookmarked Playlists New Tab Choose Tab @@ -48,8 +49,8 @@ Path to store downloaded videos in Enter download path for videos - Audio download path - Path to store downloaded audio in + Audio download folder + Downloaded audio is stored here Enter download path for audio files Autoplay @@ -75,7 +76,7 @@ Use fast inexact seek Inexact seek allows the player to seek to positions faster with reduced precision Load thumbnails - Disable to stop all thumbnails from loading and save on data and memory usage. Changing this will clear both in-memory and on-disk image cache. + When off no thumbnails load, saving data and memory usage. Changes clear both in-memory and on-disk image cache. Show comments Disable to stop showing comments Image cache wiped @@ -84,8 +85,10 @@ Metadata cache wiped Auto-queue next stream Auto-append a related stream when playing the last stream in a non-repeating queue. - Player gesture controls - Use gestures to control the brightness and volume of the player + Volume gesture control + Use gestures to control the volume of the player + Brightness gesture control + Use gestures to control the brightness of the player Search suggestions Show suggestions when searching Search history @@ -97,17 +100,17 @@ Download Up next Autoplay - Show \'next\' and \'similar\' videos - Show \"hold to append\" tip + Show \'Next\' and \'Similar\' videos + Show \"Hold to append\" tip Show tip when background or popup button is pressed on video details page - URL not supported + Unsupported URL Default content country Service - Default content language + Default content language Player Behavior - Video & Audio - History & Cache + Video & audio + History & cache Popup Appearance Other @@ -119,8 +122,8 @@ https://www.c3s.cc/ Play Content - Show age restricted content - Age Restricted Video. Allowing such material is possible from Settings. + Age restricted content + Show age Restricted Video. Allowing such material is possible from \"Settings\". live LIVE Downloads @@ -151,7 +154,7 @@ newpipe NewPipe Notification - Notifications for NewPipe Background and Popup Players + Notifications for NewPipe background and popup players [Unknown] @@ -162,29 +165,29 @@ Import database Export database - Will override your current history and subscriptions - Export history, subscriptions and playlists. + Overrides your current history and subscriptions + Export history, subscriptions and playlists Clear watch history - Deletes the history of played streams. - Delete whole watch history. + Deletes the history of played streams + Delete entire watch history? Watch history deleted. Clear search history - Deletes history of search keywords. - Delete whole search history. + Deletes history of search keywords + Delete entire search history? Search history deleted. Error - External storage not available. - Download to external SD Card is not possible yet. Should the download place be reset? + External storage unavailable + Download to external SD card is not possible yet. Reset download folder location? Network error Could not load all thumbnails Could not decrypt video URL signature Could not parse website Could not parse website completely - Content not available + Content unavailable Blocked by GEMA Could not set up download menu - This is a LIVE STREAM, which is not yet supported. + Live streams are not supported yet Could not get any stream Could not load image App/UI crashed @@ -195,10 +198,10 @@ Invalid URL No video streams found No audio streams found - Invalid directory - Invalid file/content source - File doesn\'t exist or insufficient permission to read or write to it - File name cannot be empty + No such folder + No such file/content source + The file doesn\'t exist or permission to read or write to it is lacking + Filename cannot be empty An error occurred: %1$s No streams available to download Using default tabs, error while reading saved tabs @@ -231,7 +234,7 @@ No results @string/no_videos @string/no_comments - Nothing Here But Crickets + Nothing here but crickets Drag to reorder Cannot create download directory \'%1$s\' @@ -241,8 +244,6 @@ Audio Retry Storage access permission denied - Use old player - Old built-in Mediaframework player K M @@ -294,7 +295,7 @@ Filename Threads Error - Server unsupported + Unsupported server File already exists Malformed URL or Internet not available NewPipe Downloading @@ -309,8 +310,8 @@ MD5 SHA-1 reCAPTCHA - reCAPTCHA Challenge - reCAPTCHA Challenge requested + reCAPTCHA challenge + reCAPTCHA challenge requested @@ -355,7 +356,7 @@ https://newpipe.schabi.org/legal/privacy/ Read privacy policy NewPipe\'s License - NewPipe is copyleft libre software: You can use, study share and improve it at your will. Specifically you can redistribute and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. + NewPipe is copyleft libre software: You can use, study share and improve it at will. Specifically you can redistribute and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. Read license @@ -363,7 +364,7 @@ History Searched Watched - History is disabled + History is turned off History The history is empty History cleared @@ -384,10 +385,10 @@ Feed Page Channel Page Select a channel - No channel subscribed yet + No channel subscriptions yet Select a kiosk - Export complete - Import complete + Exported + Imported No valid ZIP file Warning: Could not import all files. This will override your current setup. @@ -402,17 +403,17 @@ %1$s/%2$s - Background Player - Popup Player + Background player + Popup player Remove Details Audio Settings - Hold To Enqueue - Enqueue on Background - Enqueue on Popup - Start Playing Here - Start Here on Background - Start Here on Popup + Hold To enqueue + Enqueue when backgrounded + Enqueue on new popup + Start playing here + Start here when backgrounded + Start here on new popup Open Drawer @@ -436,9 +437,9 @@ "Loading requested content" - Create New Playlist - Delete Playlist - Rename Playlist + New Playlist + Delete + Rename Name Add To Playlist Set as Playlist Thumbnail @@ -446,11 +447,11 @@ Bookmark Playlist Remove Bookmark - Do you want to delete this playlist? + Delete this playlist? Playlist created - Added to playlist - Playlist thumbnail changed - Could not delete playlist + Playlisted + Playlist thumbnail changed. + Could not delete playlist. No Captions @@ -469,11 +470,11 @@ Enable LeakCanary Memory leak monitoring may cause the app to become unresponsive when heap dumping - Report Out-of-lifecycle Errors + Report out-of-lifecycle errors Force reporting of undeliverable Rx exceptions outside of fragment or activity lifecycle after disposal - Import/Export + Import/export Import Import from Export to @@ -524,10 +525,14 @@ - Minimize on application switch - Action when switching to other application from main video player — %s + Minimize on app switch + Action when switching to other app from main video player — %s None Minimize to background player Minimize to popup player - + List view mode + List + Grid + Auto + Switch View diff --git a/app/src/main/res/xml/appearance_settings.xml b/app/src/main/res/xml/appearance_settings.xml index 1f711b510..437736ab0 100644 --- a/app/src/main/res/xml/appearance_settings.xml +++ b/app/src/main/res/xml/appearance_settings.xml @@ -22,6 +22,14 @@ android:title="@string/show_hold_to_append_title" android:summary="@string/show_hold_to_append_summary"/> + + - + android:title="@string/content_language_title"/> - - - - + + + android:key="@string/volume_gesture_control_key" + android:summary="@string/volume_gesture_control_summary" + android:title="@string/volume_gesture_control_title"/> + +