Added Downloads Activity

This commit is contained in:
Daniel Oeh 2012-05-31 12:21:58 +02:00
parent 7944ea0ba4
commit 278fbc224c
10 changed files with 168 additions and 30 deletions

View File

@ -2,33 +2,35 @@
<manifest xmlns:android="http://schemas.android.com/apk/res/android" <manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="de.podfetcher" package="de.podfetcher"
android:versionCode="1" android:versionCode="1"
android:versionName="1.0" > android:versionName="1.0" >
<!-- <uses-permission android:name="android.permission.ACCESS_ALL_DOWNLOADS" /> --> <!-- <uses-permission android:name="android.permission.ACCESS_ALL_DOWNLOADS" /> -->
<uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-sdk android:minSdkVersion="10" /> <uses-sdk android:minSdkVersion="10" />
<application <application
android:icon="@drawable/ic_launcher" android:icon="@drawable/ic_launcher"
android:label="@string/app_name" android:label="@string/app_name"
android:theme="@style/Theme.Sherlock.Light" android:theme="@style/Theme.Sherlock.Light"
android:name=".PodcastApp"> android:name=".PodcastApp">
<activity <activity
android:label="@string/app_name" android:label="@string/app_name"
android:name="de.podfetcher.activity.PodfetcherActivity" > android:name="de.podfetcher.activity.PodfetcherActivity" >
<intent-filter> <intent-filter>
<action android:name="android.intent.action.MAIN" /> <action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" /> <category android:name="android.intent.category.LAUNCHER" />
</intent-filter> </intent-filter>
</activity> </activity>
<activity android:name="de.podfetcher.activity.AddFeedActivity" <activity android:name="de.podfetcher.activity.AddFeedActivity"
android:label="@string/add_new_feed_label"/> android:label="@string/add_new_feed_label"/>
<activity android:name="de.podfetcher.activity.FeedItemlistActivity"/> <activity android:name="de.podfetcher.activity.FeedItemlistActivity"/>
<activity android:name="de.podfetcher.activity.ItemviewActivity"/> <activity android:name="de.podfetcher.activity.ItemviewActivity"/>
<activity android:name="de.podfetcher.activity.DownloadActivity"
<service android:enabled="true" android:name="de.podfetcher.service.DownloadService" /> android:label="@string/downloads_label"/>
<service android:enabled="true" android:name="de.podfetcher.service.PlaybackService" />
<service android:enabled="true" android:name="de.podfetcher.service.DownloadService" />
<service android:enabled="true" android:name="de.podfetcher.service.PlaybackService" />
</application> </application>
</manifest> </manifest>

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

View File

@ -0,0 +1,27 @@
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TextView
android:id="@+id/txtvTitle"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:textStyle="bold"/>
<RelativeLayout
android:layout_height="wrap_content"
android:layout_width="match_parent">
<TextView
android:id="@+id/txtvDownloaded"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:layout_alignParentLeft="true"/>
<TextView
android:id="@+id/txtvPercent"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:layout_alignParentRight="true"/>
</RelativeLayout>
</LinearLayout>

View File

@ -5,11 +5,17 @@
android:title="Add Feed" android:title="Add Feed"
android:icon="@drawable/content_new" android:icon="@drawable/content_new"
android:showAsAction="ifRoom"> android:showAsAction="ifRoom">
</item> </item>
<item <item
android:id="@+id/all_feed_refresh" android:id="@+id/all_feed_refresh"
android:title="Refresh" android:title="Refresh"
android:icon="@drawable/navigation_refresh" android:icon="@drawable/navigation_refresh"
android:showAsAction="ifRoom"> android:showAsAction="ifRoom">
</item> </item>
<item
android:id="@+id/show_downloads"
android:title="Downloads"
android:icon="@drawable/av_download"
android:showAsAction="ifRoom">
</item>
</menu> </menu>

View File

@ -6,6 +6,7 @@
<string name="feeds_label">Feeds</string> <string name="feeds_label">Feeds</string>
<string name="settings_label">Settings</string> <string name="settings_label">Settings</string>
<string name="add_new_feed_label">Add a new Feed</string> <string name="add_new_feed_label">Add a new Feed</string>
<string name="downloads_label">Downloads</string>
<!-- --> <!-- -->
<string name="confirm_label">Confirm</string> <string name="confirm_label">Confirm</string>

View File

@ -0,0 +1,41 @@
package de.podfetcher.activity;
import de.podfetcher.storage.DownloadRequester;
import de.podfetcher.adapter.DownloadlistAdapter;
import de.podfetcher.service.DownloadObserver;
import de.podfetcher.feed.FeedMedia;
import de.podfetcher.feed.FeedFile;
import com.actionbarsherlock.app.SherlockListActivity;
import android.os.Bundle;
public class DownloadActivity extends SherlockListActivity {
private static final String TAG = "DownloadActivity";
private DownloadlistAdapter dla;
private DownloadRequester requester;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requester = DownloadRequester.getInstance();
observer.execute(requester.getMediaDownloads().toArray(
new FeedFile[requester.getMediaDownloads().size()]));
}
private final DownloadObserver observer = new DownloadObserver(this) {
@Override
protected void onProgressUpdate(DownloadObserver.DownloadStatus... values) {
if (dla != null) {
dla.notifyDataSetChanged();
} else {
dla = new DownloadlistAdapter(getContext(), 0, getStatusList());
setListAdapter(dla);
dla.notifyDataSetChanged();
}
}
};
}

View File

@ -0,0 +1,55 @@
package de.podfetcher.adapter;
import android.widget.ArrayAdapter;
import android.widget.TextView;
import android.view.View;
import android.view.ViewGroup;
import android.view.LayoutInflater;
import android.content.Context;
import de.podfetcher.R;
import de.podfetcher.util.Converter;
import de.podfetcher.feed.FeedMedia;
import de.podfetcher.service.DownloadObserver;
public class DownloadlistAdapter extends ArrayAdapter<DownloadObserver.DownloadStatus> {
public DownloadlistAdapter(Context context,
int textViewResourceId, DownloadObserver.DownloadStatus[] objects) {
super(context, textViewResourceId, objects);
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
Holder holder;
DownloadObserver.DownloadStatus status = getItem(position);
// Inflate layout
if (convertView == null) {
holder = new Holder();
LayoutInflater inflater = (LayoutInflater) getContext().getSystemService(
Context.LAYOUT_INFLATER_SERVICE);
convertView = inflater.inflate(R.layout.downloadlist_item, null);
holder.title = (TextView) convertView.findViewById(R.id.txtvTitle);
holder.downloaded = (TextView) convertView.findViewById(R.id.txtvDownloaded);
holder.percent = (TextView) convertView.findViewById(R.id.txtvPercent);
convertView.setTag(holder);
} else {
holder = (Holder) convertView.getTag();
}
holder.title.setText( ((FeedMedia) status.getFeedFile()).getItem().getTitle());
holder.downloaded.setText(Converter.byteToString(status.getSoFar()) + " / "
+ Converter.byteToString(status.getSize()));
holder.percent.setText(status.getProgressPercent() + "%");
return convertView;
}
static class Holder {
TextView title;
TextView downloaded;
TextView percent;
}
}

View File

@ -76,6 +76,9 @@ public class FeedlistFragment extends SherlockListFragment {
case R.id.all_feed_refresh: case R.id.all_feed_refresh:
manager.refreshAllFeeds(pActivity); manager.refreshAllFeeds(pActivity);
return true; return true;
case R.id.show_downloads:
startActivity(new Intent(pActivity, DownloadActivity.class));
return true;
default: default:
return super.onOptionsItemSelected(item); return super.onOptionsItemSelected(item);
} }

View File

@ -62,7 +62,7 @@ public class DownloadObserver extends AsyncTask<FeedFile, DownloadObserver.Downl
if (status.done == false) { if (status.done == false) {
Cursor cursor = getDownloadCursor(status.feedfile); Cursor cursor = getDownloadCursor(status.feedfile);
int statusId = getDownloadStatus(cursor, DownloadManager.COLUMN_STATUS); int statusId = getDownloadStatus(cursor, DownloadManager.COLUMN_STATUS);
status.progressPercent = getDownloadProgress(cursor); getDownloadProgress(cursor, status);
switch(statusId) { switch(statusId) {
case DownloadManager.STATUS_SUCCESSFUL: case DownloadManager.STATUS_SUCCESSFUL:
status.statusMsg = R.string.download_successful; status.statusMsg = R.string.download_successful;
@ -91,6 +91,7 @@ public class DownloadObserver extends AsyncTask<FeedFile, DownloadObserver.Downl
Log.w(TAG, "Thread was interrupted while waiting."); Log.w(TAG, "Thread was interrupted while waiting.");
} }
} }
Log.d(TAG, "Background Task finished.");
return Boolean.valueOf(true); return Boolean.valueOf(true);
} }
@ -110,17 +111,16 @@ public class DownloadObserver extends AsyncTask<FeedFile, DownloadObserver.Downl
} }
} }
private int getDownloadProgress(Cursor c) { private void getDownloadProgress(Cursor c, DownloadStatus status) {
if (c.moveToFirst()) { if (c.moveToFirst()) {
long size = c.getLong(c.getColumnIndex(DownloadManager.COLUMN_TOTAL_SIZE_BYTES)); status.size = c.getLong(c.getColumnIndex(DownloadManager.COLUMN_TOTAL_SIZE_BYTES));
long soFar = c.getLong(c.getColumnIndex(DownloadManager.COLUMN_BYTES_DOWNLOADED_SO_FAR)); status.soFar = c.getLong(c.getColumnIndex(
int progress = (int) (((double) soFar / (double) size) * 100); DownloadManager.COLUMN_BYTES_DOWNLOADED_SO_FAR));
Log.d(TAG, "Setting progress to " + progress); status.progressPercent = (int) ((
return progress; (double) status.soFar / (double) status.size) * 100);
} else { Log.d(TAG, "Setting progress to " + status.progressPercent);
return -1; }
} }
}
private DownloadManager.Query buildQuery(long id) { private DownloadManager.Query buildQuery(long id) {
DownloadManager.Query query = new DownloadManager.Query(); DownloadManager.Query query = new DownloadManager.Query();

View File

@ -158,6 +158,9 @@ public class DownloadRequester {
images.remove(fi); images.remove(fi);
} }
public ArrayList<FeedFile> getMediaDownloads() {
return media;
}
/** Get the number of uncompleted Downloads */ /** Get the number of uncompleted Downloads */
public int getNumberOfDownloads() { public int getNumberOfDownloads() {