hswidgetmodel/examples/helloworldwidgetprovider/src/helloworldwidgetprovider.cpp
author hgs
Tue, 23 Mar 2010 23:17:02 +0200
changeset 85 7feec50967db
permissions -rw-r--r--
201003_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
85
7feec50967db 201003_02
hgs
parents:
diff changeset
     1
/*
7feec50967db 201003_02
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
7feec50967db 201003_02
hgs
parents:
diff changeset
     3
* All rights reserved.
7feec50967db 201003_02
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
7feec50967db 201003_02
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
7feec50967db 201003_02
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
7feec50967db 201003_02
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
7feec50967db 201003_02
hgs
parents:
diff changeset
     8
*
7feec50967db 201003_02
hgs
parents:
diff changeset
     9
* Initial Contributors:
7feec50967db 201003_02
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
7feec50967db 201003_02
hgs
parents:
diff changeset
    11
*
7feec50967db 201003_02
hgs
parents:
diff changeset
    12
* Contributors:
7feec50967db 201003_02
hgs
parents:
diff changeset
    13
* 
7feec50967db 201003_02
hgs
parents:
diff changeset
    14
* Description: Example of home screen widget
7feec50967db 201003_02
hgs
parents:
diff changeset
    15
*
7feec50967db 201003_02
hgs
parents:
diff changeset
    16
*/
7feec50967db 201003_02
hgs
parents:
diff changeset
    17
7feec50967db 201003_02
hgs
parents:
diff changeset
    18
#include <hswidget.h>
7feec50967db 201003_02
hgs
parents:
diff changeset
    19
7feec50967db 201003_02
hgs
parents:
diff changeset
    20
#include "helloworldwidgetprovider.h"
7feec50967db 201003_02
hgs
parents:
diff changeset
    21
#include "helloworldwidget.h"
7feec50967db 201003_02
hgs
parents:
diff changeset
    22
7feec50967db 201003_02
hgs
parents:
diff changeset
    23
7feec50967db 201003_02
hgs
parents:
diff changeset
    24
/*!
7feec50967db 201003_02
hgs
parents:
diff changeset
    25
    \ingroup group_helloworld_widget
7feec50967db 201003_02
hgs
parents:
diff changeset
    26
    \class HelloWorldWidgetProvider
7feec50967db 201003_02
hgs
parents:
diff changeset
    27
    \brief Example implementation for home screen widget provider.
7feec50967db 201003_02
hgs
parents:
diff changeset
    28
7feec50967db 201003_02
hgs
parents:
diff changeset
    29
    @page page_creating_widget_provider Creating Home Screen Widget Provider
7feec50967db 201003_02
hgs
parents:
diff changeset
    30
7feec50967db 201003_02
hgs
parents:
diff changeset
    31
    Widgets are exposed to the home screen through widget provider plugins.
7feec50967db 201003_02
hgs
parents:
diff changeset
    32
    A widget can be added to an existing provider or new one can be created.
7feec50967db 201003_02
hgs
parents:
diff changeset
    33
    Widget provider plugins are implemented according to
7feec50967db 201003_02
hgs
parents:
diff changeset
    34
    the <a href="http://doc.trolltech.com/4.4/plugins-howto.html">Qt plugin model</a>.
7feec50967db 201003_02
hgs
parents:
diff changeset
    35
7feec50967db 201003_02
hgs
parents:
diff changeset
    36
    See @ref page_developing_home_screen_widget for the instructions how to create widget for the home screen.
7feec50967db 201003_02
hgs
parents:
diff changeset
    37
7feec50967db 201003_02
hgs
parents:
diff changeset
    38
    The steps to create a widget provider are:
7feec50967db 201003_02
hgs
parents:
diff changeset
    39
    <ol>
7feec50967db 201003_02
hgs
parents:
diff changeset
    40
    <li> Declare a plugin class that inherits from QObject and from the \c IHsWidgetProvider interface.
7feec50967db 201003_02
hgs
parents:
diff changeset
    41
    
7feec50967db 201003_02
hgs
parents:
diff changeset
    42
    <li> Use the Q_INTERFACES() macro to tell Qt's meta-object system about the \c IHsWidgetProvider interface.
7feec50967db 201003_02
hgs
parents:
diff changeset
    43
    
7feec50967db 201003_02
hgs
parents:
diff changeset
    44
    <li> Export the plugin using the Q_EXPORT_PLUGIN2() macro.
7feec50967db 201003_02
hgs
parents:
diff changeset
    45
    
7feec50967db 201003_02
hgs
parents:
diff changeset
    46
    <li> Build the plugin using an suitable .pro file. See @ref page_deploying_widget_provider.
7feec50967db 201003_02
hgs
parents:
diff changeset
    47
    </ol>
7feec50967db 201003_02
hgs
parents:
diff changeset
    48
    
7feec50967db 201003_02
hgs
parents:
diff changeset
    49
    An example (full example source code can be found from section @ref page_developing_home_screen_widget):
7feec50967db 201003_02
hgs
parents:
diff changeset
    50
7feec50967db 201003_02
hgs
parents:
diff changeset
    51
7feec50967db 201003_02
hgs
parents:
diff changeset
    52
Each widget provider plugin has a manifest file that allows searching widgets from the plugin without first loading it.
7feec50967db 201003_02
hgs
parents:
diff changeset
    53
The manifest file contains information on widgets inside the plugin:
7feec50967db 201003_02
hgs
parents:
diff changeset
    54
7feec50967db 201003_02
hgs
parents:
diff changeset
    55
\li \c library The name of the provider plugin binary.
7feec50967db 201003_02
hgs
parents:
diff changeset
    56
\li \c uri     Uniquely identifies the widget.
7feec50967db 201003_02
hgs
parents:
diff changeset
    57
\li \c title   Widget's human-readable name.
7feec50967db 201003_02
hgs
parents:
diff changeset
    58
\li \c iconuri URI of the widget's icon image file.
7feec50967db 201003_02
hgs
parents:
diff changeset
    59
7feec50967db 201003_02
hgs
parents:
diff changeset
    60
Example: Manifest for a widget provider.
7feec50967db 201003_02
hgs
parents:
diff changeset
    61
7feec50967db 201003_02
hgs
parents:
diff changeset
    62
@code
7feec50967db 201003_02
hgs
parents:
diff changeset
    63
<?xml version="1.0" encoding="utf-8"?>
7feec50967db 201003_02
hgs
parents:
diff changeset
    64
<widgetprovider>
7feec50967db 201003_02
hgs
parents:
diff changeset
    65
    <widget library="helloworldwidgetprovider.dll"
7feec50967db 201003_02
hgs
parents:
diff changeset
    66
            uri="homescreen.nokia.com/widget/helloworld"
7feec50967db 201003_02
hgs
parents:
diff changeset
    67
            title="HelloWorld"
7feec50967db 201003_02
hgs
parents:
diff changeset
    68
            iconuri="helloworldwidgetprovider.png"/>
7feec50967db 201003_02
hgs
parents:
diff changeset
    69
</widgetprovider>
7feec50967db 201003_02
hgs
parents:
diff changeset
    70
@endcode
7feec50967db 201003_02
hgs
parents:
diff changeset
    71
7feec50967db 201003_02
hgs
parents:
diff changeset
    72
7feec50967db 201003_02
hgs
parents:
diff changeset
    73
@page page_deploying_widget_provider Deploying Home Screen Widget Provider
7feec50967db 201003_02
hgs
parents:
diff changeset
    74
7feec50967db 201003_02
hgs
parents:
diff changeset
    75
Widget's binaries and manifest file(s) must be deployed to correct folders on emulator and in target. 
7feec50967db 201003_02
hgs
parents:
diff changeset
    76
Below are the needed .pro file for the \c helloworldwidgetprovider.
7feec50967db 201003_02
hgs
parents:
diff changeset
    77
7feec50967db 201003_02
hgs
parents:
diff changeset
    78
For example:
7feec50967db 201003_02
hgs
parents:
diff changeset
    79
@code
7feec50967db 201003_02
hgs
parents:
diff changeset
    80
# helloworldwidgetprovider.pro
7feec50967db 201003_02
hgs
parents:
diff changeset
    81
7feec50967db 201003_02
hgs
parents:
diff changeset
    82
TEMPLATE = lib
7feec50967db 201003_02
hgs
parents:
diff changeset
    83
7feec50967db 201003_02
hgs
parents:
diff changeset
    84
CONFIG += plugin hb
7feec50967db 201003_02
hgs
parents:
diff changeset
    85
LIBS += -lhswidgetmodel
7feec50967db 201003_02
hgs
parents:
diff changeset
    86
7feec50967db 201003_02
hgs
parents:
diff changeset
    87
HEADERS += ./inc/ *.h \
7feec50967db 201003_02
hgs
parents:
diff changeset
    88
           ./helloworldwidget/inc/ *.h
7feec50967db 201003_02
hgs
parents:
diff changeset
    89
7feec50967db 201003_02
hgs
parents:
diff changeset
    90
SOURCES += ./src/ *.cpp \
7feec50967db 201003_02
hgs
parents:
diff changeset
    91
           ./helloworldwidget/src/ *.cpp
7feec50967db 201003_02
hgs
parents:
diff changeset
    92
7feec50967db 201003_02
hgs
parents:
diff changeset
    93
DEPENDPATH += ./inc \
7feec50967db 201003_02
hgs
parents:
diff changeset
    94
              ./src
7feec50967db 201003_02
hgs
parents:
diff changeset
    95
7feec50967db 201003_02
hgs
parents:
diff changeset
    96
symbian: {
7feec50967db 201003_02
hgs
parents:
diff changeset
    97
    INCLUDEPATH += $$APP_LAYER_SYSTEMINCLUDE
7feec50967db 201003_02
hgs
parents:
diff changeset
    98
7feec50967db 201003_02
hgs
parents:
diff changeset
    99
    # get your own symbian uid    
7feec50967db 201003_02
hgs
parents:
diff changeset
   100
    TARGET.UID3 = 0xEABCFE12
7feec50967db 201003_02
hgs
parents:
diff changeset
   101
    TARGET.EPOCALLOWDLLDATA=1
7feec50967db 201003_02
hgs
parents:
diff changeset
   102
    TARGET.CAPABILITY = ALL -TCB
7feec50967db 201003_02
hgs
parents:
diff changeset
   103
    
7feec50967db 201003_02
hgs
parents:
diff changeset
   104
    # add your symbian uid here
7feec50967db 201003_02
hgs
parents:
diff changeset
   105
    PLUGIN_SUBDIR = /private/20022F35/import/widgetregistry/EABCFE12
7feec50967db 201003_02
hgs
parents:
diff changeset
   106
    
7feec50967db 201003_02
hgs
parents:
diff changeset
   107
    pluginstub.sources = $${TARGET}.dll
7feec50967db 201003_02
hgs
parents:
diff changeset
   108
    pluginstub.path = $$PLUGIN_SUBDIR
7feec50967db 201003_02
hgs
parents:
diff changeset
   109
7feec50967db 201003_02
hgs
parents:
diff changeset
   110
    DEPLOYMENT += pluginstub
7feec50967db 201003_02
hgs
parents:
diff changeset
   111
7feec50967db 201003_02
hgs
parents:
diff changeset
   112
    qtplugins.path = $$PLUGIN_SUBDIR
7feec50967db 201003_02
hgs
parents:
diff changeset
   113
    qtplugins.sources += qmakepluginstubs/$${TARGET}.qtplugin
7feec50967db 201003_02
hgs
parents:
diff changeset
   114
    qtplugins.sources += resource/$${TARGET}.manifest
7feec50967db 201003_02
hgs
parents:
diff changeset
   115
    qtplugins.sources += resource/$${TARGET}.png
7feec50967db 201003_02
hgs
parents:
diff changeset
   116
     
7feec50967db 201003_02
hgs
parents:
diff changeset
   117
    for(qtplugin, qtplugins.sources):BLD_INF_RULES.prj_exports += "./$$qtplugin z:$$qtplugins.path/$$basename(qtplugin)" 
7feec50967db 201003_02
hgs
parents:
diff changeset
   118
}
7feec50967db 201003_02
hgs
parents:
diff changeset
   119
7feec50967db 201003_02
hgs
parents:
diff changeset
   120
@endcode
7feec50967db 201003_02
hgs
parents:
diff changeset
   121
7feec50967db 201003_02
hgs
parents:
diff changeset
   122
For detailed information on DEPLOYMENT macro, see <a HREF="http://pepper.troll.no/s60prereleases/doc/qmake-variable-reference.html#deployment">here</a>.
7feec50967db 201003_02
hgs
parents:
diff changeset
   123
7feec50967db 201003_02
hgs
parents:
diff changeset
   124
*/
7feec50967db 201003_02
hgs
parents:
diff changeset
   125
7feec50967db 201003_02
hgs
parents:
diff changeset
   126
7feec50967db 201003_02
hgs
parents:
diff changeset
   127
/*!
7feec50967db 201003_02
hgs
parents:
diff changeset
   128
    Initialize token for hello world widget. Contains necessary information about 
7feec50967db 201003_02
hgs
parents:
diff changeset
   129
    the hello world widget that can be loaded with this provider.
7feec50967db 201003_02
hgs
parents:
diff changeset
   130
*/
7feec50967db 201003_02
hgs
parents:
diff changeset
   131
HelloWorldWidgetProvider::HelloWorldWidgetProvider()
7feec50967db 201003_02
hgs
parents:
diff changeset
   132
{
7feec50967db 201003_02
hgs
parents:
diff changeset
   133
    mWidgetToken.mLibrary = QString("helloworldwidgetprovider.dll");
7feec50967db 201003_02
hgs
parents:
diff changeset
   134
    mWidgetToken.mUri = QString("homescreen.nokia.com/widget/helloworld");
7feec50967db 201003_02
hgs
parents:
diff changeset
   135
    mWidgetToken.mTitle = QString("HelloWorld");
7feec50967db 201003_02
hgs
parents:
diff changeset
   136
    mWidgetToken.mIconUri = QString("helloworldwidgetprovider.png");
7feec50967db 201003_02
hgs
parents:
diff changeset
   137
}
7feec50967db 201003_02
hgs
parents:
diff changeset
   138
7feec50967db 201003_02
hgs
parents:
diff changeset
   139
/*!
7feec50967db 201003_02
hgs
parents:
diff changeset
   140
    Destructor
7feec50967db 201003_02
hgs
parents:
diff changeset
   141
*/
7feec50967db 201003_02
hgs
parents:
diff changeset
   142
HelloWorldWidgetProvider::~HelloWorldWidgetProvider()
7feec50967db 201003_02
hgs
parents:
diff changeset
   143
{
7feec50967db 201003_02
hgs
parents:
diff changeset
   144
7feec50967db 201003_02
hgs
parents:
diff changeset
   145
}
7feec50967db 201003_02
hgs
parents:
diff changeset
   146
7feec50967db 201003_02
hgs
parents:
diff changeset
   147
/*!
7feec50967db 201003_02
hgs
parents:
diff changeset
   148
    Returns list of loadable widgets' tokens.
7feec50967db 201003_02
hgs
parents:
diff changeset
   149
*/
7feec50967db 201003_02
hgs
parents:
diff changeset
   150
QList<HsWidgetToken> HelloWorldWidgetProvider::widgets()
7feec50967db 201003_02
hgs
parents:
diff changeset
   151
{
7feec50967db 201003_02
hgs
parents:
diff changeset
   152
    return QList<HsWidgetToken>() << mWidgetToken;
7feec50967db 201003_02
hgs
parents:
diff changeset
   153
}
7feec50967db 201003_02
hgs
parents:
diff changeset
   154
7feec50967db 201003_02
hgs
parents:
diff changeset
   155
/*!
7feec50967db 201003_02
hgs
parents:
diff changeset
   156
    Create widget based on uri \a token
7feec50967db 201003_02
hgs
parents:
diff changeset
   157
*/
7feec50967db 201003_02
hgs
parents:
diff changeset
   158
HsWidget* HelloWorldWidgetProvider::createWidget(const HsWidgetToken& token)
7feec50967db 201003_02
hgs
parents:
diff changeset
   159
{
7feec50967db 201003_02
hgs
parents:
diff changeset
   160
    HsWidget *widget = 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
   161
    if (token.mUri == mWidgetToken.mUri) {
7feec50967db 201003_02
hgs
parents:
diff changeset
   162
        widget =  new HelloWorldWidget();
7feec50967db 201003_02
hgs
parents:
diff changeset
   163
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   164
    return widget;
7feec50967db 201003_02
hgs
parents:
diff changeset
   165
}
7feec50967db 201003_02
hgs
parents:
diff changeset
   166
7feec50967db 201003_02
hgs
parents:
diff changeset
   167
Q_EXPORT_PLUGIN2(helloworldwidgetprovider, HelloWorldWidgetProvider)