diff options
author | lado <herrlado@gmail.com> | 2012-06-13 12:49:09 +0200 |
---|---|---|
committer | lado <herrlado@gmail.com> | 2012-06-13 12:49:09 +0200 |
commit | 27bba584b9945d158671d377809f9d8477e38e56 (patch) | |
tree | a45fc769d4bf3abe5cbdcaae8749e321d20103dc /vdrmanager/src/de/bjusystems | |
parent | ed7871848a0cf9dc96b0d2034b3793c23159357e (diff) | |
download | vdr-manager-27bba584b9945d158671d377809f9d8477e38e56.tar.gz vdr-manager-27bba584b9945d158671d377809f9d8477e38e56.tar.bz2 |
switch to channel
Diffstat (limited to 'vdrmanager/src/de/bjusystems')
-rw-r--r-- | vdrmanager/src/de/bjusystems/vdrmanager/gui/Utils.java | 42 |
1 files changed, 41 insertions, 1 deletions
diff --git a/vdrmanager/src/de/bjusystems/vdrmanager/gui/Utils.java b/vdrmanager/src/de/bjusystems/vdrmanager/gui/Utils.java index 8b95bf4..e7832bb 100644 --- a/vdrmanager/src/de/bjusystems/vdrmanager/gui/Utils.java +++ b/vdrmanager/src/de/bjusystems/vdrmanager/gui/Utils.java @@ -23,6 +23,7 @@ import android.text.TextUtils; import android.text.style.ForegroundColorSpan; import android.util.Log; import android.util.Pair; +import android.view.Gravity; import android.widget.Toast; import de.bjusystems.vdrmanager.R; import de.bjusystems.vdrmanager.app.C; @@ -31,6 +32,11 @@ import de.bjusystems.vdrmanager.data.Event; import de.bjusystems.vdrmanager.data.EventFormatter; import de.bjusystems.vdrmanager.data.Preferences; import de.bjusystems.vdrmanager.data.Recording; +import de.bjusystems.vdrmanager.utils.svdrp.SvdrpAsyncListener; +import de.bjusystems.vdrmanager.utils.svdrp.SvdrpAsyncTask; +import de.bjusystems.vdrmanager.utils.svdrp.SvdrpEvent; +import de.bjusystems.vdrmanager.utils.svdrp.SvdrpException; +import de.bjusystems.vdrmanager.utils.svdrp.SwitchChannelClient; public class Utils { @@ -39,8 +45,8 @@ public class Utils { public static final List EMPTY_LIST = new ArrayList(0); public static final String[] EMPTY = new String[] {}; - public static final ForegroundColorSpan HIGHLIGHT_TEXT = new ForegroundColorSpan( + Color.RED); public static CharSequence highlight(String where, String what) { @@ -314,4 +320,38 @@ public class Utils { Log.d(TAG, "try stream: " + urlstring); Utils.startStream(ctx, url.toString()); } + + public static void switchTo(final Context ctx , final Channel channel){ + switchTo(ctx, channel.getId(), channel.getName()); + } + /** + * @param ctx + * @param id + * @param name Optional für die Anzeige + */ + public static void switchTo(final Context ctx , final String id, final String name){ + + final SwitchChannelClient scc = new SwitchChannelClient(id); + SvdrpAsyncTask<String, SwitchChannelClient> task = new SvdrpAsyncTask<String, SwitchChannelClient>(scc); + task.addListener(new SvdrpAsyncListener<String>() { + public void svdrpEvent(SvdrpEvent event, String result) { + if(event == SvdrpEvent.FINISHED_SUCCESS){ + Utils.say(ctx, ctx.getString(R.string.switching_success, (name != null ? name : id ))); + } else if(event == SvdrpEvent.CONNECT_ERROR || event == SvdrpEvent.FINISHED_ABNORMALY || event == SvdrpEvent.ABORTED || event == SvdrpEvent.ERROR || event == SvdrpEvent.CACHE_HIT){ + Utils.say(ctx, ctx.getString(R.string.switching_failed, (name != null ? name : id ), event.name())); + } + } + public void svdrpException(SvdrpException e) { + Log.w(TAG, e.getMessage(), e); + Utils.say(ctx, e.getMessage()); + } + }); + task.run(); + } + + public static void say(Context ctx, String msg) { + Toast t = Toast.makeText(ctx, msg, Toast.LENGTH_SHORT); + t.setGravity(Gravity.CENTER, 0, 0); + t.show(); + } } |