diff options
-rw-r--r-- | vdrmanager/res/layout/epg_detail.xml | 30 | ||||
-rw-r--r-- | vdrmanager/res/values/common.xml | 2 | ||||
-rw-r--r-- | vdrmanager/res/values/epg.xml | 1 | ||||
-rw-r--r-- | vdrmanager/res/values/progress.xml | 1 | ||||
-rw-r--r-- | vdrmanager/src/de/bjusystems/vdrmanager/gui/EpgDetailsActivity.java | 184 |
5 files changed, 146 insertions, 72 deletions
diff --git a/vdrmanager/res/layout/epg_detail.xml b/vdrmanager/res/layout/epg_detail.xml index bc64690..b7761be 100644 --- a/vdrmanager/res/layout/epg_detail.xml +++ b/vdrmanager/res/layout/epg_detail.xml @@ -51,17 +51,24 @@ </LinearLayout> - + <LinearLayout android:layout_width="fill_parent" android:padding="3dip" android:paddingBottom="1dip" + android:layout_height="wrap_content" android:layout_marginTop="0dip" + android:orientation="horizontal"> + + <ImageView android:id="@+id/epg_timer_state" android:layout_marginRight="5dip" + android:layout_width="wrap_content" android:layout_height="fill_parent" + android:layout_centerVertical="true" android:visibility="gone" /> + <TextView android:id="@+id/epg_detail_shorttext" android:layout_width="fill_parent" android:layout_height="wrap_content" android:gravity="left" + android:layout_weight="1" android:text="Krimikömedie" - android:textAppearance="?android:textAppearanceSmall" - android:layout_below="@id/epg_detail_time"/> - - + android:textAppearance="?android:textAppearanceSmall"/> + + </LinearLayout> <TextView @@ -153,6 +160,19 @@ style="?android:attr/buttonStyleSmall" android:text="@string/epg_event_imdb_text"/> + + <!-- + <ImageButton + android:id="@+id/epg_event_share" + android:src="@android:drawable/ic_menu_share" + android:layout_width="wrap_content" + android:layout_height="wrap_content" android:layout_marginLeft="20dip" android:layout_marginRight="20dip" + android:layout_gravity="center_horizontal" + android:layout_centerHorizontal="true" + android:background="@android:drawable/list_selector_background" + style="?android:attr/buttonStyleSmall" + android:text="@string/epg_event_share_text"/> + --> <!-- <ImageButton diff --git a/vdrmanager/res/values/common.xml b/vdrmanager/res/values/common.xml index 340b42b..9d1670e 100644 --- a/vdrmanager/res/values/common.xml +++ b/vdrmanager/res/values/common.xml @@ -7,4 +7,6 @@ <string name="no_connection_retry">Retry</string> <string name="refresh">Refresh</string> <string name="done">Done</string> + <string name="share">Share</string> + <string name="share_chooser">Share EPG Entry</string> </resources> diff --git a/vdrmanager/res/values/epg.xml b/vdrmanager/res/values/epg.xml index db84fdd..3936bf4 100644 --- a/vdrmanager/res/values/epg.xml +++ b/vdrmanager/res/values/epg.xml @@ -9,6 +9,7 @@ <string name="epg_list_search_label">Search results</string> <!-- create timer --> + <string name="epg_event_share_text">Share</string> <string name="epg_event_imdb_text">IMDB Search</string> <string name="epg_eent_livetv_text">Stream</string> <string name="epg_event_create_timer_text">Add timer</string> diff --git a/vdrmanager/res/values/progress.xml b/vdrmanager/res/values/progress.xml index 8007725..0f27c03 100644 --- a/vdrmanager/res/values/progress.xml +++ b/vdrmanager/res/values/progress.xml @@ -16,6 +16,7 @@ <string name="progress_wakeup_error">Error sending wakeup request: %1$s</string> <string name="progress_timer_save">Saving timer …</string> <string name="progress_timer_delete">Deleting timer …</string> + <string name="progress_recording_delete">Deleting recording …</string> <string name="progress_timer_enable">Enabling timer …</string> <string name="progress_timer_modify">Updating timer …</string> <string name="progress_timer_disable">Disabling timer …</string> diff --git a/vdrmanager/src/de/bjusystems/vdrmanager/gui/EpgDetailsActivity.java b/vdrmanager/src/de/bjusystems/vdrmanager/gui/EpgDetailsActivity.java index b0a7c01..ca492d5 100644 --- a/vdrmanager/src/de/bjusystems/vdrmanager/gui/EpgDetailsActivity.java +++ b/vdrmanager/src/de/bjusystems/vdrmanager/gui/EpgDetailsActivity.java @@ -8,10 +8,16 @@ import android.content.Intent; import android.net.Uri; import android.os.AsyncTask; import android.os.Bundle; +import android.view.ContextMenu; +import android.view.Menu; +import android.view.MenuItem; import android.view.MotionEvent; import android.view.View; +import android.view.ContextMenu.ContextMenuInfo; import android.view.View.OnClickListener; +import android.widget.AdapterView; import android.widget.ImageButton; +import android.widget.ImageView; import android.widget.ProgressBar; import android.widget.TextView; import android.widget.Toast; @@ -22,9 +28,11 @@ import de.bjusystems.vdrmanager.data.Channel; import de.bjusystems.vdrmanager.data.Epg; import de.bjusystems.vdrmanager.data.Event; import de.bjusystems.vdrmanager.data.EventFormatter; +import de.bjusystems.vdrmanager.data.EventListItem; import de.bjusystems.vdrmanager.data.Preferences; import de.bjusystems.vdrmanager.data.Timer; import de.bjusystems.vdrmanager.gui.SimpleGestureFilter.SimpleGestureListener; +import de.bjusystems.vdrmanager.utils.date.DateFormatter; import de.bjusystems.vdrmanager.utils.svdrp.EpgClient; import de.bjusystems.vdrmanager.utils.svdrp.SvdrpException; @@ -37,79 +45,83 @@ public class EpgDetailsActivity extends Activity implements OnClickListener, SimpleGestureListener { public static String IMDB_URL = "http://www.%s/find?s=all&q=%s"; - + private SimpleGestureFilter detector; - + private String highlight = null; - + ImageButton event_left; - + ImageButton event_right; - + + Event cEvent; + @Override protected void onCreate(final Bundle savedInstanceState) { super.onCreate(savedInstanceState); - Intent i = getIntent(); - highlight = i.getStringExtra(Intents.HIGHLIGHT); - + Intent i = getIntent(); + highlight = i.getStringExtra(Intents.HIGHLIGHT); + // Attach view setContentView(R.layout.epg_detail); - - + detector = new SimpleGestureFilter(this, this); - //event_left = (ImageButton) findViewById(R.id.epg_event_left); - //event_right = (ImageButton) findViewById(R.id.epg_event_right); - - + // event_left = (ImageButton) findViewById(R.id.epg_event_left); + // event_right = (ImageButton) findViewById(R.id.epg_event_right); + // current event final VdrManagerApp app = (VdrManagerApp) getApplication(); epgs = app.getCurrentEpgList(); Event epg = app.getCurrentEvent(); - - + counter = 0; - for(Event e : epgs){ - if(epg == e){ + for (Event e : epgs) { + if (epg == e) { break; } counter++; } - - - new AsyncTask<Void,Void,Void>(){ - + new AsyncTask<Void, Void, Void>() { + protected void onPreExecute() { -// event_left.setEnabled(false); - // event_right.setEnabled(false); + // event_left.setEnabled(false); + // event_right.setEnabled(false); }; - - protected Void doInBackground(Void... params) { + + protected Void doInBackground(Void... params) { initEPGs(); return null; }; - + protected void onPostExecute(Void result) { - // event_left.setEnabled(true); - // event_right.setEnabled(true); + // event_left.setEnabled(true); + // event_right.setEnabled(true); }; - - }.execute((Void)null); + + }.execute((Void) null); publishEPG(epg); - - //TODO was ist das? + + // TODO was ist das? app.clearActivitiesToFinish(); } + private void setState(ImageView view, int res) { + view.setVisibility(View.VISIBLE); + view.setImageResource(res); + } + public void publishEPG(Event event) { - + + cEvent = event; + String cn = event.getChannelName(); - - setTitle(getString(R.string.epg_of_a_channel,cn)); - + + setTitle(getString(R.string.epg_of_a_channel, cn)); + final EventFormatter formatter = new EventFormatter(event); final TextView title = (TextView) findViewById(R.id.epg_detail_title); @@ -120,18 +132,30 @@ public class EpgDetailsActivity extends Activity implements OnClickListener, ((TextView) findViewById(R.id.epg_detail_time)).setText(formatter .getDate() + " " + formatter.getTime()); - + TextView dura = (TextView) findViewById(R.id.epg_detail_duration); - + ((TextView) findViewById(R.id.epg_detail_channel)).setText(event .getChannelName()); - //((TextView) findViewById(R.id.epg_detail_date)).setText(formatter - // .getLongDate()); - + // ((TextView) findViewById(R.id.epg_detail_date)).setText(formatter + // .getLongDate()); + ImageView state = (ImageView) findViewById(R.id.epg_timer_state); + + switch (event.getTimerState()) { + case Active: + setState(state, R.drawable.timer_active); + break; + case Inactive: + setState(state, R.drawable.timer_inactive); + break; + case Recording: + setState(state, R.drawable.timer_recording); + break; + } + final TextView shortText = (TextView) findViewById(R.id.epg_detail_shorttext); shortText.setText(Utils.highlight(formatter.getShortText(), highlight)); - final TextView textView = (TextView) findViewById(R.id.epg_detail_description); textView.setText(Utils.highlight(formatter.getDescription(), highlight)); @@ -141,13 +165,13 @@ public class EpgDetailsActivity extends Activity implements OnClickListener, // .setBackgroundColor(color); int p = Utils.getProgress(event); - - ((ProgressBar) findViewById(R.id.epg_detail_progress)) - .setProgress(p); + + ((ProgressBar) findViewById(R.id.epg_detail_progress)).setProgress(p); int dm = Utils.getDuration(event); - if(Utils.isLive(event)){ + if (Utils.isLive(event)) { int rest = dm - (dm * p / 100); - dura.setText(getString(R.string.epg_duration_template_live, rest, dm)); + dura.setText(getString(R.string.epg_duration_template_live, rest, + dm)); } else { dura.setText(getString(R.string.epg_duration_template, dm)); } @@ -157,17 +181,16 @@ public class EpgDetailsActivity extends Activity implements OnClickListener, // register button handler setThisAsOnClickListener(R.id.epg_event_create_timer); - - + View b = findViewById(R.id.epg_event_imdb); - - if(Preferences.get().isShowImdbButton() == false){ + + if (Preferences.get().isShowImdbButton() == false) { b.setVisibility(View.GONE); } else { b.setVisibility(View.VISIBLE); setThisAsOnClickListener(b); } - + b = findViewById(R.id.epg_event_livetv); if (Utils.isLive(event) == false) { b.setVisibility(View.GONE); @@ -175,8 +198,8 @@ public class EpgDetailsActivity extends Activity implements OnClickListener, b.setVisibility(View.VISIBLE); setThisAsOnClickListener(b); } -// setThisAsOnClickListener(R.id.epg_event_left); -// setThisAsOnClickListener(R.id.epg_event_right); + // setThisAsOnClickListener(R.id.epg_event_left); + // setThisAsOnClickListener(R.id.epg_event_right); // set button text if (event instanceof Timer) { @@ -200,9 +223,9 @@ public class EpgDetailsActivity extends Activity implements OnClickListener, @Override protected void onResume() { super.onResume(); - //TODO Check here whether the config has changed for imdb - //TODO check here if we are still live ? - + // TODO Check here whether the config has changed for imdb + // TODO check here if we are still live ? + } @Override @@ -211,23 +234,26 @@ public class EpgDetailsActivity extends Activity implements OnClickListener, } public void onClick(final View v) { - - final VdrManagerApp app = (VdrManagerApp) getApplication(); switch (v.getId()) { case R.id.epg_event_livetv: - Event event = app.getCurrentEvent(); - Utils.stream(this, event.getChannelNumber()); + Utils.stream(this, cEvent.getChannelNumber()); break; case R.id.epg_event_create_timer: - Toast.makeText(this, "Soon we get here the timer menu", Toast.LENGTH_SHORT).show(); + Toast.makeText(this, "Soon we get here the timer menu", + Toast.LENGTH_SHORT).show(); break; case R.id.epg_event_imdb: final TextView title = (TextView) findViewById(R.id.epg_detail_title); - String url = String.format(IMDB_URL,Preferences.get().getImdbUrl(), String.valueOf(title.getText())); + String url = String.format(IMDB_URL, + Preferences.get().getImdbUrl(), + String.valueOf(title.getText())); Intent i = new Intent(Intent.ACTION_VIEW); i.setData(Uri.parse(url)); startActivity(i); break; +// case R.id.epg_event_share: +// shareEvent(cEvent); +// break; } } @@ -258,7 +284,7 @@ public class EpgDetailsActivity extends Activity implements OnClickListener, int counter = 0; public void initEPGs() { - + if (epgs != null) { return; } @@ -299,8 +325,8 @@ public class EpgDetailsActivity extends Activity implements OnClickListener, } private void nextEPG() { - if(counter < epgs.size() - 1){ - counter ++ ; + if (counter < epgs.size() - 1) { + counter++; } Event epg = epgs.get(counter); publishEPG(epg); @@ -316,4 +342,28 @@ public class EpgDetailsActivity extends Activity implements OnClickListener, return super.dispatchTouchEvent(me); } + private static final int MENU_SHARE = 0; + + @Override + public final boolean onCreateOptionsMenu(final Menu menu) { + super.onCreateOptionsMenu(menu); + MenuItem item; + item = menu.add(MENU_SHARE, MENU_SHARE, 0, R.string.share); + item.setIcon(android.R.drawable.ic_menu_share); + item.setAlphabeticShortcut('s'); + return true; + } + + private void shareEvent(Event event) { + Utils.shareEvent(this, event); + } + + @Override + public boolean onOptionsItemSelected(MenuItem item) { + if (item.getItemId() == MENU_SHARE) { + shareEvent(cEvent); + return true; + } + return super.onOptionsItemSelected(item); + } } |