Streaming από το PC - προβλημα

stsalkit

Established Member
11 December 2008
160
Φοράω το καινούρφιο Gemini 4.20 Εχω κάνει mount τον σκληρό δίσκο του PC μέσω ethernet. Το κουτί βλέπει κανονικά τις ταινίες (mpg) που έχω στον σκληρό μέσω του πλήκτρου video (το νέο gemini στερείται media player). Το πρόβλημα είναι ότι όταν παίζει το επιλεγμένο video, έχω συνεχή σπασίματα στην εικόνα και ήχο, λές και δεν έχει αρκετή ταχύτητα μετάδοσης σε σημείο που δεν μπορείς να δεις ταινία. Εχει κανείς κάποια ιδέα τι μπορεί να φταίει? υπάρχει κάποια ρύθμιση στο κουτί ή το PC (Vista)?
Ευχαριστώ.
 
1. Δημιούργησα έναν καινούργιο χρήστη στο PC με administrator rights και password (π.χ. χρήστης = dbox, password = dbox)
2. Δημιούργησα στο C: ένα φάκελλο (π.χ C:\db), όπου έβαλα τα videos. Εφτιαξα και subfolders για να τα χωρίσω σε κατηγορίες.
3. Μπήκα στα properties του C:\db και στο sharing έδωσα co-owner rights στον "χρήστη" dbox. Για τους υποφακέλους δεν χρειάζεται φυσικά
Αυτά στο PC. Στον dm800 τώρα:
1. Blue button, επιλογή settings, επιλογή automoount editor
2. Στην οθονη που εμφανίζεται, επιλογή Add (green button)
3. Εβαλα τις παρακάτω παραμέτρους:
- mountpoint: Directory
- type: cifs
- options: rw,soft,upd,nolock
- username: dbox
- password: dbox
- buffersize: ώς έχει
- name or ip: το ip του pc π.χ. 192.168.1.100
- share: /db

Μετά το save έφυγα με exit. Αυτά σχετικά με το mount.

Νομίζω όμως ότι βρήκα και τον λόγο για τα "σπασίματα". Εκανα recoding τις ταινίες από avi, σε mpeg2 για να τις βλέπει ο dm800. Στις επιλογές έβαλα διαστάσεις οθόνης 720 x 576. Σε αυτή την διάσταση όμως εάν αυξήσω το bitrate του video κατά την μετατροπη πάνω από τα 3700 / 4000 αρχίζουν τα σπασίματα, δηλαδή δεν το "αντέχει" το dm800.

Αυτά με τα ολίγα που ξέρω. Εάν έχω κάνει κάπου λάθος ή μπορώ να κάνω κάτι καλύτερα παρακαλώ πείτε το.
Ευχαριστώ
 
Last edited:
Δεν έχεις κάνει κάτι λάθος.
Για το πρόβλημά σου ευθύνεται το VLC σε συνδυασμό με το Vlc plugin του DM σου. Πάρα πολλοί χρήστες αντιμετωπίζουν παρόμοια προβλήματα.
Το μόνο που μπορείς να κάνεις είναι κάποιες δοκιμές, ώστε να ανακαλύψεις ποιες είναι οι μέγιστες δυνατές τιμές στις οποίες ανταποκρίνεται η συνεργασία VLC-PC-δίκτυο-800-Vlc plugin και αποδίδει καλά.
Πάντως, από τα όσα έχω δει εγώ μέχρι στιγμής, ο DM δεν προσφέρεται για κάλυψη των αναγκών μας σε επίπεδο media center όσον αφορά τις ταινίες.
 
Για να σας ενημερώσω... την εμπειρία με τα κολήματα την είχα με τον media player (ή το κουμπί video αν πρόκειται για GP 4.20). ΔΕΝ έχω κολλήματα με το vlc plugin!!!
 
Για τον 500 υπαρχει ενα Plugin τοWeb-X-TV Stream Player που κανεις τη δουλεια σου.Για τον 800 αραγε κανει ?
 
Καλησπέρα παιδιά.

Όσο αφορά το mount θα ήθελα να σας περιγράψω έναν άλλο τρόπο που για μένα βολεύει πάρα πολύ και ας μην έχω ιδέα από linux.

A. Εντολή mount.

A1. Μπαίνουμε με telnet στον dreambox βάζοντας root για login.
A2. Τρέχουμε την εντολή:
mount -t cifs -o user=admin,password=admin //192.168.1.1/Movies /Movies

Όπου:

user=admin,password=admin: το username και password του λογαριασμού μας.
//192.168.1.1/Movies : το δικτυακό path του φακέλου στον server μας που θέλουμε να κάνουμε mount.
/Movies : Ο φάκελος στο dreambox που δημιουργήσαμε.

B. Η παρακάτω διαδικασία είναι για να κρατάει το mount και να μην το χάνει όταν κάνουμε reboot το dreambox.

B1. Δημιουργούμε ένα αρχείο netmount.sh που περιέχει τα παρακάτω:

#! /bin/sh
#
# netmount.sh mounts all networkfilesystems.
#
PATH=/sbin:/bin:/usr/sbin:/usr/bin
echo > /proc/fs/cifs/LinuxExtensionsEnabled 0
mount -t cifs -o user=admin,password=admin //192.168.1.1/Movies /Movies

Β2. Με ftp μεταφέρουμε το αρχείο netmount.sh στον φάκελο etc/init.d του dreambox.

Β3. Μπαίνουμε με telnet και τρέχουμε την παρακάτω εντολή:

ln -s /etc/init.d/netmount.sh /etc/rcS.d/S90netmount.sh
(βάζει το αρχείο μας στην λίστα με τα start/stop scripts services)

Β4. REBOOT

Β5. Τέλος. :)
 
Last edited:
Ας γράψω και για το record σε δικτυακό δίσκο...

Ανοίγουμε το αρχείο Directories.py και αλλάζουμε την δεύτερη και τρίτη εγγραφή SCOPE_HDD που βρίσκουμε στο αρχείο μας. Βάζουμε το path που θέλουμε να γράφει
π.χ: /Movies
Αντικαθιστούμε το Directories.py με αυτό που βρίσκεται στο path
/usr/lib/enigma2/python/Tools/Directories.py

Reboot and Ready…


Το αρχείο Directories.py:

# -*- coding: utf-8 -*-

from os import path as os_path, mkdir, rmdir, system, walk, stat as os_stat, listdir, readlink, makedirs, error as os_error, symlink, access, F_OK, R_OK, W_OK
from stat import S_IMODE
from re import compile

try:
from os import chmod
have_chmod = True
except:
have_chmod = False

try:
from os import utime
have_utime = True
except:
have_utime = False

SCOPE_TRANSPONDERDATA = 0
SCOPE_SYSETC = 1
SCOPE_FONTS = 2
SCOPE_SKIN = 3
SCOPE_SKIN_IMAGE = 4
SCOPE_USERETC = 5
SCOPE_CONFIG = 6
SCOPE_LANGUAGE = 7
SCOPE_HDD = 8
SCOPE_PLUGINS = 9
SCOPE_MEDIA = 10
SCOPE_PLAYLIST = 11
SCOPE_CURRENT_SKIN = 12
SCOPE_DEFAULTDIR = 13
SCOPE_DEFAULTPARTITION = 14
SCOPE_DEFAULTPARTITIONMOUNTDIR = 15
SCOPE_METADIR = 16

PATH_CREATE = 0
PATH_DONTCREATE = 1
PATH_FALLBACK = 2
defaultPaths = {
SCOPE_TRANSPONDERDATA: ("/etc/", PATH_DONTCREATE),
SCOPE_SYSETC: ("/etc/", PATH_DONTCREATE),
SCOPE_FONTS: ("/usr/share/fonts/", PATH_DONTCREATE),
SCOPE_CONFIG: ("/etc/enigma2/", PATH_CREATE),
SCOPE_PLUGINS: ("/usr/lib/enigma2/python/Plugins/", PATH_CREATE),

SCOPE_LANGUAGE: ("/usr/share/enigma2/po/", PATH_DONTCREATE),

SCOPE_SKIN: ("/usr/share/enigma2/", PATH_DONTCREATE),
SCOPE_SKIN_IMAGE: ("/usr/share/enigma2/", PATH_DONTCREATE),
SCOPE_HDD: ("/media/hdd/Records/", PATH_DONTCREATE),
SCOPE_MEDIA: ("/media/", PATH_DONTCREATE),
SCOPE_PLAYLIST: ("/etc/enigma2/playlist/", PATH_CREATE),

SCOPE_USERETC: ("", PATH_DONTCREATE), # user home directory

SCOPE_DEFAULTDIR: ("/usr/share/enigma2/defaults/", PATH_CREATE),
SCOPE_DEFAULTPARTITION: ("/dev/mtdblock/6", PATH_DONTCREATE),
SCOPE_DEFAULTPARTITIONMOUNTDIR: ("/usr/share/enigma2/dealer", PATH_CREATE),
SCOPE_METADIR: ("/usr/lib/enigma2/python/Plugins/meta", PATH_CREATE),
}

FILE_COPY = 0 # copy files from fallback dir to the basedir
FILE_MOVE = 1 # move files
PATH_COPY = 2 # copy the complete fallback dir to the basedir
PATH_MOVE = 3 # move the fallback dir to the basedir (can be used for changes in paths)
fallbackPaths = {
SCOPE_CONFIG: [("/home/root/", FILE_MOVE),
("/usr/share/enigma2/defaults/", FILE_COPY)],
SCOPE_HDD: [("/media/hdd/Records/", PATH_MOVE)]
}

def resolveFilename(scope, base = "", path_prefix = None):
if base[0:2] == "~/":
# you can only use the ~/ if we have a prefix directory
assert path_prefix is not None
base = os_path.join(path_prefix, base[2:])

# don't resolve absolute paths
if base[0:1] == '/':
return base

if scope == SCOPE_CURRENT_SKIN:
from Components.config import config
tmp = defaultPaths[SCOPE_SKIN]
pos = config.skin.primary_skin.value.rfind('/')
if pos != -1:
path = tmp[0]+config.skin.primary_skin.value[:pos+1]
else:
path = tmp[0]
else:
tmp = defaultPaths[scope]
path = tmp[0]

flags = tmp[1]

if flags == PATH_CREATE:
if not pathExists(path):
mkdir(path)

fallbackPath = fallbackPaths.get(scope)

if fallbackPath and not fileExists(path + base):
for x in fallbackPath:
if x[1] == FILE_COPY:
if fileExists(x[0] + base):
system("cp " + x[0] + base + " " + path + base)
break
elif x[1] == FILE_MOVE:
if fileExists(x[0] + base):
system("mv " + x[0] + base + " " + path + base)
break
elif x[1] == PATH_COPY:
if pathExists(x[0]):
if not pathExists(defaultPaths[scope][0]):
mkdir(path)
system("cp -a " + x[0] + "* " + path)
break
elif x[1] == PATH_MOVE:
if pathExists(x[0]):
system("mv " + x[0] + " " + path)
break

# FIXME: we also have to handle DATADIR etc. here.
return path + base
# this is only the BASE - an extension must be added later.

def pathExists(path):
return os_path.exists(path)

def isMount(path):
return os_path.ismount(path)

def createDir(path, makeParents = False):
try:
if makeParents:
makedirs(path)
else:
mkdir(path)
except:
ret = 0
else:
ret = 1
return ret

def removeDir(path):
try:
rmdir(path)
except:
ret = 0
else:
ret = 1
return ret

def fileExists(f, mode='r'):
if mode == 'r':
acc_mode = R_OK
elif mode == 'w':
acc_mode = W_OK
else:
acc_mode = F_OK
return access(f, acc_mode)

def getRecordingFilename(basename, dirname = None):
# filter out non-allowed characters
non_allowed_characters = "/.\\:*?<>|\""
filename = ""

basename = basename.replace('\xc2\x86', '').replace('\xc2\x87', '')

for c in basename:
if c in non_allowed_characters or ord(c) < 32:
c = "_"
filename += c

if dirname is not None:
filename = ''.join((dirname, filename))

i = 0
while True:
path = resolveFilename(SCOPE_HDD, filename)
if i > 0:
path += "_%03d" % i
try:
open(path + ".ts")
i += 1
except IOError:
return path

# this is clearly a hack:
def InitFallbackFiles():
resolveFilename(SCOPE_CONFIG, "userbouquet.favourites.tv")
resolveFilename(SCOPE_CONFIG, "bouquets.tv")
resolveFilename(SCOPE_CONFIG, "userbouquet.favourites.radio")
resolveFilename(SCOPE_CONFIG, "bouquets.radio")

# returns a list of tuples containing pathname and filename matching the given pattern
# example-pattern: match all txt-files: ".*\.txt$"
def crawlDirectory(directory, pattern):
expression = compile(pattern)
list = []
for root, dirs, files in walk(directory):
for file in files:
if expression.match(file) is not None:
list.append((root, file))
return list

def copyfile(src, dst):
try:
f1 = open(src, "rb")
if os_path.isdir(dst):
dst = os_path.join(dst, os_path.basename(src))
f2 = open(dst, "w+b")
while True:
buf = f1.read(16*1024)
if not buf:
break
f2.write(buf)
st = os_stat(src)
mode = S_IMODE(st.st_mode)
if have_chmod:
chmod(dst, mode)
if have_utime:
utime(dst, (st.st_atime, st.st_mtime))
except:
print "copy", src, "to", dst, "failed!"
return -1
return 0

def copytree(src, dst, symlinks=False):
names = listdir(src)
if os_path.isdir(dst):
dst = os_path.join(dst, os_path.basename(src))
if not os_path.isdir(dst):
mkdir(dst)
else:
makedirs(dst)
for name in names:
srcname = os_path.join(src, name)
dstname = os_path.join(dst, name)
try:
if symlinks and os_path.islink(srcname):
linkto = readlink(srcname)
symlink(linkto, dstname)
elif os_path.isdir(srcname):
copytree(srcname, dstname, symlinks)
else:
copyfile(srcname, dstname)
except:
print "dont copy srcname (no file or link or folder)"
try:
st = os_stat(src)
mode = S_IMODE(st.st_mode)
if have_chmod:
chmod(dst, mode)
if have_utime:
utime(dst, (st.st_atime, st.st_mtime))
except:
print "copy stats for", src, "failed!"