From 438c31692792fcd4045eb6c437eac1a086713460 Mon Sep 17 00:00:00 2001
From: ulrich
Date: Thu, 22 Apr 2021 15:39:33 +0000
Subject: [PATCH] Option -b des omxplayer entfernt
---
src/de/uhilger/avdirektor/App.java | 105 ++++++++++++++++++++++++++++++++--------------------
1 files changed, 65 insertions(+), 40 deletions(-)
diff --git a/src/de/uhilger/avdirektor/App.java b/src/de/uhilger/avdirektor/App.java
index c9552fc..33906d2 100644
--- a/src/de/uhilger/avdirektor/App.java
+++ b/src/de/uhilger/avdirektor/App.java
@@ -1,54 +1,63 @@
+/*
+ AV-Direktor - Control OMXPlayer on Raspberry Pi via HTTP
+ Copyright (C) 2021 Ulrich Hilger
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU Affero General Public License as
+ published by the Free Software Foundation, either version 3 of the
+ License, or (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU Affero General Public License for more details.
+
+ You should have received a copy of the GNU Affero General Public License
+ along with this program. If not, see <https://www.gnu.org/licenses/>.
+*/
+
package de.uhilger.avdirektor;
+import de.uhilger.avdirektor.handler.OMXPlayer;
+import de.uhilger.avdirektor.handler.Player;
+import de.uhilger.avdirektor.handler.VLCPlayer;
import java.io.IOException;
import java.util.HashMap;
import java.util.logging.Level;
import java.util.logging.Logger;
/**
- *
+ * Hauptklasse des av-director
+ *
+ * Aufruf mit
+ * java -jar av-director.jar port=9000
+ * java -jar av-director.jar nfs-prefix="/media/mc" port=9000
+ * java -Djava.util.logging.config.file=logging.properties -jar ..
+ *
+ * Der Parameter nfs-prefix bewirkt, dass beim Abspielen relative Pfade
+ * mit diesem Praefix verbunden werden und setzt voraus, dass auf der
+ * Maschine ein NFS-Mount ueber /etc/fstab eingerichtet ist.
+ *
* @author ulrich
+ * @version 0.1, 20.03.2021
*/
public class App {
private static final Logger logger = Logger.getLogger(App.class.getName());
-
- public static final String PI_PLAYER = "pi_player";
- //public static final String FBI_PROC = "fbi_proc";
+ public static final String IP_PORT = "port";
+ public static final String IP_WWW_DATA = "www-data";
+ public static final String IP_NFS_PREFIX = "nfs-prefix";
+ public static final String IP_PLAYER = "player";
+ public static final String VLC_PLAYER = "vlc";
+ public static final String OMX_PLAYER = "omx";
+ public static final String OMX_WD = "omx.wd";
- public static final String CMD_STOP = "q";
- public static final String CMD_DEC_SPEED = "1";
- public static final String CMD_INC_SPEED = "2";
- public static final String CMD_PREV_AUDIO = "j";
- public static final String CMD_NEXT_AUDIO = "k";
- public static final String CMD_PREV_CHAPTER = "i";
- public static final String CMD_NEXT_CHAPTER = "o";
- public static final String CMD_PREV_SUB = "n";
- public static final String CMD_NEXT_SUB = "m";
- public static final String CMD_TOGGLE_SUB = "s";
- public static final String CMD_PAUSE_RESUME = "p";
- public static final String CMD_DEC_VOL = "-";
- public static final String CMD_INC_VOL = "+";
- public static final String PFEIL_LINKS = "5b44";
- public static final String PFEIL_RECHTS = "5b43";
- public static final String PFEIL_HERAUF = "5b41";
- public static final String PFEIL_HERUNTER = "5b42";
-
- public static final String SP_RUECK_30 = "rueck30";
- public static final String SP_VOR_30 = "rueck30";
- public static final String SP_VOR_600 = "vor600";
- public static final String SP_RUECK_600 = "rueck600";
-
- public static final String OPT_LOCAL_AUDIO = "-o%20local";
- public static final String OPT_HDMI_AUDIO = "-o hdmi";
-
- public static final String BLANK = " ";
-
- private static HashMap initParams;
-
+ private static HashMap initParams;
private static Process playerproc;
+ private static Player player;
+
/**
* @param args the command line arguments
@@ -56,15 +65,20 @@
public static void main(String[] args) {
initParams = new HashMap();
for(String arg: args) {
- //logger.info("arg: " + arg);
String[] argParts = arg.split("=");
- //logger.info(argParts[0]);
- //logger.info(argParts[1]);
initParams.put(argParts[0], argParts[1]);
}
-
-
- Server server = new Server(Integer.parseInt(getInitParameter("port")));
+
+ String playerType = getInitParameter(IP_PLAYER);
+ switch(playerType) {
+ case VLC_PLAYER:
+ player = new VLCPlayer();
+ break;
+ case OMX_PLAYER:
+ player = new OMXPlayer();
+ break;
+ }
+ Server server = new Server(Integer.parseInt(getInitParameter(IP_PORT)));
try {
server.start();
} catch (IOException ex) {
@@ -92,4 +106,15 @@
public static void setPlayerProcess(Process p) {
playerproc = p;
}
+
+ public static Player getPlayer() {
+ return player;
+ }
+
+ public static void setPlayer(Player pl) {
+ player = pl;
+ }
+
+
+
}
--
Gitblit v1.9.3