diff options
author | daniel oeh <daniel.oeh@gmail.com> | 2012-09-21 13:31:54 +0200 |
---|---|---|
committer | daniel oeh <daniel.oeh@gmail.com> | 2012-09-21 13:31:54 +0200 |
commit | 81fbf3bcb67669c6320228912b7b4512ead10c24 (patch) | |
tree | 1b66c6dc49827b7261cae2c3bb2df765dbe086c9 /src | |
parent | ea7b7bbb731f21b2e60b4ddc4425037e95f8c2ac (diff) | |
download | AntennaPod-81fbf3bcb67669c6320228912b7b4512ead10c24.zip |
Auto-enqueue will now enqueue when the user starts the download
Diffstat (limited to 'src')
3 files changed, 20 insertions, 21 deletions
diff --git a/src/de/danoeh/antennapod/feed/FeedManager.java b/src/de/danoeh/antennapod/feed/FeedManager.java index 07b4ae6f7..a3ab901f9 100644 --- a/src/de/danoeh/antennapod/feed/FeedManager.java +++ b/src/de/danoeh/antennapod/feed/FeedManager.java @@ -10,6 +10,7 @@ import java.util.concurrent.Executors; import java.util.concurrent.ThreadFactory; import de.danoeh.antennapod.AppConfig; +import de.danoeh.antennapod.PodcastApp; import de.danoeh.antennapod.activity.AudioplayerActivity; import de.danoeh.antennapod.asynctask.DownloadStatus; import de.danoeh.antennapod.service.PlaybackService; @@ -25,6 +26,7 @@ import android.os.AsyncTask; import android.os.Debug; import android.os.Handler; import android.os.Message; +import android.preference.PreferenceManager; import android.util.Log; /** @@ -368,14 +370,28 @@ public class FeedManager { } public void downloadAllItemsInQueue(final Context context) { - DownloadRequester requester = DownloadRequester.getInstance(); - for (FeedItem item : queue) { + if (!queue.isEmpty()) { + downloadFeedItem(context, queue.toArray(new FeedItem[queue.size()])); + } + } + + public void downloadFeedItem(final Context context, FeedItem... items) { + boolean autoQueue = PreferenceManager.getDefaultSharedPreferences( + context.getApplicationContext()).getBoolean( + PodcastApp.PREF_AUTO_QUEUE, true); + List<FeedItem> addToQueue = new ArrayList<FeedItem>(); + + for (FeedItem item : items) { if (item.getMedia() != null && !requester.isDownloadingFile(item.getMedia()) && !item.getMedia().isDownloaded()) { requester.downloadMedia(context, item.getMedia()); + addToQueue.add(item); } } + if (autoQueue) { + addQueueItem(context, addToQueue.toArray(new FeedItem[addToQueue.size()])); + } } public void enqueueAllNewItems(final Context context) { diff --git a/src/de/danoeh/antennapod/service/download/DownloadService.java b/src/de/danoeh/antennapod/service/download/DownloadService.java index 734fab1ac..25cc1ee5a 100644 --- a/src/de/danoeh/antennapod/service/download/DownloadService.java +++ b/src/de/danoeh/antennapod/service/download/DownloadService.java @@ -694,24 +694,7 @@ public class DownloadService extends Service { saveDownloadStatus(status); sendDownloadHandledIntent(DOWNLOAD_TYPE_MEDIA); manager.setFeedMedia(DownloadService.this, media); - boolean autoQueue = PreferenceManager.getDefaultSharedPreferences( - getApplicationContext()).getBoolean( - PodcastApp.PREF_AUTO_QUEUE, true); - - if (!manager.isInQueue(media.getItem())) { - // Auto-queue - if (autoQueue) { - if (AppConfig.DEBUG) - Log.d(TAG, "Autoqueue is enabled. Adding item to queue"); - manager.addQueueItem(DownloadService.this, media.getItem()); - } else { - if (AppConfig.DEBUG) - Log.d(TAG, "Autoqueue is disabled"); - } - } else { - if (AppConfig.DEBUG) - Log.d(TAG, "Item is already in queue"); - } + downloadsBeingHandled -= 1; queryDownloads(); } diff --git a/src/de/danoeh/antennapod/util/menuhandler/FeedItemMenuHandler.java b/src/de/danoeh/antennapod/util/menuhandler/FeedItemMenuHandler.java index f1dd13dab..1120f8072 100644 --- a/src/de/danoeh/antennapod/util/menuhandler/FeedItemMenuHandler.java +++ b/src/de/danoeh/antennapod/util/menuhandler/FeedItemMenuHandler.java @@ -69,7 +69,7 @@ public class FeedItemMenuHandler { FeedManager manager = FeedManager.getInstance(); switch (item.getItemId()) { case R.id.download_item: - requester.downloadMedia(context, selectedItem.getMedia()); + manager.downloadFeedItem(context, selectedItem); break; case R.id.play_item: manager.playMedia(context, selectedItem.getMedia(), true, true, |