videocollection/videocollectionview/inc/videolistwidget.h
author hgs
Thu, 01 Apr 2010 23:03:51 +0300
changeset 32 253cc391d7f9
parent 30 4f111d64a341
child 34 bbb98528c666
permissions -rw-r--r--
201005_2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
30
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:   Videolist content widget
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#ifndef VIDEOLISTWIDGET_H
hgs
parents:
diff changeset
    20
#define VIDEOLISTWIDGET_H
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include <QGraphicsWidget>
hgs
parents:
diff changeset
    23
#include <QPixmap>
hgs
parents:
diff changeset
    24
#include <QModelIndex>
hgs
parents:
diff changeset
    25
#include <qmap.h>
hgs
parents:
diff changeset
    26
#include <qpoint.h>
hgs
parents:
diff changeset
    27
#include <hbview.h>
hgs
parents:
diff changeset
    28
#include <hblistview.h>
hgs
parents:
diff changeset
    29
#include <mpxitemid.h>
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
class VideoSortFilterProxyModel;
hgs
parents:
diff changeset
    32
class HbAction;
hgs
parents:
diff changeset
    33
class HbMenu;
hgs
parents:
diff changeset
    34
class QTimer;
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
class QItemSelection;
hgs
parents:
diff changeset
    37
class VideoServices;
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
/**
hgs
parents:
diff changeset
    40
 * Widget for displaying all videos, either using list- or grid view.
hgs
parents:
diff changeset
    41
 * Widget contains 2 widgets to be used for different orientation in the stacked layout.
hgs
parents:
diff changeset
    42
 *
hgs
parents:
diff changeset
    43
 * Depending on the orientation and it's change, corresponding view is set active.
hgs
parents:
diff changeset
    44
 *
hgs
parents:
diff changeset
    45
 */
hgs
parents:
diff changeset
    46
class VideoListWidget : public HbListView
hgs
parents:
diff changeset
    47
{
hgs
parents:
diff changeset
    48
    Q_OBJECT
hgs
parents:
diff changeset
    49
    Q_DISABLE_COPY(VideoListWidget)
hgs
parents:
diff changeset
    50
public:
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
	enum TVideoListLevel
hgs
parents:
diff changeset
    53
    {
hgs
parents:
diff changeset
    54
        ELevelCategory = 2,
hgs
parents:
diff changeset
    55
        ELevelVideos   = 3
hgs
parents:
diff changeset
    56
    };
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
	enum TVideoListType
hgs
parents:
diff changeset
    59
    {
hgs
parents:
diff changeset
    60
        EUnknown,
hgs
parents:
diff changeset
    61
		EAllVideos,        // list displaying all videos
hgs
parents:
diff changeset
    62
        ECollections,      // list displaying all collections
hgs
parents:
diff changeset
    63
        EDefaultColItems,  // list displying videos in default collection
hgs
parents:
diff changeset
    64
        EUserColItems      // list displaying videos in user defined collection
hgs
parents:
diff changeset
    65
    };
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
    /**
hgs
parents:
diff changeset
    68
     * Contructor.
hgs
parents:
diff changeset
    69
     *
hgs
parents:
diff changeset
    70
     * @param parent parent of this widget
hgs
parents:
diff changeset
    71
     */
hgs
parents:
diff changeset
    72
    VideoListWidget(HbView *parent = 0);
hgs
parents:
diff changeset
    73
hgs
parents:
diff changeset
    74
    /**
hgs
parents:
diff changeset
    75
     * Destructor.
hgs
parents:
diff changeset
    76
     *
hgs
parents:
diff changeset
    77
     */
hgs
parents:
diff changeset
    78
    virtual ~VideoListWidget();
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
    /**
hgs
parents:
diff changeset
    81
     * Method creates colleciton wrapper, grid and list views,
hgs
parents:
diff changeset
    82
     * layout and activates correct view based on the current orientation
hgs
parents:
diff changeset
    83
     * 
hgs
parents:
diff changeset
    84
     * @param model Model for this list view.
hgs
parents:
diff changeset
    85
     * @return int 0 initialization ok, < 0 if fails.
hgs
parents:
diff changeset
    86
     */
hgs
parents:
diff changeset
    87
    int initialize(VideoSortFilterProxyModel &model, VideoServices* videoServices  = 0);
hgs
parents:
diff changeset
    88
hgs
parents:
diff changeset
    89
    /**
hgs
parents:
diff changeset
    90
     * Method enables and displays current active view
hgs
parents:
diff changeset
    91
     *
hgs
parents:
diff changeset
    92
     * @return int 0 initialization ok, < 0 if fails.
hgs
parents:
diff changeset
    93
     */
hgs
parents:
diff changeset
    94
    int activate();
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
    /**
hgs
parents:
diff changeset
    97
     * Method enables and displays current active view
hgs
parents:
diff changeset
    98
     *
hgs
parents:
diff changeset
    99
     * @return int 0 initialization ok, < 0 if fails.
hgs
parents:
diff changeset
   100
     */
hgs
parents:
diff changeset
   101
    int activate(VideoListWidget::TVideoListLevel role);
hgs
parents:
diff changeset
   102
hgs
parents:
diff changeset
   103
    /**
hgs
parents:
diff changeset
   104
     * Method disables and hides current active view
hgs
parents:
diff changeset
   105
     *
hgs
parents:
diff changeset
   106
     */
hgs
parents:
diff changeset
   107
    void deactivate();
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
    /**
hgs
parents:
diff changeset
   110
     * Used for resolving widget's current type
hgs
parents:
diff changeset
   111
     *
hgs
parents:
diff changeset
   112
     * @return TVideoListType current level.
hgs
parents:
diff changeset
   113
     */
hgs
parents:
diff changeset
   114
    TVideoListType getType();
hgs
parents:
diff changeset
   115
    
hgs
parents:
diff changeset
   116
    /**
hgs
parents:
diff changeset
   117
     * returns widget's model
hgs
parents:
diff changeset
   118
     * 
hgs
parents:
diff changeset
   119
     * @return VideoSortFilterProxyModel*
hgs
parents:
diff changeset
   120
     */
hgs
parents:
diff changeset
   121
    VideoSortFilterProxyModel& getModel();
hgs
parents:
diff changeset
   122
    
hgs
parents:
diff changeset
   123
protected:
hgs
parents:
diff changeset
   124
    
hgs
parents:
diff changeset
   125
    /**
hgs
parents:
diff changeset
   126
     * Called by the fw when some item is tapped. Method check that
hgs
parents:
diff changeset
   127
     * index is valid and calls open item for collectionwrapper to
hgs
parents:
diff changeset
   128
     * open media object throught collection.
hgs
parents:
diff changeset
   129
     * 
hgs
parents:
diff changeset
   130
     * @param midelIndex, item's index
hgs
parents:
diff changeset
   131
     */
hgs
parents:
diff changeset
   132
    void emitActivated (const QModelIndex &modelIndex);
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
signals:
hgs
parents:
diff changeset
   135
hgs
parents:
diff changeset
   136
    /**
hgs
parents:
diff changeset
   137
     * Command signal.
hgs
parents:
diff changeset
   138
     *
hgs
parents:
diff changeset
   139
     * @param int command id
hgs
parents:
diff changeset
   140
     */
hgs
parents:
diff changeset
   141
    void command(int);
hgs
parents:
diff changeset
   142
hgs
parents:
diff changeset
   143
    /**
hgs
parents:
diff changeset
   144
     * Signals collection view's state. Used to indicate
hgs
parents:
diff changeset
   145
     * view incase some collection item is opened
hgs
parents:
diff changeset
   146
     *
hgs
parents:
diff changeset
   147
     * @param true if opened, false if closed.
hgs
parents:
diff changeset
   148
     * @param optional name string
hgs
parents:
diff changeset
   149
     */
hgs
parents:
diff changeset
   150
    void collectionOpened(bool, const QString&);
hgs
parents:
diff changeset
   151
hgs
parents:
diff changeset
   152
    /**
hgs
parents:
diff changeset
   153
     * signal is connected to service's itemSelected -slot
hgs
parents:
diff changeset
   154
     */
hgs
parents:
diff changeset
   155
    void fileUri(const QString&);
hgs
parents:
diff changeset
   156
hgs
parents:
diff changeset
   157
protected slots:
hgs
parents:
diff changeset
   158
    /**
hgs
parents:
diff changeset
   159
     * Signaled by the fw during long press and indicating that popupmenu
hgs
parents:
diff changeset
   160
     * concerning particular item is to be opened.
hgs
parents:
diff changeset
   161
     * Saves current selected item's index to mCurrentIndex
hgs
parents:
diff changeset
   162
     */
hgs
parents:
diff changeset
   163
    void longPressGesture (const QPointF &point);
hgs
parents:
diff changeset
   164
hgs
parents:
diff changeset
   165
private slots:
hgs
parents:
diff changeset
   166
hgs
parents:
diff changeset
   167
	/**
hgs
parents:
diff changeset
   168
     * Signaled for item share.
hgs
parents:
diff changeset
   169
     *
hgs
parents:
diff changeset
   170
     */
hgs
parents:
diff changeset
   171
    void shareItemSlot();
hgs
parents:
diff changeset
   172
hgs
parents:
diff changeset
   173
    /**
hgs
parents:
diff changeset
   174
     * Signaled for one item deletion.
hgs
parents:
diff changeset
   175
     *
hgs
parents:
diff changeset
   176
     */
hgs
parents:
diff changeset
   177
    void deleteItemSlot();
hgs
parents:
diff changeset
   178
hgs
parents:
diff changeset
   179
    /**
hgs
parents:
diff changeset
   180
     * Signaled for item rename.
hgs
parents:
diff changeset
   181
     *
hgs
parents:
diff changeset
   182
     */
hgs
parents:
diff changeset
   183
    void renameSlot();
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
    /**
hgs
parents:
diff changeset
   186
     * Signaled to play all items.
hgs
parents:
diff changeset
   187
     *
hgs
parents:
diff changeset
   188
     */
hgs
parents:
diff changeset
   189
    void playAllSlot();
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
    /**
hgs
parents:
diff changeset
   192
     * Signaled to add an item into currently open collection.
hgs
parents:
diff changeset
   193
     *
hgs
parents:
diff changeset
   194
     */
hgs
parents:
diff changeset
   195
    void addItemSlot();
hgs
parents:
diff changeset
   196
hgs
parents:
diff changeset
   197
    /**
hgs
parents:
diff changeset
   198
     * Signaled to add an item into a collection.
hgs
parents:
diff changeset
   199
     *
hgs
parents:
diff changeset
   200
     */
hgs
parents:
diff changeset
   201
    void addToCollectionSlot();
hgs
parents:
diff changeset
   202
hgs
parents:
diff changeset
   203
    /**
hgs
parents:
diff changeset
   204
     * Signaled when details will be selected from the videolist's
hgs
parents:
diff changeset
   205
     * context menu. Maps mCurrentIndex to model's source index and
hgs
parents:
diff changeset
   206
     * calls collection wrapper to open details
hgs
parents:
diff changeset
   207
     *
hgs
parents:
diff changeset
   208
     */
hgs
parents:
diff changeset
   209
    void openDetailsSlot();
hgs
parents:
diff changeset
   210
hgs
parents:
diff changeset
   211
    /**
hgs
parents:
diff changeset
   212
     * Signaled when the application has been lauched as a service and
hgs
parents:
diff changeset
   213
     * playback is initialized from context menu.
hgs
parents:
diff changeset
   214
     *
hgs
parents:
diff changeset
   215
     */
hgs
parents:
diff changeset
   216
    void playItemSlot();
hgs
parents:
diff changeset
   217
hgs
parents:
diff changeset
   218
    /**
hgs
parents:
diff changeset
   219
     * Signaled when stepping back from collection in collection view
hgs
parents:
diff changeset
   220
     *
hgs
parents:
diff changeset
   221
     */
hgs
parents:
diff changeset
   222
    void back();
hgs
parents:
diff changeset
   223
	
hgs
parents:
diff changeset
   224
	/**
hgs
parents:
diff changeset
   225
	 * Signaled when view scrolling ends, initiates thumbnail fetching
hgs
parents:
diff changeset
   226
	 * at index of first visible item. 
hgs
parents:
diff changeset
   227
	 *
hgs
parents:
diff changeset
   228
	 */
hgs
parents:
diff changeset
   229
	void scrollingEndedSlot();
hgs
parents:
diff changeset
   230
	
hgs
parents:
diff changeset
   231
	/**
hgs
parents:
diff changeset
   232
	 * Signaled when view scroll position changes, initiates timer to 
hgs
parents:
diff changeset
   233
	 * fetch thumbnails at index of first visible item.
hgs
parents:
diff changeset
   234
	 */
hgs
parents:
diff changeset
   235
	void scrollPositionChangedSlot(const QPointF &newPosition);
hgs
parents:
diff changeset
   236
	
hgs
parents:
diff changeset
   237
    // TODO: following can be removed after all implementation ready
hgs
parents:
diff changeset
   238
    /**
hgs
parents:
diff changeset
   239
     * Slot is connected into item signals that are not yet implemented.
hgs
parents:
diff changeset
   240
     * Slot shows "Not yet implemented" note
hgs
parents:
diff changeset
   241
     */
hgs
parents:
diff changeset
   242
    void debugNotImplementedYet();
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
private:
hgs
parents:
diff changeset
   245
hgs
parents:
diff changeset
   246
    enum TContextActionIds
hgs
parents:
diff changeset
   247
    {
hgs
parents:
diff changeset
   248
        EActionShare = 1,
hgs
parents:
diff changeset
   249
        EActionDelete,
hgs
parents:
diff changeset
   250
        EActionDetails,
hgs
parents:
diff changeset
   251
        EACtionRemoveFromCollection,
hgs
parents:
diff changeset
   252
        EACtionAddToCollection,
hgs
parents:
diff changeset
   253
        EACtionRemoveCollection,
hgs
parents:
diff changeset
   254
        EActionAddVideos,
hgs
parents:
diff changeset
   255
        EActionRename,
hgs
parents:
diff changeset
   256
        EActionSetThumb,
hgs
parents:
diff changeset
   257
    	EActionPlay
hgs
parents:
diff changeset
   258
    };
hgs
parents:
diff changeset
   259
hgs
parents:
diff changeset
   260
    /**
hgs
parents:
diff changeset
   261
     * Method creates popup menu for list items.
hgs
parents:
diff changeset
   262
     *
hgs
parents:
diff changeset
   263
     */
hgs
parents:
diff changeset
   264
    void createContextMenu();
hgs
parents:
diff changeset
   265
hgs
parents:
diff changeset
   266
    /**
hgs
parents:
diff changeset
   267
     * Method sets correct popup menu for specific list items.
hgs
parents:
diff changeset
   268
     *
hgs
parents:
diff changeset
   269
     */
hgs
parents:
diff changeset
   270
    void setContextMenu(bool isDefaultCollection);
hgs
parents:
diff changeset
   271
hgs
parents:
diff changeset
   272
    /**
hgs
parents:
diff changeset
   273
     * Method connects signals needed by the widget
hgs
parents:
diff changeset
   274
     *
hgs
parents:
diff changeset
   275
     * @return int 0 if connect ok, < 0 if connect fails
hgs
parents:
diff changeset
   276
     */
hgs
parents:
diff changeset
   277
    int connectSignals();
hgs
parents:
diff changeset
   278
hgs
parents:
diff changeset
   279
    /**
hgs
parents:
diff changeset
   280
     * Method disconnects signals needed by the widget
hgs
parents:
diff changeset
   281
     *
hgs
parents:
diff changeset
   282
     */
hgs
parents:
diff changeset
   283
    void disConnectSignals();
hgs
parents:
diff changeset
   284
hgs
parents:
diff changeset
   285
private:
hgs
parents:
diff changeset
   286
hgs
parents:
diff changeset
   287
    /**
hgs
parents:
diff changeset
   288
     * Provided model
hgs
parents:
diff changeset
   289
     * Not own.
hgs
parents:
diff changeset
   290
     */
hgs
parents:
diff changeset
   291
    VideoSortFilterProxyModel *mModel;
hgs
parents:
diff changeset
   292
hgs
parents:
diff changeset
   293
    /**
hgs
parents:
diff changeset
   294
     * pointer to videoservices instance
hgs
parents:
diff changeset
   295
     */
hgs
parents:
diff changeset
   296
    VideoServices* mVideoServices;
hgs
parents:
diff changeset
   297
hgs
parents:
diff changeset
   298
    /**
hgs
parents:
diff changeset
   299
     * map containing pointers to main menu actions
hgs
parents:
diff changeset
   300
     */
hgs
parents:
diff changeset
   301
    QMap<TContextActionIds, HbAction*> mContextMenuActions;
hgs
parents:
diff changeset
   302
hgs
parents:
diff changeset
   303
    /**
hgs
parents:
diff changeset
   304
     * current level indicating content currently showing: 
hgs
parents:
diff changeset
   305
     * category or videos
hgs
parents:
diff changeset
   306
     */
hgs
parents:
diff changeset
   307
	VideoListWidget::TVideoListLevel mCurrentLevel;
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
	/**
hgs
parents:
diff changeset
   310
     * True if signals have been connected
hgs
parents:
diff changeset
   311
     */
hgs
parents:
diff changeset
   312
	bool                       mSignalsConnected;
hgs
parents:
diff changeset
   313
	
hgs
parents:
diff changeset
   314
	/**
hgs
parents:
diff changeset
   315
     * True if details plugin is ready
hgs
parents:
diff changeset
   316
     */
hgs
parents:
diff changeset
   317
	bool                       mDetailsReady;
hgs
parents:
diff changeset
   318
hgs
parents:
diff changeset
   319
    /**
hgs
parents:
diff changeset
   320
     * Boolean for knowing when the app was started as a service.
hgs
parents:
diff changeset
   321
     */
hgs
parents:
diff changeset
   322
	bool                       mIsService;
hgs
parents:
diff changeset
   323
hgs
parents:
diff changeset
   324
	/**
hgs
parents:
diff changeset
   325
     * Secondary softkey action object
hgs
parents:
diff changeset
   326
     */
hgs
parents:
diff changeset
   327
	HbAction 				   *mSecSkAction;
hgs
parents:
diff changeset
   328
hgs
parents:
diff changeset
   329
    /**
hgs
parents:
diff changeset
   330
     * Item sensitive context menu
hgs
parents:
diff changeset
   331
     */
hgs
parents:
diff changeset
   332
    HbMenu                      *mContextMenu;
hgs
parents:
diff changeset
   333
hgs
parents:
diff changeset
   334
    /**
hgs
parents:
diff changeset
   335
     * Last opened item id is saved when collection is opened from the 
hgs
parents:
diff changeset
   336
	 * collections -list. Value used to indentify the type of list.
hgs
parents:
diff changeset
   337
     */
hgs
parents:
diff changeset
   338
    TMPXItemId                 mLastOpenItemId;
hgs
parents:
diff changeset
   339
    
hgs
parents:
diff changeset
   340
    /**
hgs
parents:
diff changeset
   341
     * Timer used to report thumbnail fetches class index of 
hgs
parents:
diff changeset
   342
     * first visible item when view is scrolling. 
hgs
parents:
diff changeset
   343
     */
hgs
parents:
diff changeset
   344
    QTimer                      *mScrollPositionTimer;
hgs
parents:
diff changeset
   345
};
hgs
parents:
diff changeset
   346
hgs
parents:
diff changeset
   347
#endif // VIDEOLISTWIDGET_H