videocollection/videocollectionwrapper/inc/videocollectionwrapper.h
author hgs
Thu, 01 Apr 2010 23:22:15 +0300
changeset 34 bbb98528c666
parent 30 4f111d64a341
child 36 8aed59de29f9
permissions -rw-r--r--
201009
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
30
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 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:   VideoCollectionWrapper class definition
hgs
parents:
diff changeset
    15
* 
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef __VIDEOCOLLECTIONWRAPPER_H__
hgs
parents:
diff changeset
    19
#define __VIDEOCOLLECTIONWRAPPER_H__
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
// INCLUDES
hgs
parents:
diff changeset
    23
#include <QObject>
hgs
parents:
diff changeset
    24
#include <qabstractitemmodel.h>
hgs
parents:
diff changeset
    25
#include "videocollectionexport.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
// FORWARD DECLARATIONS
hgs
parents:
diff changeset
    28
class VideoCollectionWrapperPrivate;
hgs
parents:
diff changeset
    29
class VideoSortFilterProxyModel;
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
/**
hgs
parents:
diff changeset
    33
 * Class is used as an interface of the video collection QT wrapper.
hgs
parents:
diff changeset
    34
 * 
hgs
parents:
diff changeset
    35
 * Singleton instance is deleted when it's not used anymore by clients. At instantion time  
hgs
parents:
diff changeset
    36
 * reference count is incremented. Client must call decreaseReferenceCount when it doesn't 
hgs
parents:
diff changeset
    37
 * need the instance anymore. When reference count is 0 the instance is destroyed.
hgs
parents:
diff changeset
    38
 * 
hgs
parents:
diff changeset
    39
 * * Usage:
hgs
parents:
diff changeset
    40
 *  @code
hgs
parents:
diff changeset
    41
 *  #include "videocollectionwrapper.h"
hgs
parents:
diff changeset
    42
 *  #include "videosortfilterproxymodel.h"
hgs
parents:
diff changeset
    43
 *  
hgs
parents:
diff changeset
    44
 *  ...
hgs
parents:
diff changeset
    45
 *  ////
hgs
parents:
diff changeset
    46
 *  // Getting the instances
hgs
parents:
diff changeset
    47
 *  ////
hgs
parents:
diff changeset
    48
 *  VideoCollectionWrapper *wrapper = VideoCollectionWrapper::instance();
hgs
parents:
diff changeset
    49
 * 
hgs
parents:
diff changeset
    50
 *  VideoSortFilterProxyModel *model = wrapper->getModel();
hgs
parents:
diff changeset
    51
 *  ...
hgs
parents:
diff changeset
    52
 *  ////
hgs
parents:
diff changeset
    53
 *  // Opening collection and start fetching video item data
hgs
parents:
diff changeset
    54
 *  ////
hgs
parents:
diff changeset
    55
 *  if(model)
hgs
parents:
diff changeset
    56
 *  {
hgs
parents:
diff changeset
    57
 *      mModel->open(VideoListWidget::ELevelVideos);
hgs
parents:
diff changeset
    58
 *  }
hgs
parents:
diff changeset
    59
 *  // see model documentation for the open funtionality
hgs
parents:
diff changeset
    60
 *
hgs
parents:
diff changeset
    61
 *  /////
hgs
parents:
diff changeset
    62
 *  // Instance is not used anymore. 
hgs
parents:
diff changeset
    63
 *  // Wrapper owns the model, so client should not deallocate it
hgs
parents:
diff changeset
    64
 *  /////
hgs
parents:
diff changeset
    65
 *  wrapper->decreaseReferenceCount();
hgs
parents:
diff changeset
    66
 *  wrapper = 0; // Don't use before new instantion.
hgs
parents:
diff changeset
    67
 * 
hgs
parents:
diff changeset
    68
 *  @endcode
hgs
parents:
diff changeset
    69
 * 
hgs
parents:
diff changeset
    70
 */
hgs
parents:
diff changeset
    71
class VIDEOCOLLECTION_DLL_EXPORT VideoCollectionWrapper : public QObject         
hgs
parents:
diff changeset
    72
{    
hgs
parents:
diff changeset
    73
    /**
hgs
parents:
diff changeset
    74
     * define to be able to use signals and slots
hgs
parents:
diff changeset
    75
     */
hgs
parents:
diff changeset
    76
    Q_OBJECT
hgs
parents:
diff changeset
    77
    
hgs
parents:
diff changeset
    78
public: // Constructor
hgs
parents:
diff changeset
    79
    
34
hgs
parents: 30
diff changeset
    80
    enum TModelType
hgs
parents: 30
diff changeset
    81
    {
hgs
parents: 30
diff changeset
    82
        EAllVideos,
hgs
parents: 30
diff changeset
    83
        ECollections,
hgs
parents: 30
diff changeset
    84
        ECollectionContent,
hgs
parents: 30
diff changeset
    85
        EGeneric
hgs
parents: 30
diff changeset
    86
    };
hgs
parents: 30
diff changeset
    87
    
30
hgs
parents:
diff changeset
    88
    /**
hgs
parents:
diff changeset
    89
     * Returns singleton instance for this class.
hgs
parents:
diff changeset
    90
     * 
hgs
parents:
diff changeset
    91
     * WARNING! Not safe to call this from destructor of another function scope static object!
hgs
parents:
diff changeset
    92
     * 
hgs
parents:
diff changeset
    93
     * @return The singleton instance.
hgs
parents:
diff changeset
    94
     */
34
hgs
parents: 30
diff changeset
    95
    static VideoCollectionWrapper &instance();  
30
hgs
parents:
diff changeset
    96
    
hgs
parents:
diff changeset
    97
	/**
hgs
parents:
diff changeset
    98
     * Returns pointer to model
hgs
parents:
diff changeset
    99
     * 
34
hgs
parents: 30
diff changeset
   100
     * @param type of the model
hgs
parents: 30
diff changeset
   101
     * 
30
hgs
parents:
diff changeset
   102
     * @return address to model or NULL if fails.
hgs
parents:
diff changeset
   103
     */    
34
hgs
parents: 30
diff changeset
   104
    VideoSortFilterProxyModel* getModel(int type);
30
hgs
parents:
diff changeset
   105
hgs
parents:
diff changeset
   106
    /**
hgs
parents:
diff changeset
   107
     * Method can be used by client to emit status signal
hgs
parents:
diff changeset
   108
     * containing status code from particular async status.
hgs
parents:
diff changeset
   109
     * 
hgs
parents:
diff changeset
   110
     * @param statusCode code of status
hgs
parents:
diff changeset
   111
     * 
hgs
parents:
diff changeset
   112
     * @param additional additional information for the code
hgs
parents:
diff changeset
   113
     */
hgs
parents:
diff changeset
   114
    void sendAsyncStatus(int statusCode, QVariant &additional);
hgs
parents:
diff changeset
   115
     
hgs
parents:
diff changeset
   116
signals:     
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
    /**
hgs
parents:
diff changeset
   119
     * Signal that can be emitted by the wrapper to indicate status
hgs
parents:
diff changeset
   120
     * of some async operation.
hgs
parents:
diff changeset
   121
     * 
hgs
parents:
diff changeset
   122
     * See videocollectioncommon.h for codes
hgs
parents:
diff changeset
   123
     * 
hgs
parents:
diff changeset
   124
     * @param status code of status
hgs
parents:
diff changeset
   125
     * 
hgs
parents:
diff changeset
   126
     * @param additional additional information for the code
hgs
parents:
diff changeset
   127
     */
hgs
parents:
diff changeset
   128
    void asyncStatus(int statusCode, QVariant &additional);
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
private:
hgs
parents:
diff changeset
   131
    
hgs
parents:
diff changeset
   132
    /**
hgs
parents:
diff changeset
   133
     * Private contructor.
hgs
parents:
diff changeset
   134
     */    
hgs
parents:
diff changeset
   135
    VideoCollectionWrapper(); 
hgs
parents:
diff changeset
   136
    
hgs
parents:
diff changeset
   137
    /**
hgs
parents:
diff changeset
   138
     * Private destructor.
hgs
parents:
diff changeset
   139
     *
hgs
parents:
diff changeset
   140
     */
hgs
parents:
diff changeset
   141
    virtual ~VideoCollectionWrapper();    
hgs
parents:
diff changeset
   142
    
hgs
parents:
diff changeset
   143
    /**
hgs
parents:
diff changeset
   144
     * disables copy-constructor and assingment operator
hgs
parents:
diff changeset
   145
     */
hgs
parents:
diff changeset
   146
    Q_DISABLE_COPY(VideoCollectionWrapper)    
hgs
parents:
diff changeset
   147
    
hgs
parents:
diff changeset
   148
private:
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
	/**
hgs
parents:
diff changeset
   151
     * d -pointer for actual implementation
hgs
parents:
diff changeset
   152
     */ 
hgs
parents:
diff changeset
   153
    VideoCollectionWrapperPrivate *d;
hgs
parents:
diff changeset
   154
hgs
parents:
diff changeset
   155
    /**
hgs
parents:
diff changeset
   156
     * Reference count.
hgs
parents:
diff changeset
   157
     */
hgs
parents:
diff changeset
   158
    int mReferenceCount;
hgs
parents:
diff changeset
   159
    
hgs
parents:
diff changeset
   160
};
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
#endif  // __VIDEOCOLLECTIONWRAPPER_H__
hgs
parents:
diff changeset
   163
hgs
parents:
diff changeset
   164
// End of file