ChannelSelection modifications
Re: ChannelSelection modifications #2
Posted 25 February 2012 - 11:46
Matrix10 MH-HD2 skin modification by me: https://github.com/B...-MX-HD2-OpenPli
MetrixHD skin modification by me: https://github.com/T...xHD-WPstyle-mod
Slovenian translation for OpenPLi E2: https://github.com/T...ion-for-OpenPLi
Re: ChannelSelection modifications #3
Re: ChannelSelection modifications #4
Re: ChannelSelection modifications #5
Posted 20 March 2012 - 22:13
option `services count` have missed for long years sinc moved from E1 dream to E2 dream
can devolopers search some other way implement this important feature dirrectly into Enigma2 cause trough python it is so slow -
on every time presing green key have to wait 9 seconds (red key spends 4sec)
Step5
- change path separator in title for easyer reading
if end_ref is not None: if Len > 2: # - titleStr += '/../' # + titleStr += ' \xbb..\xbb ' # + END else: # - titleStr += '/' # + titleStr += ' \xbb ' # + END
Step6
- feat request: change location(order) of "Current transponder" to top or botomn
Re: ChannelSelection modifications #6
Posted 21 March 2012 - 22:13
in case i have large services list will leave only for `*** New` folders
another feature is hide `*** New` folders where none services present
!!! not jet adopted for OpenPLI, there changes which i made NN2(DMM experimental) files
changes in /usr/lib/enigma2/python/Screens>ChannelSelection.py
. .. ... # + def getServicesCount(self, root_ref): count = 0 serviceHandler = eServiceCenter.getInstance() list = serviceHandler.list(root_ref) if list is not None: while True: s = list.getNext() if not s.valid(): break count += 1 return count # + END def showSatellites(self): if not self.pathChangeDisabled: refstr = '%s FROM SATELLITES ORDER BY satellitePosition'%(self.service_types) if not self.preEnterPath(refstr): ref = eServiceReference(refstr) justSet=False prev = None if self.isBasePathEqual(ref): if self.isPrevPathEqual(ref): justSet=True prev = self.pathUp(justSet) else: currentRoot = self.getRoot() if currentRoot is None or currentRoot != ref: justSet=True self.clearPath() self.enterPath(ref, True) if justSet: serviceHandler = eServiceCenter.getInstance() servicelist = serviceHandler.list(ref) if not servicelist is None: while True: service = servicelist.getNext() if not service.valid(): #check if end of list break unsigned_orbpos = service.getUnsignedData(4) >> 16 orbpos = service.getData(4) >> 16 if orbpos < 0: orbpos += 3600 # + skip = 0 cntstr = "" # + END if service.getPath().find("FROM PROVIDER") != -1: service_type = _("Providers") elif service.getPath().find("flags == %d" %(FLAG_SERVICE_NEW_FOUND)) != -1: # + if "..New" in config.usage.show_services_count_for_folders.value or config.usage.hide_empty_newfound_folders.value: cnt = self.getServicesCount(service) if cnt == 0 and config.usage.hide_empty_newfound_folders.value: skip = 1 else: cntstr = " (%d)"%(cnt) # + END service_type = _("New") elif service.getPath().find("numCAIDs") != -1: # + if "..FTA" in config.usage.show_services_count_for_folders.value: cntstr = " (%d)"%(self.getServicesCount(service)) # + END service_type = _("Services") + " FTA" else: # + if "..Simple" in config.usage.show_services_count_for_folders.value: cntstr = " (%d)"%(self.getServicesCount(service)) # + END service_type = _("Services") try: # why we need this cast? service_name = str(nimmanager.getSatDescription(orbpos)) except: if unsigned_orbpos == 0xFFFF: #Cable service_name = _("Cable") elif unsigned_orbpos == 0xEEEE: #Terrestrial service_name = _("Terrestrial") else: if orbpos > 1800: # west orbpos = 3600 - orbpos h = _("W") else: h = _("E") service_name = ("%d.%d" + h) % (orbpos / 10, orbpos % 10) # - service.setName("%s - %s" % (service_name, service_type)) # - self.servicelist.addService(service) # + if not skip: service.setName("%s - %s%s" %(service_name, service_type, cntstr)) self.servicelist.addService(service) # + END cur_ref = self.session.nav.getCurrentlyPlayingServiceReference() if cur_ref: pos = self.service_types.rfind(':') refstr = '%s (channelID == %08x%04x%04x) && %s ORDER BY name' %(self.service_types[:pos+1], cur_ref.getUnsignedData(4), # NAMESPACE cur_ref.getUnsignedData(2), # TSID cur_ref.getUnsignedData(3), # ONID self.service_types[pos+1:]) ref = eServiceReference(refstr) ref.setName(_("Current Transponder")) self.servicelist.addService(ref) self.servicelist.finishFill() if prev is not None: self.setCurrentSelection(prev) ... .. .changes in /usr/lib/enigma2/python/Components>UsageConfig.py
. .. ... def InitUsageConfig(): config.usage = ConfigSubsection(); # + config.usage.toggle_show_close_automatically = ConfigYesNo(default = False) config.usage.show_services_count_for_folders = ConfigSet(default=["..New"], choices = ["..New", "..FTA", "..HD", "..Simple"]) config.usage.hide_empty_newfound_folders = ConfigYesNo(default = True) # + END ... .. .changes in /usr/share/enigma2>setup.xml
. .. ... <item level="0" text="Infobar timeout">config.usage.infobar_timeout</item> <item level="0" text="Auto Hide manual activated Infobar">config.usage.toggle_show_close_automatically</item> <item level="1" text="12V output" requires="12V_Output">config.usage.output_12V</item> <item level="0" text="Show event-progress in channel selection">config.usage.show_event_progress_in_servicelist</item> <item level="0" text="Show Services Count for Folders">config.usage.show_services_count_for_folders</item> <item level="0" text="Hide Empty NewFound folders">config.usage.hide_empty_newfound_folders</item> <item level="2" text="Show infobar on channel change">config.usage.show_infobar_on_zap</item> ... .. .
Attached Files
Re: ChannelSelection modifications #7
Posted 22 March 2012 - 08:10
In addition we cannot take over code from DMM due to licence issues....
Edited by littlesat, 22 March 2012 - 08:11.
WaveFrontier 28.2E | 23.5E | 19.2E | 16E | 13E | 10/9E | 7E | 5E | 1W | 4/5W | 15W
Re: ChannelSelection modifications #8
Re: ChannelSelection modifications #9
Re: ChannelSelection modifications #10
Re: ChannelSelection modifications #11
Posted 22 March 2012 - 09:15
developers have to read only lines between markers `# +` and `# + END`
methods/options `Hide empty NewFound folder` and `count services for only selected folders` can be compatible in OpenPLI
Re: ChannelSelection modifications #12
Re: ChannelSelection modifications #13
Re: ChannelSelection modifications #14
Re: ChannelSelection modifications #15
Re: ChannelSelection modifications #16
Posted 22 March 2012 - 23:55
Excellent work.
I have a couple suggestions maybe you may like it:
1) Like MartiniB mentioned, hide sats with zero/empty in NEW?
2) Highlighting HD channels in 'all services and user bouquets' with a different foreground color, marked or make them bold? (Maybe include an option to customize this in a skin?)
H9.Twin ::: H9.S :::::::::: WaveFrontier T90: 1W, 3, 7, 13, 16, 19, 23, 28, 39, 42E ::::::::::
Re: ChannelSelection modifications #17
Posted 23 March 2012 - 06:39
>1) Like MartiniB mentioned, hide sats with zero/empty in NEW?
This will require changes to multiple files.
You will do to change them after each update?
For example, I do not want to.
Edited by Dima73, 23 March 2012 - 06:39.
GigaBlue UHD Quad 4K /Lunix3-4K/Duo 4K
Re: ChannelSelection modifications #18
Re: ChannelSelection modifications #19
Posted 23 March 2012 - 11:49
have find free hour yesterday and installed OpenPLI on one box,
noticed there arent present *.py files,
then how can i compare with original PLI's /usr/lib/enigma2/python/Screens/ChannelSelection.py ?
for images where *.py files are present i have wrote my own /usr/script/python_patcher.sh and /usr/script/skin_patcher.sh
which i run after each online update, then my made changes restored
http://www.dream-mul...&threadID=12560
@Dima73> This will require changes to multiple files. You will do to change them after each update? For example, I do not want to.
multiple modules change requered only when turn On turn Off option is supported, you can chose Hide Allways case
btw `turn On turn Off option` have made just because 9 seconds on open Sat list is too much long time
if counting can be made another/faster way then that sub options will not be necesary at all
Re: ChannelSelection modifications #20
Posted 23 March 2012 - 13:25
opkg install enigma2-src does the trick... And all our sources are on http://openpli.git.s...itweb-index.cgi.noticed there arent present *.py files,
To do this right you do not work with patcher.sh files.... but with real diffs/patches created with git.
At least post your endresulting py file....
Edited by littlesat, 23 March 2012 - 13:26.
WaveFrontier 28.2E | 23.5E | 19.2E | 16E | 13E | 10/9E | 7E | 5E | 1W | 4/5W | 15W
4 user(s) are reading this topic
0 members, 4 guests, 0 anonymous users