diff --git a/app/src/main/java/com/github/libretube/MyApp.kt b/app/src/main/java/com/github/libretube/MyApp.kt index 1fbacc843..5f74f948b 100644 --- a/app/src/main/java/com/github/libretube/MyApp.kt +++ b/app/src/main/java/com/github/libretube/MyApp.kt @@ -9,7 +9,6 @@ import android.os.StrictMode import android.os.StrictMode.VmPolicy import androidx.preference.PreferenceManager import androidx.work.ExistingPeriodicWorkPolicy -import coil.ImageLoader import com.fasterxml.jackson.core.type.TypeReference import com.fasterxml.jackson.databind.ObjectMapper import com.github.libretube.api.CronetHelper @@ -19,8 +18,8 @@ import com.github.libretube.db.obj.WatchHistoryItem import com.github.libretube.db.obj.WatchPosition import com.github.libretube.preferences.PreferenceHelper import com.github.libretube.preferences.PreferenceKeys -import com.github.libretube.util.ConnectionHelper import com.github.libretube.util.ExceptionHandler +import com.github.libretube.util.ImageHelper import com.github.libretube.util.NotificationHelper class MyApp : Application() { @@ -93,9 +92,7 @@ class MyApp : Application() { RetrofitInstance.url } CronetHelper.initCronet(this) - ConnectionHelper.imageLoader = ImageLoader.Builder(this) - .callFactory(CronetHelper.callFactory) - .build() + ImageHelper.initializeImageLoader(this) } /** diff --git a/app/src/main/java/com/github/libretube/activities/MainActivity.kt b/app/src/main/java/com/github/libretube/activities/MainActivity.kt index 2c8826c7a..d54f59104 100644 --- a/app/src/main/java/com/github/libretube/activities/MainActivity.kt +++ b/app/src/main/java/com/github/libretube/activities/MainActivity.kt @@ -36,8 +36,8 @@ import com.github.libretube.models.SearchViewModel import com.github.libretube.preferences.PreferenceHelper import com.github.libretube.preferences.PreferenceKeys import com.github.libretube.services.ClosingService -import com.github.libretube.util.ConnectionHelper import com.github.libretube.util.LocaleHelper +import com.github.libretube.util.NetworkHelper import com.github.libretube.util.ThemeHelper import com.google.android.material.dialog.MaterialAlertDialogBuilder import com.google.android.material.elevation.SurfaceColors @@ -73,7 +73,7 @@ class MainActivity : BaseActivity() { } // show noInternet Activity if no internet available on app startup - if (!ConnectionHelper.isNetworkAvailable(this)) { + if (!NetworkHelper.isNetworkAvailable(this)) { val noInternetIntent = Intent(this, NoInternetActivity::class.java) startActivity(noInternetIntent) finish() diff --git a/app/src/main/java/com/github/libretube/activities/NoInternetActivity.kt b/app/src/main/java/com/github/libretube/activities/NoInternetActivity.kt index fa5f2cae7..17cb13b97 100644 --- a/app/src/main/java/com/github/libretube/activities/NoInternetActivity.kt +++ b/app/src/main/java/com/github/libretube/activities/NoInternetActivity.kt @@ -6,7 +6,7 @@ import com.github.libretube.R import com.github.libretube.databinding.ActivityNointernetBinding import com.github.libretube.extensions.BaseActivity import com.github.libretube.extensions.showSnackBar -import com.github.libretube.util.ConnectionHelper +import com.github.libretube.util.NetworkHelper import com.github.libretube.util.ThemeHelper class NoInternetActivity : BaseActivity() { @@ -18,7 +18,7 @@ class NoInternetActivity : BaseActivity() { binding = ActivityNointernetBinding.inflate(layoutInflater) // retry button binding.retryButton.setOnClickListener { - if (ConnectionHelper.isNetworkAvailable(this)) { + if (NetworkHelper.isNetworkAvailable(this)) { ThemeHelper.restartMainActivity(this) } else { binding.root.showSnackBar(R.string.turnInternetOn) diff --git a/app/src/main/java/com/github/libretube/adapters/ChannelAdapter.kt b/app/src/main/java/com/github/libretube/adapters/ChannelAdapter.kt index 3574d9117..9fdc4893c 100644 --- a/app/src/main/java/com/github/libretube/adapters/ChannelAdapter.kt +++ b/app/src/main/java/com/github/libretube/adapters/ChannelAdapter.kt @@ -8,7 +8,7 @@ import androidx.recyclerview.widget.RecyclerView import com.github.libretube.databinding.VideoRowBinding import com.github.libretube.dialogs.VideoOptionsDialog import com.github.libretube.obj.StreamItem -import com.github.libretube.util.ConnectionHelper +import com.github.libretube.util.ImageHelper import com.github.libretube.util.NavigationHelper import com.github.libretube.util.formatShort import com.github.libretube.util.setWatchProgressLength @@ -45,7 +45,7 @@ class ChannelAdapter( DateUtils.getRelativeTimeSpanString(trending.uploaded!!) thumbnailDuration.text = DateUtils.formatElapsedTime(trending.duration!!) - ConnectionHelper.loadImage(trending.thumbnail, thumbnail) + ImageHelper.loadImage(trending.thumbnail, thumbnail) root.setOnClickListener { NavigationHelper.navigateVideo(root.context, trending.url) } diff --git a/app/src/main/java/com/github/libretube/adapters/ChaptersAdapter.kt b/app/src/main/java/com/github/libretube/adapters/ChaptersAdapter.kt index 8ddaba1cd..9a333403d 100644 --- a/app/src/main/java/com/github/libretube/adapters/ChaptersAdapter.kt +++ b/app/src/main/java/com/github/libretube/adapters/ChaptersAdapter.kt @@ -6,7 +6,7 @@ import android.view.ViewGroup import androidx.recyclerview.widget.RecyclerView import com.github.libretube.databinding.ChapterColumnBinding import com.github.libretube.obj.ChapterSegment -import com.github.libretube.util.ConnectionHelper +import com.github.libretube.util.ImageHelper import com.github.libretube.util.ThemeHelper import com.google.android.exoplayer2.ExoPlayer @@ -25,7 +25,7 @@ class ChaptersAdapter( override fun onBindViewHolder(holder: ChaptersViewHolder, position: Int) { val chapter = chapters[position] holder.binding.apply { - ConnectionHelper.loadImage(chapter.image, chapterImage) + ImageHelper.loadImage(chapter.image, chapterImage) chapterTitle.text = chapter.title if (selectedPosition == position) { diff --git a/app/src/main/java/com/github/libretube/adapters/CommentsAdapter.kt b/app/src/main/java/com/github/libretube/adapters/CommentsAdapter.kt index b9165be4c..44e03ba82 100644 --- a/app/src/main/java/com/github/libretube/adapters/CommentsAdapter.kt +++ b/app/src/main/java/com/github/libretube/adapters/CommentsAdapter.kt @@ -13,7 +13,7 @@ import com.github.libretube.databinding.CommentsRowBinding import com.github.libretube.extensions.TAG import com.github.libretube.obj.Comment import com.github.libretube.obj.CommentsPage -import com.github.libretube.util.ConnectionHelper +import com.github.libretube.util.ImageHelper import com.github.libretube.util.NavigationHelper import com.github.libretube.util.formatShort import kotlinx.coroutines.CoroutineScope @@ -51,7 +51,7 @@ class CommentsAdapter( " • " + comment.commentedTime.toString() commentText.text = comment.commentText.toString() - ConnectionHelper.loadImage(comment.thumbnail, commentorImage) + ImageHelper.loadImage(comment.thumbnail, commentorImage) likesTextView.text = comment.likeCount?.toLong().formatShort() if (comment.verified == true) { diff --git a/app/src/main/java/com/github/libretube/adapters/PlaylistAdapter.kt b/app/src/main/java/com/github/libretube/adapters/PlaylistAdapter.kt index 9f9a5fa7d..2874843c2 100644 --- a/app/src/main/java/com/github/libretube/adapters/PlaylistAdapter.kt +++ b/app/src/main/java/com/github/libretube/adapters/PlaylistAdapter.kt @@ -15,7 +15,7 @@ import com.github.libretube.extensions.setFormattedDuration import com.github.libretube.obj.PlaylistId import com.github.libretube.obj.StreamItem import com.github.libretube.preferences.PreferenceHelper -import com.github.libretube.util.ConnectionHelper +import com.github.libretube.util.ImageHelper import com.github.libretube.util.NavigationHelper import com.github.libretube.util.setWatchProgressLength import com.github.libretube.util.toID @@ -54,7 +54,7 @@ class PlaylistAdapter( playlistTitle.text = streamItem.title playlistDescription.text = streamItem.uploaderName thumbnailDuration.setFormattedDuration(streamItem.duration!!) - ConnectionHelper.loadImage(streamItem.thumbnail, playlistThumbnail) + ImageHelper.loadImage(streamItem.thumbnail, playlistThumbnail) root.setOnClickListener { NavigationHelper.navigateVideo(root.context, streamItem.url, playlistId) } diff --git a/app/src/main/java/com/github/libretube/adapters/PlaylistsAdapter.kt b/app/src/main/java/com/github/libretube/adapters/PlaylistsAdapter.kt index d9355c303..55a146a73 100644 --- a/app/src/main/java/com/github/libretube/adapters/PlaylistsAdapter.kt +++ b/app/src/main/java/com/github/libretube/adapters/PlaylistsAdapter.kt @@ -14,7 +14,7 @@ import com.github.libretube.extensions.TAG import com.github.libretube.obj.PlaylistId import com.github.libretube.obj.Playlists import com.github.libretube.preferences.PreferenceHelper -import com.github.libretube.util.ConnectionHelper +import com.github.libretube.util.ImageHelper import com.github.libretube.util.NavigationHelper import com.google.android.material.dialog.MaterialAlertDialogBuilder import kotlinx.coroutines.CoroutineScope @@ -52,7 +52,7 @@ class PlaylistsAdapter( playlistThumbnail.setImageResource(R.drawable.ic_empty_playlist) playlistThumbnail.setBackgroundColor(R.attr.colorSurface) } else { - ConnectionHelper.loadImage(playlist.thumbnail, playlistThumbnail) + ImageHelper.loadImage(playlist.thumbnail, playlistThumbnail) } playlistTitle.text = playlist.name deletePlaylist.setOnClickListener { diff --git a/app/src/main/java/com/github/libretube/adapters/RepliesAdapter.kt b/app/src/main/java/com/github/libretube/adapters/RepliesAdapter.kt index a155ccd85..e4a31b4af 100644 --- a/app/src/main/java/com/github/libretube/adapters/RepliesAdapter.kt +++ b/app/src/main/java/com/github/libretube/adapters/RepliesAdapter.kt @@ -6,7 +6,7 @@ import android.view.ViewGroup import androidx.recyclerview.widget.RecyclerView import com.github.libretube.databinding.RepliesRowBinding import com.github.libretube.obj.Comment -import com.github.libretube.util.ConnectionHelper +import com.github.libretube.util.ImageHelper import com.github.libretube.util.NavigationHelper import com.github.libretube.util.formatShort @@ -40,7 +40,7 @@ class RepliesAdapter( " • " + reply.commentedTime.toString() commentText.text = reply.commentText.toString() - ConnectionHelper.loadImage(reply.thumbnail, commentorImage) + ImageHelper.loadImage(reply.thumbnail, commentorImage) likesTextView.text = reply.likeCount?.toLong().formatShort() if (reply.verified == true) { diff --git a/app/src/main/java/com/github/libretube/adapters/SearchAdapter.kt b/app/src/main/java/com/github/libretube/adapters/SearchAdapter.kt index 522dde4c8..97635d6d8 100644 --- a/app/src/main/java/com/github/libretube/adapters/SearchAdapter.kt +++ b/app/src/main/java/com/github/libretube/adapters/SearchAdapter.kt @@ -14,7 +14,7 @@ import com.github.libretube.dialogs.PlaylistOptionsDialog import com.github.libretube.dialogs.VideoOptionsDialog import com.github.libretube.extensions.setFormattedDuration import com.github.libretube.obj.SearchItem -import com.github.libretube.util.ConnectionHelper +import com.github.libretube.util.ImageHelper import com.github.libretube.util.NavigationHelper import com.github.libretube.util.formatShort import com.github.libretube.util.setWatchProgressLength @@ -79,9 +79,9 @@ class SearchAdapter( private fun bindWatch(item: SearchItem, binding: VideoRowBinding) { binding.apply { - ConnectionHelper.loadImage(item.thumbnail, thumbnail) + ImageHelper.loadImage(item.thumbnail, thumbnail) thumbnailDuration.setFormattedDuration(item.duration!!) - ConnectionHelper.loadImage(item.uploaderAvatar, channelImage) + ImageHelper.loadImage(item.uploaderAvatar, channelImage) videoTitle.text = item.title val viewsString = if (item.views?.toInt() != -1) item.views.formatShort() else "" val uploadDate = if (item.uploadedDate != null) item.uploadedDate else "" @@ -110,7 +110,7 @@ class SearchAdapter( private fun bindChannel(item: SearchItem, binding: ChannelRowBinding) { binding.apply { - ConnectionHelper.loadImage(item.thumbnail, searchChannelImage) + ImageHelper.loadImage(item.thumbnail, searchChannelImage) searchChannelName.text = item.name searchViews.text = root.context.getString( R.string.subscribers, @@ -157,7 +157,7 @@ class SearchAdapter( private fun bindPlaylist(item: SearchItem, binding: PlaylistSearchRowBinding) { binding.apply { - ConnectionHelper.loadImage(item.thumbnail, searchThumbnail) + ImageHelper.loadImage(item.thumbnail, searchThumbnail) if (item.videos?.toInt() != -1) searchPlaylistNumber.text = item.videos.toString() searchDescription.text = item.name searchName.text = item.uploaderName diff --git a/app/src/main/java/com/github/libretube/adapters/SubscriptionChannelAdapter.kt b/app/src/main/java/com/github/libretube/adapters/SubscriptionChannelAdapter.kt index ffcee61a6..1357b25dd 100644 --- a/app/src/main/java/com/github/libretube/adapters/SubscriptionChannelAdapter.kt +++ b/app/src/main/java/com/github/libretube/adapters/SubscriptionChannelAdapter.kt @@ -7,7 +7,7 @@ import com.github.libretube.R import com.github.libretube.api.SubscriptionHelper import com.github.libretube.databinding.ChannelSubscriptionRowBinding import com.github.libretube.obj.Subscription -import com.github.libretube.util.ConnectionHelper +import com.github.libretube.util.ImageHelper import com.github.libretube.util.NavigationHelper import com.github.libretube.util.toID @@ -31,7 +31,7 @@ class SubscriptionChannelAdapter(private val subscriptions: MutableList(PreferenceKeys.MAX_IMAGE_CACHE) + maxImageCache?.setOnPreferenceChangeListener { _, _ -> + ImageHelper.initializeImageLoader(requireContext()) + true + } + val resetSettings = findPreference(PreferenceKeys.RESET_SETTINGS) resetSettings?.setOnPreferenceClickListener { showResetDialog() diff --git a/app/src/main/java/com/github/libretube/preferences/MainSettings.kt b/app/src/main/java/com/github/libretube/preferences/MainSettings.kt index b465a0652..20c0d5bfd 100644 --- a/app/src/main/java/com/github/libretube/preferences/MainSettings.kt +++ b/app/src/main/java/com/github/libretube/preferences/MainSettings.kt @@ -9,7 +9,7 @@ import com.github.libretube.activities.SettingsActivity import com.github.libretube.dialogs.UpdateDialog import com.github.libretube.extensions.showSnackBar import com.github.libretube.update.UpdateChecker -import com.github.libretube.util.ConnectionHelper +import com.github.libretube.util.NetworkHelper import com.github.libretube.views.MaterialPreferenceFragment import kotlinx.coroutines.CoroutineScope import kotlinx.coroutines.Dispatchers @@ -86,7 +86,7 @@ class MainSettings : MaterialPreferenceFragment() { // checking for update: yes -> dialog, no -> snackBar update?.setOnPreferenceClickListener { CoroutineScope(Dispatchers.IO).launch { - if (!ConnectionHelper.isNetworkAvailable(requireContext())) { + if (!NetworkHelper.isNetworkAvailable(requireContext())) { (activity as SettingsActivity).binding.root.showSnackBar(R.string.unknown_error) return@launch } diff --git a/app/src/main/java/com/github/libretube/preferences/PreferenceHelper.kt b/app/src/main/java/com/github/libretube/preferences/PreferenceHelper.kt index 284d05666..7781c3321 100644 --- a/app/src/main/java/com/github/libretube/preferences/PreferenceHelper.kt +++ b/app/src/main/java/com/github/libretube/preferences/PreferenceHelper.kt @@ -39,6 +39,10 @@ object PreferenceHelper { return settings.getBoolean(key, defValue) } + fun getInt(key: String?, defValue: Int): Int { + return settings.getInt(key, defValue) + } + fun clearPreferences() { editor.clear().apply() } diff --git a/app/src/main/java/com/github/libretube/preferences/PreferenceKeys.kt b/app/src/main/java/com/github/libretube/preferences/PreferenceKeys.kt index fa3fdff01..dbe69a7f1 100644 --- a/app/src/main/java/com/github/libretube/preferences/PreferenceKeys.kt +++ b/app/src/main/java/com/github/libretube/preferences/PreferenceKeys.kt @@ -92,6 +92,7 @@ object PreferenceKeys { * Advanced */ const val DATA_SAVER_MODE = "data_saver_mode" + const val MAX_IMAGE_CACHE = "" const val RESET_SETTINGS = "reset_settings" const val CLEAR_SEARCH_HISTORY = "clear_search_history" const val CLEAR_WATCH_HISTORY = "clear_watch_history" diff --git a/app/src/main/java/com/github/libretube/util/ImageHelper.kt b/app/src/main/java/com/github/libretube/util/ImageHelper.kt new file mode 100644 index 000000000..f072dacd4 --- /dev/null +++ b/app/src/main/java/com/github/libretube/util/ImageHelper.kt @@ -0,0 +1,46 @@ +package com.github.libretube.util + +import android.content.Context +import android.widget.ImageView +import coil.ImageLoader +import coil.disk.DiskCache +import coil.load +import com.github.libretube.api.CronetHelper +import com.github.libretube.preferences.PreferenceHelper +import com.github.libretube.preferences.PreferenceKeys + +object ImageHelper { + lateinit var imageLoader: ImageLoader + + /** + * Initialize the image loader + */ + fun initializeImageLoader(context: Context) { + val maxImageCacheSize = PreferenceHelper.getInt( + PreferenceKeys.MAX_IMAGE_CACHE, + 128 + ) + + val diskCache = DiskCache.Builder() + .directory(context.filesDir.resolve("coil")) + .maxSizeBytes(maxImageCacheSize * 1024 * 1024L) + .build() + + imageLoader = ImageLoader.Builder(context) + .callFactory(CronetHelper.callFactory) + .diskCache(diskCache) + .build() + } + + /** + * load an image from a url into an imageView + */ + fun loadImage(url: String?, target: ImageView) { + // only load the image if the data saver mode is disabled + val dataSaverModeEnabled = PreferenceHelper.getBoolean( + PreferenceKeys.DATA_SAVER_MODE, + false + ) + if (!dataSaverModeEnabled) target.load(url, imageLoader) + } +} diff --git a/app/src/main/java/com/github/libretube/util/ConnectionHelper.kt b/app/src/main/java/com/github/libretube/util/NetworkHelper.kt similarity index 68% rename from app/src/main/java/com/github/libretube/util/ConnectionHelper.kt rename to app/src/main/java/com/github/libretube/util/NetworkHelper.kt index f4d15d6f5..98d61e5a8 100644 --- a/app/src/main/java/com/github/libretube/util/ConnectionHelper.kt +++ b/app/src/main/java/com/github/libretube/util/NetworkHelper.kt @@ -2,15 +2,11 @@ package com.github.libretube.util import android.content.Context import android.net.ConnectivityManager -import android.widget.ImageView -import coil.ImageLoader -import coil.load -import com.github.libretube.preferences.PreferenceHelper -import com.github.libretube.preferences.PreferenceKeys - -object ConnectionHelper { - lateinit var imageLoader: ImageLoader +object NetworkHelper { + /** + * Detect whether network is available + */ fun isNetworkAvailable(context: Context): Boolean { val connectivityManager = context.getSystemService(Context.CONNECTIVITY_SERVICE) as ConnectivityManager @@ -40,14 +36,4 @@ object ConnectionHelper { return connectivityManager.activeNetworkInfo?.isConnected ?: false } - - // load an image from a url into an imageView - fun loadImage(url: String?, target: ImageView) { - // only load the image if the data saver mode is disabled - val dataSaverModeEnabled = PreferenceHelper.getBoolean( - PreferenceKeys.DATA_SAVER_MODE, - false - ) - if (!dataSaverModeEnabled) target.load(url, imageLoader) - } } diff --git a/app/src/main/res/drawable/ic_cache.xml b/app/src/main/res/drawable/ic_cache.xml new file mode 100644 index 000000000..018572f36 --- /dev/null +++ b/app/src/main/res/drawable/ic_cache.xml @@ -0,0 +1,19 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/values/array.xml b/app/src/main/res/values/array.xml index 7488678f1..e4d0eff1c 100644 --- a/app/src/main/res/values/array.xml +++ b/app/src/main/res/values/array.xml @@ -858,4 +858,22 @@ fill + + 16MB + 32MB + 64MB + 128MB + 256MB + 512MB + + + + 16 + 32 + 64 + 128 + 256 + 512 + + \ No newline at end of file diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index a096ddd64..cb567d137 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -314,4 +314,5 @@ Backup Picture in Picture Resize mode + Max image cache size diff --git a/app/src/main/res/xml/advanced_settings.xml b/app/src/main/res/xml/advanced_settings.xml index 3a4d7413d..27a644e7e 100644 --- a/app/src/main/res/xml/advanced_settings.xml +++ b/app/src/main/res/xml/advanced_settings.xml @@ -40,6 +40,15 @@ app:key="data_saver_mode" app:title="@string/data_saver_mode" /> + +