* 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
+#ifdef HAVE_CONFIG_H
+# include <config.h>
+#endif
+
#include "EPGWidget.hpp"
-#include <QGridLayout>
+#include <QVBoxLayout>
#include <QScrollBar>
#include <QDebug>
#include <QLabel>
-
-ChannelsWidget::ChannelsWidget( QWidget *parent ) : QWidget( parent )
-{
- setContentsMargins( 0, 0, 0, 0 );
- setMaximumWidth( 50 );
- setFocusPolicy( Qt::ClickFocus );
-}
+#include "qt4.hpp"
EPGWidget::EPGWidget( QWidget *parent ) : QWidget( parent )
{
- QGridLayout* layout = new QGridLayout( this );
-
m_rulerWidget = new EPGRuler( this );
- m_channelsWidget = new ChannelsWidget( this );
m_epgView = new EPGView( this );
+ m_channelsWidget = new EPGChannels( this, m_epgView );
- m_channelsWidget->setMinimumWidth( 40 );
+ m_channelsWidget->setMinimumWidth( 100 );
m_epgView->setSizePolicy( QSizePolicy::Expanding, QSizePolicy::Expanding );
setZoom( 1 );
- layout->addWidget( m_rulerWidget, 0, 1 );
- layout->addWidget( m_channelsWidget, 1, 0 );
- layout->addWidget( m_epgView, 1, 1 );
+ QGridLayout* layout = new QGridLayout( this );
+ layout->addWidget( m_rulerWidget, 0, 1 );
+ layout->addWidget( m_channelsWidget, 1, 0 );
+ layout->addWidget( m_epgView, 1, 1 );
layout->setSpacing( 0 );
setLayout( layout );
m_rulerWidget, SLOT( setDuration(int) ) );
connect( m_epgView->horizontalScrollBar(), SIGNAL( valueChanged(int) ),
m_rulerWidget, SLOT( setOffset(int) ) );
+ connect( m_epgView->verticalScrollBar(), SIGNAL( valueChanged(int) ),
+ m_channelsWidget, SLOT( setOffset(int) ) );
connect( m_epgView, SIGNAL( eventFocusedChanged(EPGEvent*)),
this, SIGNAL(itemSelectionChanged(EPGEvent*)) );
}
void EPGWidget::updateEPG( vlc_epg_t **pp_epg, int i_epg )
{
- m_epgView->setStartTime( QDateTime::currentDateTime() );
for ( int i = 0; i < i_epg; ++i )
{
vlc_epg_t *p_epg = pp_epg[i];
- QString channelName = QString( p_epg->psz_name );
+ QString channelName = qfu( p_epg->psz_name );
for ( int j = 0; j < p_epg->i_event; ++j )
{
- EPGEvent *item = NULL;
vlc_epg_event_t *p_event = p_epg->pp_event[j];
- QString eventName = QString( p_event->psz_name );
+ QString eventName = qfu( p_event->psz_name );
+ QDateTime eventStart = QDateTime::fromTime_t( p_event->i_start );
QList<EPGEvent*> events = m_events.values( channelName );
+ EPGEvent *item = new EPGEvent( eventName );
+ item->description = qfu( p_event->psz_description );
+ item->shortDescription = qfu( p_event->psz_short_description );
+ item->start = eventStart;
+ item->duration = p_event->i_duration;
+ item->channelName = channelName;
+ item->current = ( p_epg->p_current == p_event ) ? true : false;
+
+ bool alreadyIn = false;
+
for ( int k = 0; k < events.count(); ++k )
{
- if ( events.at( k )->name == eventName &&
- events.at( k )->channelName == channelName )
+ if ( *events.at( k ) == *item )
{
- item = events.at( k );
- item->updated = true;
- item->description = QString( p_event->psz_description );
- item->shortDescription = QString( p_event->psz_short_description );
- item->start = QDateTime::fromTime_t( p_event->i_start );
- item->duration = p_event->i_duration;
- item->current = ( p_epg->p_current == p_event ) ? true : false;
-
- if ( item->start < m_epgView->startTime() )
- m_epgView->setStartTime( item->start );
-
- m_epgView->updateEvent( item );
+ alreadyIn = true;
+ events.at( k )->updated = true;
break;
}
}
- if ( !item )
+ if ( !alreadyIn )
{
- item = new EPGEvent( eventName );
- item->description = QString( p_event->psz_description );
- item->shortDescription = QString( p_event->psz_short_description );
- item->start = QDateTime::fromTime_t( p_event->i_start );
- item->duration = p_event->i_duration;
- item->channelName = channelName;
- item->current = ( p_epg->p_current == p_event ) ? true : false;
m_events.insert( channelName, item );
-
- if ( item->start < m_epgView->startTime() )
- m_epgView->setStartTime( item->start );
-
m_epgView->addEvent( item );
}
+ else
+ delete item;
}
}
++i;
}
- // Update the global duration
+ // Update the global duration and start time.
m_epgView->updateDuration();
+ m_epgView->updateStartTime();
}