summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--vdrmanager/src/de/bjusystems/vdrmanager/data/Preferences.java99
-rw-r--r--vdrmanager/src/de/bjusystems/vdrmanager/data/Recording.java24
-rw-r--r--vdrmanager/src/de/bjusystems/vdrmanager/gui/Utils.java51
3 files changed, 104 insertions, 70 deletions
diff --git a/vdrmanager/src/de/bjusystems/vdrmanager/data/Preferences.java b/vdrmanager/src/de/bjusystems/vdrmanager/data/Preferences.java
index 84cc0d4..85394ba 100644
--- a/vdrmanager/src/de/bjusystems/vdrmanager/data/Preferences.java
+++ b/vdrmanager/src/de/bjusystems/vdrmanager/data/Preferences.java
@@ -13,9 +13,9 @@ import de.bjusystems.vdrmanager.data.db.DBAccess;
/**
* Class for all preferences
- *
+ *
* @author bju, lado
- *
+ *
*/
public class Preferences {
@@ -41,12 +41,12 @@ public class Preferences {
public int getCurrentVdrContext(Context context){
return getInteger(context, R.string.current_vdr_id_key, -1);
}
-
+
/** user defined epg search times */
private String epgSearchTimes;
/**
* format times AM/PM or 24H
- *
+ *
* @since 0.2
*/
private boolean use24hFormat;
@@ -137,7 +137,7 @@ public class Preferences {
/**
* Whether to send Packets to the custom broadcast address. It is used, if
* the address ist not empty
- *
+ *
* @return
* @since 0.2
*/
@@ -147,7 +147,7 @@ public class Preferences {
/**
* Getter for use24hFormat
- *
+ *
* @since 0.2
* @return
*/
@@ -157,7 +157,7 @@ public class Preferences {
/**
* Checks for connect using SSL
- *
+ *
* @return true, if use SSL connections
*/
public boolean isSecure() {
@@ -166,7 +166,7 @@ public class Preferences {
/**
* Retrieves the channel filtering mode
- *
+ *
* @return true, if channels will be filtered
*/
public boolean isFilterChannels() {
@@ -175,7 +175,7 @@ public class Preferences {
/**
* Last channel to receive
- *
+ *
* @return channel number
*/
public String getChannels() {
@@ -184,7 +184,7 @@ public class Preferences {
/**
* Gets the SVDRP host or IP address
- *
+ *
* @return SVDRP host
*/
public String getSvdrpHost() {
@@ -193,7 +193,7 @@ public class Preferences {
/**
* Gets the SVDRP port
- *
+ *
* @return SVDRP port
*/
public int getSvdrpPort() {
@@ -202,7 +202,7 @@ public class Preferences {
/**
* Gets the SVDRP password
- *
+ *
* @return SVDRO password
*/
public String getPassword() {
@@ -215,7 +215,7 @@ public class Preferences {
/**
* Checks for enables remote wakeup
- *
+ *
* @return true, if remote wakeup is enabled
*/
public boolean isWakeupEnabled() {
@@ -224,7 +224,7 @@ public class Preferences {
/**
* Gets the URL for the wakeup request
- *
+ *
* @return wakeup url
*/
public String getWakeupUrl() {
@@ -233,7 +233,7 @@ public class Preferences {
/**
* Gets the user for the wakeup url
- *
+ *
* @return user name
*/
public String getWakeupUser() {
@@ -242,7 +242,7 @@ public class Preferences {
/**
* Gets the password for the wakeup url
- *
+ *
* @return password
*/
public String getWakeupPassword() {
@@ -251,7 +251,7 @@ public class Preferences {
/**
* Checks for enabled alive check
- *
+ *
* @return true, if enabled
*/
public boolean isAliveCheckEnabled() {
@@ -268,7 +268,7 @@ public class Preferences {
/**
* Gets the time between alive checks
- *
+ *
* @return time in seconds
*/
public int getAliveCheckInterval() {
@@ -277,7 +277,7 @@ public class Preferences {
/**
* Gets the buffer before the event start
- *
+ *
* @return pre event buffer
*/
public int getTimerPreMargin() {
@@ -286,7 +286,7 @@ public class Preferences {
/**
* Gets the buffer after the event stop
- *
+ *
* @return post event buffer
*/
public int getTimerPostMargin() {
@@ -295,7 +295,7 @@ public class Preferences {
/**
* Gets the default priority
- *
+ *
* @return default priority
*/
public int getTimerDefaultPriority() {
@@ -304,7 +304,7 @@ public class Preferences {
/**
* Gets the default lifetime
- *
+ *
* @return default lifetime
*/
public int getTimerDefaultLifetime() {
@@ -313,7 +313,7 @@ public class Preferences {
/**
* Gets the time values for the epg search
- *
+ *
* @return
*/
public String getEpgSearchTimes() {
@@ -322,7 +322,7 @@ public class Preferences {
/**
* gets the MAC Address of the vdr host
- *
+ *
* @return
* @since 0.2
*/
@@ -332,7 +332,7 @@ public class Preferences {
/**
* Gets the selection which wakeup method to use
- *
+ *
* @return
* @since 0.2
*/
@@ -342,7 +342,7 @@ public class Preferences {
/**
* Getter for streaming port
- *
+ *
* @return
* @since 02.
*/
@@ -352,7 +352,7 @@ public class Preferences {
/**
* Getter for selected streaming format
- *
+ *
* @return
* @since 0.2
*/
@@ -362,7 +362,7 @@ public class Preferences {
/**
* Sets the time values for the epg search
- *
+ *
* @param epgSearchTimes
* new time values
*/
@@ -381,7 +381,7 @@ public class Preferences {
/**
* Gets the name for the file which preferences will be saved into
- *
+ *
* @param context
* Context
* @return filename
@@ -392,7 +392,7 @@ public class Preferences {
/**
* Show Channel Numbers in the overviews
- *
+ *
* @since 0.2
* @return
*/
@@ -402,7 +402,7 @@ public class Preferences {
/**
* getter
- *
+ *
* @return
*/
public boolean isEnableRemux() {
@@ -411,7 +411,7 @@ public class Preferences {
/**
* getter
- *
+ *
* @return
*/
public String getRemuxCommand() {
@@ -420,7 +420,7 @@ public class Preferences {
/**
* getter
- *
+ *
* @return
*/
public String getRemuxParameter() {
@@ -429,7 +429,7 @@ public class Preferences {
/**
* getter
- *
+ *
* @return
*/
public boolean isQuiteOnBackButton() {
@@ -438,17 +438,22 @@ public class Preferences {
/**
* Gets the previous loaded preferences
- *
+ *
* @return preferences
*/
public static Preferences getPreferences() {
return thePrefs;
}
+ public String getRecStreamMethod(){
+ return getCurrentVdr().getRecStreamMethod();
+ }
+
+
/**
- *
+ *
* Gets the previous loaded preferences, same as getPreferences();
- *
+ *
* @return
*/
public static Preferences get() {
@@ -501,7 +506,7 @@ public class Preferences {
}
public static boolean initVDR(final Context context) {
-
+
if (current != null) {
return true;
}
@@ -513,8 +518,8 @@ public class Preferences {
vdr = DBAccess.get(context).getVdrDAO().queryForId(id);
}
- setCurrentVdr(context, vdr);
-
+ setCurrentVdr(context, vdr);
+
if (vdr != null) {
return true;
}
@@ -525,7 +530,7 @@ public class Preferences {
setCurrentVdr(context, vdr);
return true;
}
-
+
return initFromOldVersion(context);
//Intent intent = new Intent();
//intent.setClass(context, VdrListActivity.class);
@@ -537,7 +542,7 @@ public class Preferences {
/**
* Loads all preferences
- *
+ *
* @param context
* Context
* @return Preferences
@@ -633,7 +638,7 @@ public class Preferences {
/**
* Gets the persistent preferences
- *
+ *
* @param context
* Context
* @return preferences
@@ -645,7 +650,7 @@ public class Preferences {
/**
* Helper for retrieving integer values from preferences
- *
+ *
* @param context
* Context
* @param resId
@@ -665,7 +670,7 @@ public class Preferences {
/**
* Helper for retrieving boolean values from preferences
- *
+ *
* @param context
* Context
* @param resId
@@ -682,7 +687,7 @@ public class Preferences {
/**
* Helper for retrieving string values from preferences
- *
+ *
* @param context
* Context
* @param resId
@@ -712,7 +717,7 @@ public class Preferences {
/**
* Set locale read from preferences to context.
- *
+ *
* @param context
* {@link Context}
*/
diff --git a/vdrmanager/src/de/bjusystems/vdrmanager/data/Recording.java b/vdrmanager/src/de/bjusystems/vdrmanager/data/Recording.java
index 26c3ca4..94a60f7 100644
--- a/vdrmanager/src/de/bjusystems/vdrmanager/data/Recording.java
+++ b/vdrmanager/src/de/bjusystems/vdrmanager/data/Recording.java
@@ -9,7 +9,7 @@ import de.bjusystems.vdrmanager.app.C;
import static de.bjusystems.vdrmanager.gui.Utils.mapSpecialChars;
public class Recording extends Event{
-
+
public Recording(String line) {
final String[] words = StringUtils.splitPreserveAllTokens(line, C.DATA_SEPARATOR);
int idx = 0;
@@ -28,16 +28,30 @@ public class Recording extends Event{
if(idx < words.length){
realDuration = Long.parseLong(words[idx++]) * 1000;
}
+
+ if(idx < words.length){
+ devInode = mapSpecialChars(words[idx++]);
+ }
}
-
+
private String fileName;
private int fileSize;
-
+
private int index;
-
+
private long realDuration = -1;
+ private String devInode = null;
+
+ public String getDevInode() {
+ return devInode;
+ }
+
+ public void setDevInode(String devInode) {
+ this.devInode = devInode;
+ }
+
/**
* in millis
* @return
@@ -45,7 +59,7 @@ public class Recording extends Event{
public long getRealDuration() {
return realDuration;
}
-
+
public long getDuration(){
if(realDuration != -1){
return realDuration;
diff --git a/vdrmanager/src/de/bjusystems/vdrmanager/gui/Utils.java b/vdrmanager/src/de/bjusystems/vdrmanager/gui/Utils.java
index 842de8a..bd3dc7a 100644
--- a/vdrmanager/src/de/bjusystems/vdrmanager/gui/Utils.java
+++ b/vdrmanager/src/de/bjusystems/vdrmanager/gui/Utils.java
@@ -27,6 +27,7 @@ import android.util.Pair;
import android.view.Gravity;
import android.widget.Toast;
import de.bjusystems.vdrmanager.R;
+import de.bjusystems.vdrmanager.StringUtils;
import de.bjusystems.vdrmanager.app.C;
import de.bjusystems.vdrmanager.data.Channel;
import de.bjusystems.vdrmanager.data.Event;
@@ -249,9 +250,6 @@ public class Utils {
return minuts;
}
-
-
-
public static void shareEvent(Activity activity, Event event) {
final Intent share = new Intent(android.content.Intent.ACTION_SEND);
share.setType("text/plain");
@@ -275,8 +273,7 @@ public class Utils {
activity.getString(R.string.share_chooser)));
}
-
- public static void addCalendarEvent(Activity activity, Event event){
+ public static void addCalendarEvent(Activity activity, Event event) {
Intent intent = new Intent(Intent.ACTION_EDIT);
intent.setType("vnd.android.cursor.item/event");
intent.putExtra("title", event.getTitle());
@@ -286,7 +283,6 @@ public class Utils {
activity.startActivity(intent);
}
-
public static String mapSpecialChars(String src) {
if (src == null) {
return "";
@@ -323,21 +319,40 @@ public class Utils {
return false;
}
- public static void streamRecording(Activity ctx, Recording rec) {
+ private static String getRecordingStream(Activity ctx, Recording rec) {
+
+ String m = Preferences.get().getRecStreamMethod();
StringBuilder url = new StringBuilder();
- url.append("http://")
- .append(Preferences.get().getSvdrpHost())
- //
- .append(":")
- .append(Integer.valueOf(Preferences.get().getLivePort()))
- //
- .append("/recstream.html?recid=recording_")
- .append(Utils.md5(rec.getFileName()));
- // http://192.168.1.119:8008/b0cdedeed2d36508dfd924f0876a851b
- String urlstring = url.toString();
+
+ if (StringUtils.equals(m, "vdr-live")) {
+ url.append("http://")
+ .append(Preferences.get().getSvdrpHost())
+ //
+ .append(":")
+ .append(Integer.valueOf(Preferences.get().getLivePort()))
+ //
+ .append("/recstream.html?recid=recording_")
+ .append(Utils.md5(rec.getFileName()));
+ // http://192.168.1.119:8008/b0cdedeed2d36508dfd924f0876a851b
+ String urlstring = url.toString();
+ return urlstring;
+ } else if (StringUtils.equals(m, "vdr-streamdev")) {
+ url.append("http://")
+ .append(Preferences.get().getSvdrpHost())
+ //
+ .append(":")
+ .append(Integer.valueOf(Preferences.get().getStreamPort()))
+ //
+ .append("/").append(rec.getDevInode());
+ }
+ return url.toString();
+ }
+
+ public static void streamRecording(Activity ctx, Recording rec) {
+ String urlstring = getRecordingStream(ctx, rec);
Log.d(TAG, "try stream: " + urlstring);
- Utils.startStream(ctx, url.toString());
+ Utils.startStream(ctx, urlstring);
}
public static void switchTo(final Context ctx, final Channel channel) {