intf_thread_t *_p_intf )
: QWidget( parent ), p_intf( _p_intf )
{
- QGridLayout *l = new QGridLayout( this );
+ QGridLayout *metaLayout = new QGridLayout( this );
+
int line = 0; /* Counter for GridLayout */
p_input = NULL;
#define ADD_META( string, widget ) { \
- l->addWidget( new QLabel( qtr( string ) + " :" ), line, 0 ); \
+ metaLayout->addWidget( new QLabel( qtr( string ) + " :" ), line, 0 ); \
widget = new QLineEdit; \
- l->addWidget( widget, line, 1, 1, 9 ); \
+ metaLayout->addWidget( widget, line, 1, 1, 9 ); \
line++; }
-
+
/* Title, artist and album*/
ADD_META( VLC_META_TITLE, title_text ); /* OK */
ADD_META( VLC_META_ARTIST, artist_text ); /* OK */
/* Genre Name */
/* FIXME List id3genres.h is not includable yet ? */
genre_text = new QLineEdit;
- l->addWidget( new QLabel( qtr( VLC_META_GENRE ) + " :" ), line, 0 );
- l->addWidget( genre_text, line, 1, 1, 6 );
-
- /* Date (Should be in years) */
- date_text = new QSpinBox; setSpinBounds( date_text );
- l->addWidget( new QLabel( qtr( VLC_META_DATE ) + " :" ), line, 7 );
- l->addWidget( date_text, line, 8, 1, 2 );
+ metaLayout->addWidget( new QLabel( qtr( VLC_META_GENRE ) + " :" ), line, 0 );
+ metaLayout->addWidget( genre_text, line, 1, 1, 4 );
+
+ /* Number - on the same line */
+ metaLayout->addWidget( new QLabel( qtr( "Track Number" ) + " :" ),
+ line, 5, 1, 2 );
+ seqnum_text = new QLineEdit;
+ seqnum_text->setInputMask("0000");
+ seqnum_text->setAlignment( Qt::AlignRight );
+ metaLayout->addWidget( seqnum_text, line, 7, 1, 3 );
line++;
- /* Number and Rating */
- l->addWidget( new QLabel( qtr( "Track number/Position" ) + " :" ),
- line, 0 );
- seqnum_text = new QSpinBox; setSpinBounds( seqnum_text );
- l->addWidget( seqnum_text, line, 1, 1, 4 );
-
- l->addWidget( new QLabel( qtr( VLC_META_RATING ) + " :" ), line, 5 );
- rating_text = new QSpinBox; setSpinBounds( rating_text) ;
- l->addWidget( rating_text, line, 6, 1, 4 );
- line++;
-
- /* Now Playing ? */
- ADD_META( VLC_META_NOW_PLAYING, nowplaying_text );
-
- /* Language and settings */
- l->addWidget( new QLabel( qfu( VLC_META_LANGUAGE ) + " :" ), line, 0 );
+ /* Date (Should be in years) */
+ date_text = new QLineEdit;
+ date_text->setInputMask("0000");
+ date_text->setAlignment( Qt::AlignRight );
+ metaLayout->addWidget( new QLabel( qtr( VLC_META_DATE ) + " :" ), line, 0 );
+ metaLayout->addWidget( date_text, line, 1, 1, 3 );
+
+ /* Rating - on the same line */
+ metaLayout->addWidget( new QLabel( qtr( VLC_META_RATING ) + " :" ), line, 4, 1, 2 );
+ rating_text = new QSpinBox; setSpinBounds( rating_text );
+ metaLayout->addWidget( rating_text, line, 6, 1, 1 );
+
+ /* Language on the same line */
+ metaLayout->addWidget( new QLabel( qfu( VLC_META_LANGUAGE ) + " :" ), line, 7, 1, 2 );
language_text = new QLineEdit;
- l->addWidget( language_text, line, 1, 1, 4 );
- l->addWidget( new QLabel( qtr( VLC_META_SETTING ) + " :" ), line, 5 );
- setting_text = new QLineEdit;
- l->addWidget( setting_text, line, 6, 1, 4 );
+ language_text->setReadOnly( true );
+ metaLayout->addWidget( language_text, line, 9, 1, 1 );
line++;
/* ART_URL */
art_cover->setMaximumWidth( 128 );
art_cover->setScaledContents( true );
art_cover->setPixmap( QPixmap( ":/noart.png" ) );
- l->addWidget( art_cover, line, 8, 4, 2 );
+ metaLayout->addWidget( art_cover, line, 8, 4, 2 );
+
+/* Settings is unused */
+/* l->addWidget( new QLabel( qtr( VLC_META_SETTING ) + " :" ), line, 5 );
+ setting_text = new QLineEdit;
+ l->addWidget( setting_text, line, 6, 1, 4 ); */
+/* Less used metadata */
#define ADD_META_2( string, widget ) { \
- l->addWidget( new QLabel( qtr( string ) + " :" ), line, 0 ); \
+ metaLayout->addWidget( new QLabel( qtr( string ) + " :" ), line, 0 ); \
widget = new QLineEdit; \
- l->addWidget( widget, line, 1, 1, 7 ); \
+ metaLayout->addWidget( widget, line, 1, 1, 7 ); \
line++; }
-
- ADD_META_2( VLC_META_COPYRIGHT, copyright_text );
+
+ /* Now Playing - Useful for live feeds (HTTP, DVB, ETC...) */
+ ADD_META_2( VLC_META_NOW_PLAYING, nowplaying_text );
+ nowplaying_text->setReadOnly( true );
ADD_META_2( VLC_META_PUBLISHER, publisher_text );
+ ADD_META_2( VLC_META_COPYRIGHT, copyright_text );
+ ADD_META_2( "Comments", description_text );
- ADD_META_2( VLC_META_ENCODED_BY, publisher_text );
- ADD_META_2( VLC_META_DESCRIPTION, description_text );
+/* useless metadata */
+ //ADD_META_2( VLC_META_ENCODED_BY, encodedby_text );
/* ADD_META( TRACKID ) Useless ? */
/* ADD_URI - DO not show it, done outside */
#undef ADD_META
#undef ADD_META_2
+
+ CONNECT( title_text, textEdited( QString ), this, enterEditMode() );
+ CONNECT( artist_text, textEdited( QString ), this, enterEditMode() );
+ CONNECT( collection_text, textEdited( QString ), this, enterEditMode() );
+ CONNECT( genre_text, textEdited( QString ), this, enterEditMode() );
+ CONNECT( seqnum_text, textEdited( QString ), this, enterEditMode() );
+
+ CONNECT( date_text, textEdited( QString ), this, enterEditMode() );
+ CONNECT( description_text, textEdited( QString ), this, enterEditMode() );
+/* CONNECT( rating_text, valueChanged( QString ), this, enterEditMode( QString ) );*/
+
+ /* We are not yet in Edit Mode */
+ b_inEditMode = false;
}
MetaPanel::~MetaPanel(){}
+/**
+ * Update all the MetaData and art on an "item-changed" event
+ **/
+void MetaPanel::update( input_item_t *p_item )
+{
+ /* Don't update if you are in edit mode */
+ if( b_inEditMode ) return;
+
+ char *psz_meta;
+#define UPDATE_META( meta, widget ) { \
+ psz_meta = input_item_Get##meta( p_item ); \
+ if( !EMPTY_STR( psz_meta ) ) \
+ widget->setText( qfu( psz_meta ) ); \
+ else \
+ widget->setText( "" ); } \
+ free( psz_meta );
+
+#define UPDATE_META_INT( meta, widget ) { \
+ psz_meta = input_item_Get##meta( p_item ); \
+ if( !EMPTY_STR( psz_meta ) ) \
+ widget->setValue( atoi( psz_meta ) ); } \
+ free( psz_meta );
+
+ /* Name / Title */
+ psz_meta = input_item_GetTitle( p_item );
+ char *psz_name = input_item_GetName( p_item );
+ if( !EMPTY_STR( psz_meta ) )
+ title_text->setText( qfu( psz_meta ) );
+ else if( !EMPTY_STR( psz_name ) )
+ title_text->setText( qfu( psz_name ) );
+ else title_text->setText( "" );
+ free( psz_meta );
+ free( psz_name );
+
+ /* URL / URI */
+ psz_meta = input_item_GetURL( p_item );
+ if( !EMPTY_STR( psz_meta ) )
+ {
+ emit uriSet( QString( psz_meta ) );
+ free( psz_meta );
+ }
+ else
+ {
+ free( psz_meta );
+ psz_meta = input_item_GetURI( p_item );
+ if( !EMPTY_STR( psz_meta ) )
+ emit uriSet( QString( psz_meta ) );
+ }
+
+ /* Other classic though */
+ UPDATE_META( Artist, artist_text );
+ UPDATE_META( Genre, genre_text );
+ UPDATE_META( Copyright, copyright_text );
+ UPDATE_META( Album, collection_text );
+ UPDATE_META( Description, description_text );
+ UPDATE_META( Language, language_text );
+ UPDATE_META( NowPlaying, nowplaying_text );
+ UPDATE_META( Publisher, publisher_text );
+// UPDATE_META( Setting, setting_text );
+// UPDATE_META( EncodedBy, encodedby_text );
+
+ UPDATE_META( Date, date_text );
+ UPDATE_META( TrackNum, seqnum_text );
+ UPDATE_META_INT( Rating, rating_text );
+
+#undef UPDATE_META_INT
+#undef UPDATE_META
+
+ /* Art Urls */
+ psz_meta = input_item_GetArtURL( p_item );
+ if( psz_meta && !strncmp( psz_meta, "file://", 7 ) )
+ {
+ QString artUrl = qfu( psz_meta ).replace( "file://",QString("" ) );
+ art_cover->setPixmap( QPixmap( artUrl ) );
+ }
+ else
+ art_cover->setPixmap( QPixmap( ":/noart.png" ) );
+ free( psz_meta );
+}
+
/**
* Save the MetaData, triggered by parent->save Button
**/
void MetaPanel::saveMeta()
{
playlist_t *p_playlist;
+ char psz[5];
meta_export_t p_export;
p_export.p_item = p_input;
return;
/* we can write meta data only in a file */
- if( ( p_input->i_type == ITEM_TYPE_AFILE ) || \
- ( p_input->i_type == ITEM_TYPE_VFILE ) )
- /* some audio files are detected as video files */
+ vlc_mutex_lock( &p_input->lock );
+ int i_type = p_input->i_type;
+ vlc_mutex_unlock( &p_input->lock );
+ if( i_type == ITEM_TYPE_FILE )
{
- char *psz_uri = p_input->psz_uri;
+ char *psz_uri_orig = input_item_GetURI( p_input );
+ char *psz_uri = psz_uri_orig;
if( !strncmp( psz_uri, "file://", 7 ) )
psz_uri += 7; /* strlen("file://") = 7 */
p_export.psz_file = strndup( psz_uri, PATH_MAX );
+ free( psz_uri_orig );
}
else
return;
/* now we read the modified meta data */
- free( p_input->p_meta->psz_artist );
- p_input->p_meta->psz_artist = strdup( qtu( artist_text->text() ) );
- free( p_input->p_meta->psz_album );
- p_input->p_meta->psz_album = strdup( qtu( collection_text->text() ) );
- free( p_input->p_meta->psz_genre );
- p_input->p_meta->psz_genre = strdup( qtu( genre_text->text() ) );
- free( p_input->p_meta->psz_date );
- p_input->p_meta->psz_date = (char*) malloc(5);
- snprintf( p_input->p_meta->psz_date, 5, "%d", date_text->value() );
- free( p_input->p_meta->psz_tracknum );
- p_input->p_meta->psz_tracknum = (char*) malloc(5);
- snprintf( p_input->p_meta->psz_tracknum, 5, "%d", seqnum_text->value() );
- free( p_input->p_meta->psz_title );
- p_input->p_meta->psz_title = strdup( qtu( title_text->text() ) );
+ input_item_SetTitle( p_input, qtu( title_text->text() ) );
+ input_item_SetArtist( p_input, qtu( artist_text->text() ) );
+ input_item_SetAlbum( p_input, qtu( collection_text->text() ) );
+ input_item_SetGenre( p_input, qtu( genre_text->text() ) );
+ input_item_SetTrackNum( p_input, qtu( seqnum_text->text() ) );
+ input_item_SetDate( p_input, qtu( date_text->text() ) );
- p_playlist = pl_Yield( p_intf );
+ input_item_SetCopyright( p_input, qtu( copyright_text->text() ) );
+ input_item_SetPublisher( p_input, qtu( publisher_text->text() ) );
+ input_item_SetDescription( p_input, qtu( description_text->text() ) );
+ p_playlist = pl_Yield( p_intf );
PL_LOCK;
p_playlist->p_private = &p_export;
module_Unneed( p_playlist, p_mod );
PL_UNLOCK;
pl_Release( p_playlist );
+
+ /* Reset the status of the mode. No need to emit any signal */
+ b_inEditMode = false;
}
-/**
- * Update all the MetaData and art on an "item-changed" event
- **/
-void MetaPanel::update( input_item_t *p_item )
-{
- if( !p_item->p_meta )
- return;
- char *psz_meta;
-#define UPDATE_META( meta, widget ) { \
- psz_meta = p_item->p_meta->psz_##meta; \
- if( !EMPTY_STR( psz_meta ) ) \
- widget->setText( qfu( psz_meta ) ); \
- else \
- widget->setText( "" ); }
-
-#define UPDATE_META_INT( meta, widget ) { \
- psz_meta = p_item->p_meta->psz_##meta; \
- if( !EMPTY_STR( psz_meta ) ) \
- widget->setValue( atoi( psz_meta ) ); }
- /* Name / Title */
- psz_meta = p_item->p_meta->psz_title;
- if( !EMPTY_STR( psz_meta ) )
- title_text->setText( qfu( psz_meta ) );
- else if( !EMPTY_STR( p_item->psz_name ) )
- title_text->setText( qfu( p_item->psz_name ) );
- else title_text->setText( "" );
+bool MetaPanel::isInEditMode()
+{
+ return b_inEditMode;
+}
- /* URL / URI */
- psz_meta = p_item->p_meta->psz_url;
- if( !EMPTY_STR( psz_meta ) )
- emit uriSet( QString( psz_meta ) );
- else if( !EMPTY_STR( p_item->psz_uri ) )
- emit uriSet( QString( p_item->psz_uri ) );
+void MetaPanel::enterEditMode()
+{
+ setEditMode( true );
+}
- /* Other classic though */
- UPDATE_META( artist, artist_text );
- UPDATE_META( genre, genre_text );
- UPDATE_META( copyright, copyright_text );
- UPDATE_META( album, collection_text );
- UPDATE_META( description, description_text );
- UPDATE_META( language, language_text );
- UPDATE_META( nowplaying, nowplaying_text );
- UPDATE_META( publisher, publisher_text );
- UPDATE_META( setting, setting_text );
-
- UPDATE_META_INT( date, date_text );
- UPDATE_META_INT( tracknum, seqnum_text );
- UPDATE_META_INT( rating, rating_text );
+void MetaPanel::setEditMode( bool b_editing )
+{
+ b_inEditMode = b_editing;
+ if( b_editing )emit editing();
+}
-#undef UPDATE_META
+void MetaPanel::setInput( input_item_t *input )
+{
+ if( b_inEditMode ) return;
- /* Art Urls */
- psz_meta = p_item->p_meta->psz_arturl;
- if( psz_meta && !strncmp( psz_meta, "file://", 7 ) )
- {
- QString artUrl = qfu( psz_meta ).replace( "file://",QString("" ) );
- art_cover->setPixmap( QPixmap( artUrl ) );
- }
- else
- art_cover->setPixmap( QPixmap( ":/noart.png" ) );
+ p_input = input;
}
/*
* Clear all the metadata widgets
- * Unused yet
+ * Unused yet FIXME
*/
-void MetaPanel::clear(){}
+void MetaPanel::clear(){
+ setEditMode( false );
+}
/**
* Second Panel - Shows the extra metadata in a tree, non editable.
}
/**
- * Update the Extra Metadata from p_meta->i_extras
+ * Update the Extra Metadata from p_meta->i_extras
**/
void ExtraMetaPanel::update( input_item_t *p_item )
{
+ vlc_mutex_lock( &p_item->lock );
vlc_meta_t *p_meta = p_item->p_meta;
if( !p_meta )
return;
items.append( new QTreeWidgetItem ( extraMetaTree, tempItem ) );
free( ppsz_allkey[i] );
}
+ vlc_mutex_unlock( &p_item->lock );
free( ppsz_allkey );
extraMetaTree->addTopLevelItems( items );
}
**/
/*
void InfoPanel::saveCodecsInfo()
-{
-
-}
+{}
*/
/**
catName->addChild( itemName ); }
/* Create the main categories */
- CREATE_CATEGORY( input, qtr("Input") );
+ CREATE_CATEGORY( audio, qtr("Audio") );
CREATE_CATEGORY( video, qtr("Video") );
+ CREATE_CATEGORY( input, qtr("Input") );
CREATE_CATEGORY( streaming, qtr("Streaming") );
- CREATE_CATEGORY( audio, qtr("Audio") );
CREATE_AND_ADD_TO_CAT( read_media_stat, qtr("Read at media"),
"0", input , "kB" );
void InputStatsPanel::clear()
{
}
-
-