Commit ab097340 authored by Adrien Maglo's avatar Adrien Maglo Committed by Jean-Baptiste Kempf

Qt/EPG: update and synchronise as in master

(cherry picked from commit c57d47dbe87f236784e975743ae1fe32e18fdcdc)
(cherry picked from commit 753a7d15e9d2dedf650789245dc7d0b5b1765c65)
(cherry picked from commit 1ef8da27660e7a46070a7b104b9b5b1f96daf5a7)
(cherry picked from commit 44676a0590c2b96d13ea5a700b5878166b6f432a)
Signed-off-by: default avatarJean-Baptiste Kempf <jb@videolan.org>
parent 472087d6
...@@ -25,17 +25,29 @@ ...@@ -25,17 +25,29 @@
#define EPGEVENT_H #define EPGEVENT_H
class QString; class QString;
class EPGItem;
#include <QDateTime> #include <QDateTime>
class EPGEvent class EPGEvent
{ {
public: public:
EPGEvent( const QString& eventName ) EPGEvent( const QString& eventName )
: current( false ), updated( true ) : current( false ), updated( true ), item( NULL )
{ {
name = eventName; name = eventName;
} }
bool operator==( const EPGEvent & other ) const
{
return start == other.start
&& duration == other.duration
&& name == other.name
&& description == other.description
&& shortDescription == other.shortDescription
&& channelName == other.channelName
&& current == other.current;
}
QDateTime start; QDateTime start;
int duration; int duration;
QString name; QString name;
...@@ -44,6 +56,8 @@ public: ...@@ -44,6 +56,8 @@ public:
QString channelName; QString channelName;
bool current; bool current;
bool updated; bool updated;
EPGItem *item;
}; };
#endif // EPGEVENT_H #endif // EPGEVENT_H
...@@ -59,15 +59,19 @@ void EPGItem::paint( QPainter *painter, const QStyleOptionGraphicsItem*, QWidget ...@@ -59,15 +59,19 @@ void EPGItem::paint( QPainter *painter, const QStyleOptionGraphicsItem*, QWidget
QTransform viewPortTransform = m_view->viewportTransform(); QTransform viewPortTransform = m_view->viewportTransform();
QRectF mapped = deviceTransform( viewPortTransform ).mapRect( boundingRect() ); QRectF mapped = deviceTransform( viewPortTransform ).mapRect( boundingRect() );
painter->setPen( QPen( Qt::black ) );
if ( m_current ) if ( m_current )
painter->setBrush( QBrush( QColor( 100, 100, 100 ) ) ); {
painter->setBrush( QBrush( QColor( 244, 102, 146 ) ) );
painter->setPen( QPen( QColor( 244, 102, 146 ) ) );
}
else else
painter->setBrush( QBrush( QColor( 150, 150, 150 ) ) ); {
painter->setBrush( QBrush( QColor( 201, 217, 242 ) ) );
painter->drawRect( mapped ); painter->setPen( QPen( QColor( 201, 217, 242 ) ) );
}
mapped.adjust( 1, 2, -1, -2 );
painter->drawRoundedRect( mapped, 10, 10 );
/* Draw text */ /* Draw text */
...@@ -80,7 +84,7 @@ void EPGItem::paint( QPainter *painter, const QStyleOptionGraphicsItem*, QWidget ...@@ -80,7 +84,7 @@ void EPGItem::paint( QPainter *painter, const QStyleOptionGraphicsItem*, QWidget
// Adjust the drawing rect // Adjust the drawing rect
mapped.adjust( 6, 6, -6, -6 ); mapped.adjust( 6, 6, -6, -6 );
painter->setPen( Qt::white ); painter->setPen( Qt::black );
/* Draw the title. */ /* Draw the title. */
painter->drawText( mapped, Qt::AlignTop | Qt::AlignLeft, fm.elidedText( m_name, Qt::ElideRight, mapped.width() ) ); painter->drawText( mapped, Qt::AlignTop | Qt::AlignLeft, fm.elidedText( m_name, Qt::ElideRight, mapped.width() ) );
......
...@@ -62,7 +62,7 @@ void EPGView::setStartTime( const QDateTime& startTime ) ...@@ -62,7 +62,7 @@ void EPGView::setStartTime( const QDateTime& startTime )
{ {
EPGItem* item = qgraphicsitem_cast<EPGItem*>( itemList.at( i ) ); EPGItem* item = qgraphicsitem_cast<EPGItem*>( itemList.at( i ) );
if ( !item ) continue; if ( !item ) continue;
item->setStart( item->start() ); item->updatePos();
} }
// Our start time has changed // Our start time has changed
...@@ -88,17 +88,16 @@ void EPGView::addEvent( EPGEvent* event ) ...@@ -88,17 +88,16 @@ void EPGView::addEvent( EPGEvent* event )
item->setShortDescription( event->shortDescription ); item->setShortDescription( event->shortDescription );
item->setCurrent( event->current ); item->setCurrent( event->current );
scene()->addItem( item ); event->item = item;
}
void EPGView::updateEvent( EPGEvent* event ) scene()->addItem( item );
{
//qDebug() << "Update event: " << event->name;
} }
void EPGView::delEvent( EPGEvent* event ) void EPGView::delEvent( EPGEvent* event )
{ {
//qDebug() << "Del event: " << event->name; if( event->item != NULL )
scene()->removeItem( event->item );
event->item = NULL;
} }
void EPGView::updateDuration() void EPGView::updateDuration()
......
...@@ -29,7 +29,7 @@ ...@@ -29,7 +29,7 @@
#include <QGraphicsView> #include <QGraphicsView>
#include <QList> #include <QList>
#define TRACKS_HEIGHT 75 #define TRACKS_HEIGHT 60
class QDateTime; class QDateTime;
class EPGView : public QGraphicsView class EPGView : public QGraphicsView
...@@ -45,7 +45,6 @@ public: ...@@ -45,7 +45,6 @@ public:
const QDateTime& startTime(); const QDateTime& startTime();
void addEvent( EPGEvent* event ); void addEvent( EPGEvent* event );
void updateEvent( EPGEvent* event );
void delEvent( EPGEvent* event ); void delEvent( EPGEvent* event );
void updateDuration(); void updateDuration();
......
...@@ -72,7 +72,6 @@ void EPGWidget::setZoom( int level ) ...@@ -72,7 +72,6 @@ void EPGWidget::setZoom( int level )
void EPGWidget::updateEPG( vlc_epg_t **pp_epg, int i_epg ) void EPGWidget::updateEPG( vlc_epg_t **pp_epg, int i_epg )
{ {
m_epgView->setStartTime( QDateTime::currentDateTime() );
for ( int i = 0; i < i_epg; ++i ) for ( int i = 0; i < i_epg; ++i )
{ {
vlc_epg_t *p_epg = pp_epg[i]; vlc_epg_t *p_epg = pp_epg[i];
...@@ -80,52 +79,42 @@ void EPGWidget::updateEPG( vlc_epg_t **pp_epg, int i_epg ) ...@@ -80,52 +79,42 @@ void EPGWidget::updateEPG( vlc_epg_t **pp_epg, int i_epg )
for ( int j = 0; j < p_epg->i_event; ++j ) for ( int j = 0; j < p_epg->i_event; ++j )
{ {
EPGEvent *item = NULL;
vlc_epg_event_t *p_event = p_epg->pp_event[j]; vlc_epg_event_t *p_event = p_epg->pp_event[j];
QString eventName = qfu( p_event->psz_name ); QString eventName = qfu( p_event->psz_name );
QDateTime eventStart = QDateTime::fromTime_t( p_event->i_start ); QDateTime eventStart = QDateTime::fromTime_t( p_event->i_start );
QList<EPGEvent*> events = m_events.values( channelName ); 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 ) for ( int k = 0; k < events.count(); ++k )
{ {
if ( events.at( k )->name == eventName && if ( *events.at( k ) == *item )
events.at( k )->channelName == channelName &&
events.at( k )->start == eventStart )
{ {
/* Update the event. */ alreadyIn = true;
item = events.at( k ); events.at( k )->updated = true;
item->updated = true;
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->current = ( p_epg->p_current == p_event ) ? true : false;
if ( item->start < m_epgView->startTime() )
m_epgView->setStartTime( item->start );
m_epgView->updateEvent( item );
break; break;
} }
} }
if ( !item ) if ( !alreadyIn )
{ {
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;
m_events.insert( channelName, item ); m_events.insert( channelName, item );
if ( item->start < m_epgView->startTime() ) if ( item->start < m_epgView->startTime() )
m_epgView->setStartTime( item->start ); m_epgView->setStartTime( item->start );
m_epgView->addEvent( item ); m_epgView->addEvent( item );
} }
else
delete item;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment