1 #include <lib/service/listboxservice.h>
2 #include <lib/service/service.h>
3 #include <lib/gdi/font.h>
4 #include <lib/dvb/epgcache.h>
5 #include <lib/dvb/pmt.h>
7 void eListboxServiceContent::setRoot(const eServiceReference &root)
12 assert(m_service_center);
14 ePtr<iListableService> lst;
15 if (m_service_center->list(m_root, lst))
16 eDebug("no list available!");
18 if (lst->getContent(m_list))
19 eDebug("getContent failed");
21 m_size = m_list.size();
25 m_listbox->entryReset();
28 void eListboxServiceContent::setCurrent(const eServiceReference &ref)
31 for (list::iterator i(m_list.begin()); i != m_list.end(); ++i, ++index)
35 m_cursor_number = index;
40 void eListboxServiceContent::getCurrent(eServiceReference &ref)
45 ref = eServiceReference();
48 int eListboxServiceContent::getNextBeginningWithChar(char c)
50 // printf("Char: %c\n", c);
52 for (list::iterator i(m_list.begin()); i != m_list.end(); ++i, ++index)
55 ePtr<iStaticServiceInformation> service_info;
56 m_service_center->info(*i, service_info);
57 service_info->getName(*i, text);
58 // printf("%c\n", text.c_str()[0]);
60 int len=text.length();
63 char cc = text[idx++];
64 if ( cc >= 33 && cc < 127)
75 void eListboxServiceContent::initMarked()
80 void eListboxServiceContent::addMarked(const eServiceReference &ref)
84 m_listbox->entryChanged(lookupService(ref));
87 void eListboxServiceContent::removeMarked(const eServiceReference &ref)
91 m_listbox->entryChanged(lookupService(ref));
94 int eListboxServiceContent::isMarked(const eServiceReference &ref)
96 return m_marked.find(ref) != m_marked.end();
99 void eListboxServiceContent::markedQueryStart()
101 m_marked_iterator = m_marked.begin();
104 int eListboxServiceContent::markedQueryNext(eServiceReference &ref)
106 if (m_marked_iterator == m_marked.end())
108 ref = *m_marked_iterator++;
112 int eListboxServiceContent::lookupService(const eServiceReference &ref)
114 /* shortcut for cursor */
115 if (ref == *m_cursor)
116 return m_cursor_number;
117 /* otherwise, search in the list.. */
119 for (list::const_iterator i(m_list.begin()); i != m_list.end(); ++i, ++index);
121 /* this is ok even when the index was not found. */
125 void eListboxServiceContent::setVisualMode(int mode)
127 m_visual_mode = mode;
129 if (m_visual_mode == visModeSimple)
131 m_element_position[celServiceName] = eRect(ePoint(0, 0), m_itemsize);
132 m_element_font[celServiceName] = new gFont("Arial", 23);
133 m_element_position[celServiceNumber] = eRect();
134 m_element_font[celServiceNumber] = 0;
135 m_element_position[celIcon] = eRect();
136 m_element_position[celServiceInfo] = eRect();
137 m_element_font[celServiceInfo] = 0;
141 void eListboxServiceContent::setElementPosition(int element, eRect where)
143 if ((element >= 0) && (element < celElements))
144 m_element_position[element] = where;
147 void eListboxServiceContent::setElementFont(int element, gFont *font)
149 if ((element >= 0) && (element < celElements))
150 m_element_font[element] = font;
153 void eListboxServiceContent::sort()
155 ePtr<iListableService> lst;
156 if (!m_service_center->list(m_root, lst))
158 m_list.sort(iListableServiceCompare(lst));
159 /* FIXME: is this really required or can we somehow keep the current entry? */
162 m_listbox->entryReset();
166 DEFINE_REF(eListboxServiceContent);
168 eListboxServiceContent::eListboxServiceContent()
169 :m_epgcache(eEPGCache::getInstance()), m_visual_mode(visModeSimple), m_size(0), m_current_marked(false), m_numberoffset(0)
172 eServiceCenter::getInstance(m_service_center);
173 if (eDVBResourceManager::getInstance(m_res_mgr))
174 eDebug("no resource manager");
177 void eListboxServiceContent::cursorHome()
179 if (m_current_marked && m_saved_cursor == m_list.end())
181 while (m_cursor_number)
183 std::iter_swap(m_cursor--, m_cursor);
185 if (m_listbox && m_cursor_number)
186 m_listbox->entryChanged(m_cursor_number);
191 m_cursor = m_list.begin();
196 void eListboxServiceContent::cursorEnd()
198 if (m_current_marked && m_saved_cursor == m_list.end())
200 while (m_cursor != m_list.end())
202 list::iterator prev = m_cursor++;
204 if ( prev != m_list.end() && m_cursor != m_list.end() )
206 std::iter_swap(m_cursor, prev);
208 m_listbox->entryChanged(m_cursor_number);
214 m_cursor = m_list.end();
215 m_cursor_number = m_size;
219 int eListboxServiceContent::setCurrentMarked(bool state)
221 bool prev = m_current_marked;
222 m_current_marked = state;
224 if (state != prev && m_listbox)
226 m_listbox->entryChanged(m_cursor_number);
229 ePtr<iListableService> lst;
230 if (m_service_center->list(m_root, lst))
231 eDebug("no list available!");
234 ePtr<iMutableServiceList> list;
235 if (lst->startEdit(list))
236 eDebug("no editable list");
239 eServiceReference ref;
242 eDebug("no valid service selected");
245 int pos = cursorGet();
246 eDebugNoNewLine("move %s to %d ", ref.toString().c_str(), pos);
247 if (list->moveService(ref, cursorGet()))
260 int eListboxServiceContent::cursorMove(int count)
262 int prev = m_cursor_number, last = m_cursor_number + count;
265 while(count && m_cursor != m_list.end())
267 list::iterator prev_it = m_cursor++;
268 if ( m_current_marked && m_cursor != m_list.end() && m_saved_cursor == m_list.end() )
270 std::iter_swap(prev_it, m_cursor);
271 if ( m_listbox && prev != m_cursor_number && last != m_cursor_number )
272 m_listbox->entryChanged(m_cursor_number);
277 } else if (count < 0)
279 while (count && m_cursor != m_list.begin())
281 list::iterator prev_it = m_cursor--;
282 if ( m_current_marked && m_cursor != m_list.end() && prev_it != m_list.end() && m_saved_cursor == m_list.end() )
284 std::iter_swap(prev_it, m_cursor);
285 if ( m_listbox && prev != m_cursor_number && last != m_cursor_number )
286 m_listbox->entryChanged(m_cursor_number);
295 int eListboxServiceContent::cursorValid()
297 return m_cursor != m_list.end();
300 int eListboxServiceContent::cursorSet(int n)
307 int eListboxServiceContent::cursorGet()
309 return m_cursor_number;
312 void eListboxServiceContent::cursorSave()
314 m_saved_cursor = m_cursor;
315 m_saved_cursor_number = m_cursor_number;
318 void eListboxServiceContent::cursorRestore()
320 m_cursor = m_saved_cursor;
321 m_cursor_number = m_saved_cursor_number;
322 m_saved_cursor = m_list.end();
325 int eListboxServiceContent::size()
330 void eListboxServiceContent::setSize(const eSize &size)
333 setVisualMode(m_visual_mode);
336 void eListboxServiceContent::paint(gPainter &painter, eWindowStyle &style, const ePoint &offset, int selected)
338 painter.clip(eRect(offset, m_itemsize));
342 if (m_res_mgr && cursorValid() && !((m_cursor->flags & eServiceReference::flagDirectory) == eServiceReference::flagDirectory))
344 if ( eDVBServicePMTHandler::getCount() > 1 )
346 eServiceReferenceDVB &ref = (eServiceReferenceDVB&) *m_cursor;
347 eUsePtr<iDVBChannel> channel;
349 ref.getChannelID(chid);
350 tuneable = !m_res_mgr->allocateChannel(chid, channel, true); // no real allocate channel..just fake
354 if (m_current_marked && selected)
355 style.setStyle(painter, eWindowStyle::styleListboxMarked);
356 else if (cursorValid() && isMarked(*m_cursor))
357 style.setStyle(painter, eWindowStyle::styleListboxMarked);
360 style.setStyle(painter, selected ? eWindowStyle::styleListboxSelected : eWindowStyle::styleListboxNormal);
362 painter.setForegroundColor(gRGB(0xbbbbbb));
368 /* get service information */
369 ePtr<iStaticServiceInformation> service_info;
370 m_service_center->info(*m_cursor, service_info);
372 for (int e = 0; e < celElements; ++e)
374 if (!m_element_font[e])
376 int flags=gPainter::RT_VALIGN_CENTER;
378 eRect area = m_element_position[e];
380 std::string text = "<n/a>";
385 // render icon here...
387 case celServiceNumber:
390 sprintf(bla, "%d", m_numberoffset + m_cursor_number + 1);
392 flags|=gPainter::RT_HALIGN_RIGHT;
398 service_info->getName(*m_cursor, text);
403 ePtr<eServiceEvent> evt;
405 if ( !m_epgcache->lookupEventTime(*m_cursor, t, evt) )
406 text = '(' + evt->getEventName() + ')';
413 eTextPara *para = new eTextPara(area);
415 para->setFont(m_element_font[e]);
416 para->renderString(text);
418 if (e == celServiceName)
420 eRect bbox = para->getBoundBox();
421 int name_width = bbox.width()+10;
422 m_element_position[celServiceInfo].setLeft(area.left()+name_width);
423 m_element_position[celServiceInfo].setTop(area.top());
424 m_element_position[celServiceInfo].setWidth(area.width()-name_width);
425 m_element_position[celServiceInfo].setHeight(area.height());
428 if (flags & gPainter::RT_HALIGN_RIGHT)
429 para->realign(eTextPara::dirRight);
430 else if (flags & gPainter::RT_HALIGN_CENTER)
431 para->realign(eTextPara::dirCenter);
432 else if (flags & gPainter::RT_HALIGN_BLOCK)
433 para->realign(eTextPara::dirBlock);
435 ePoint offs = offset;
437 if (flags & gPainter::RT_VALIGN_CENTER)
439 eRect bbox = para->getBoundBox();
440 int vcentered_top = (area.height() - bbox.height()) / 2;
441 int correction = vcentered_top - bbox.top();
442 offs += ePoint(0, correction);
445 painter.renderPara(para, offs);
449 style.drawFrame(painter, eRect(offset, m_itemsize), eWindowStyle::frameListboxEntry);