ui/uiengine/model/modelwrapper/src/glxmodelwrapper.cpp
author hgs
Mon, 23 Aug 2010 18:06:16 +0530
changeset 58 383b67fbdb11
parent 50 a0f57508af73
permissions -rw-r--r--
201033
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
40
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:   ?Description
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#include <glxmodelwrapper.h>
hgs
parents:
diff changeset
    19
#include <glxmodelparm.h>
hgs
parents:
diff changeset
    20
#include <QDebug>
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
GlxModelWrapper::GlxModelWrapper(): mModel ( NULL),
hgs
parents:
diff changeset
    23
    mOriginalRole(Qt::DecorationRole),
58
hgs
parents: 50
diff changeset
    24
    mConvertRole(Qt::DecorationRole),
hgs
parents: 50
diff changeset
    25
    mPaintPage(false)
40
hgs
parents:
diff changeset
    26
    {
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
    }
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
void GlxModelWrapper::setModel(QAbstractItemModel *model)
hgs
parents:
diff changeset
    31
    {
hgs
parents:
diff changeset
    32
    if(model && mModel != model)
hgs
parents:
diff changeset
    33
        {
hgs
parents:
diff changeset
    34
        disConnectFromModel();
hgs
parents:
diff changeset
    35
        mModel = model;
58
hgs
parents: 50
diff changeset
    36
        QVariant variant = mModel->data(mModel->index(0,0),GlxPaintPageFlag);
hgs
parents: 50
diff changeset
    37
        if (variant.isValid() &&  variant.canConvert<bool> () )
hgs
parents: 50
diff changeset
    38
            {
hgs
parents: 50
diff changeset
    39
            mPaintPage = variant.value<bool>();
hgs
parents: 50
diff changeset
    40
            }
40
hgs
parents:
diff changeset
    41
        connectToModel();
hgs
parents:
diff changeset
    42
        resetTheModel();
hgs
parents:
diff changeset
    43
        }	
hgs
parents:
diff changeset
    44
    }
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
void GlxModelWrapper::setRoles(int convertrole, int originalrole)
hgs
parents:
diff changeset
    48
    {
hgs
parents:
diff changeset
    49
	mConvertRole  =   convertrole;
hgs
parents:
diff changeset
    50
	mOriginalRole =   originalrole;
hgs
parents:
diff changeset
    51
	}
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
void GlxModelWrapper::scrollingStarted()
hgs
parents:
diff changeset
    54
    {
hgs
parents:
diff changeset
    55
 
hgs
parents:
diff changeset
    56
    }
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
void GlxModelWrapper::scrollingEnded()
hgs
parents:
diff changeset
    59
    {
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
    }
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
void GlxModelWrapper::connectToModel()
hgs
parents:
diff changeset
    64
	{
hgs
parents:
diff changeset
    65
	connect(mModel, SIGNAL(destroyed()),this, SLOT(modelDestroyed()));
hgs
parents:
diff changeset
    66
	connect(mModel, SIGNAL(dataChanged(QModelIndex,QModelIndex)),this,SLOT(dataChangedinModel(QModelIndex,QModelIndex)));
hgs
parents:
diff changeset
    67
	connect(mModel, SIGNAL(rowsAboutToBeInserted(QModelIndex,int,int)),this,SLOT(rowsAboutToBeInserted(QModelIndex,int,int)));
hgs
parents:
diff changeset
    68
    connect(mModel, SIGNAL(rowsInserted(QModelIndex,int,int)),this,  SLOT(rowsInserted(QModelIndex,int,int)));
hgs
parents:
diff changeset
    69
    connect(mModel, SIGNAL(rowsAboutToBeRemoved(QModelIndex,int,int)),this,SLOT(rowsAboutToBeRemoved(QModelIndex,int,int)));
hgs
parents:
diff changeset
    70
    connect(mModel, SIGNAL(rowsRemoved(QModelIndex,int,int)),this,SLOT(rowsRemoved(QModelIndex,int,int)));
hgs
parents:
diff changeset
    71
	}
hgs
parents:
diff changeset
    72
	
hgs
parents:
diff changeset
    73
void GlxModelWrapper::disConnectFromModel()
hgs
parents:
diff changeset
    74
	{
hgs
parents:
diff changeset
    75
	if(mModel)
hgs
parents:
diff changeset
    76
	    {
hgs
parents:
diff changeset
    77
	    disconnect(mModel, SIGNAL(destroyed()),this, SLOT(modelDestroyed()));
hgs
parents:
diff changeset
    78
		disconnect(mModel, SIGNAL(dataChanged(QModelIndex,QModelIndex)),this,SLOT(dataChangedinModel(QModelIndex,QModelIndex)));
hgs
parents:
diff changeset
    79
		disconnect(mModel, SIGNAL(rowsAboutToBeInserted(QModelIndex,int,int)),this,SLOT(rowsAboutToBeInserted(QModelIndex,int,int)));
hgs
parents:
diff changeset
    80
	    disconnect(mModel, SIGNAL(rowsInserted(QModelIndex,int,int)),this,  SLOT(rowsInserted(QModelIndex,int,int)));
hgs
parents:
diff changeset
    81
	    disconnect(mModel, SIGNAL(rowsAboutToBeRemoved(QModelIndex,int,int)),this,SLOT(rowsAboutToBeRemoved(QModelIndex,int,int)));
hgs
parents:
diff changeset
    82
	    disconnect(mModel, SIGNAL(rowsRemoved(QModelIndex,int,int)),this,SLOT(rowsRemoved(QModelIndex,int,int)));	
hgs
parents:
diff changeset
    83
		}
hgs
parents:
diff changeset
    84
	}
hgs
parents:
diff changeset
    85
	
hgs
parents:
diff changeset
    86
hgs
parents:
diff changeset
    87
GlxModelWrapper::~GlxModelWrapper()
hgs
parents:
diff changeset
    88
    {
hgs
parents:
diff changeset
    89
	disConnectFromModel();
hgs
parents:
diff changeset
    90
    }
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
int GlxModelWrapper::rowCount(const QModelIndex &parent ) const
hgs
parents:
diff changeset
    93
    {
hgs
parents:
diff changeset
    94
	Q_UNUSED(parent);
hgs
parents:
diff changeset
    95
	if(mModel)
hgs
parents:
diff changeset
    96
		return (mModel->rowCount());
hgs
parents:
diff changeset
    97
	else
hgs
parents:
diff changeset
    98
		return 0;
hgs
parents:
diff changeset
    99
    }
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
int GlxModelWrapper::columnCount(const QModelIndex &parent ) const
hgs
parents:
diff changeset
   102
    {
hgs
parents:
diff changeset
   103
    Q_UNUSED(parent);
hgs
parents:
diff changeset
   104
	return 1; 
hgs
parents:
diff changeset
   105
    }
hgs
parents:
diff changeset
   106
hgs
parents:
diff changeset
   107
QModelIndex GlxModelWrapper::parent(const QModelIndex &child) const
hgs
parents:
diff changeset
   108
    {
hgs
parents:
diff changeset
   109
    Q_UNUSED(child);
hgs
parents:
diff changeset
   110
    return QModelIndex();  // No need to Check mModel ,Should i Set mModel As parent
hgs
parents:
diff changeset
   111
    }
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
QVariant GlxModelWrapper::data(const QModelIndex &idx, int role) const
hgs
parents:
diff changeset
   114
    {
hgs
parents:
diff changeset
   115
	if(mModel)
hgs
parents:
diff changeset
   116
		{
hgs
parents:
diff changeset
   117
		if(mOriginalRole == role)
hgs
parents:
diff changeset
   118
			{
hgs
parents:
diff changeset
   119
			return (mModel->data(idx,mConvertRole));
hgs
parents:
diff changeset
   120
			}
hgs
parents:
diff changeset
   121
		else
hgs
parents:
diff changeset
   122
			{
hgs
parents:
diff changeset
   123
			return (mModel->data(idx,role));		
hgs
parents:
diff changeset
   124
			}
hgs
parents:
diff changeset
   125
		}
hgs
parents:
diff changeset
   126
	else
hgs
parents:
diff changeset
   127
		{
hgs
parents:
diff changeset
   128
		return QVariant();	
hgs
parents:
diff changeset
   129
		}
hgs
parents:
diff changeset
   130
    }
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
bool GlxModelWrapper::setData ( const QModelIndex & idx, const QVariant & value, int role )
hgs
parents:
diff changeset
   133
    {
hgs
parents:
diff changeset
   134
    if(mModel)
hgs
parents:
diff changeset
   135
    	{
hgs
parents:
diff changeset
   136
    	return (mModel->setData(mModel->index(idx.row(),0),value,role));
hgs
parents:
diff changeset
   137
    	}
hgs
parents:
diff changeset
   138
    else
hgs
parents:
diff changeset
   139
    	{
hgs
parents:
diff changeset
   140
    	return FALSE;
hgs
parents:
diff changeset
   141
    	}
hgs
parents:
diff changeset
   142
    }
hgs
parents:
diff changeset
   143
hgs
parents:
diff changeset
   144
QModelIndex GlxModelWrapper::index(int row, int column, const QModelIndex &parent) const
hgs
parents:
diff changeset
   145
    {
hgs
parents:
diff changeset
   146
    Q_UNUSED(parent);
hgs
parents:
diff changeset
   147
    if ( ( row < 0 ) || ( row >= rowCount() )  || ( column < 0 )  || ( column >= columnCount() ) ) 
hgs
parents:
diff changeset
   148
        {
hgs
parents:
diff changeset
   149
        return QModelIndex();
hgs
parents:
diff changeset
   150
        }
hgs
parents:
diff changeset
   151
    return QAbstractItemModel::createIndex(row, column); 
hgs
parents:
diff changeset
   152
    }
hgs
parents:
diff changeset
   153
hgs
parents:
diff changeset
   154
QModelIndex GlxModelWrapper::basemodelindex(int row, int column, const QModelIndex &parent) const
hgs
parents:
diff changeset
   155
    {
hgs
parents:
diff changeset
   156
    Q_UNUSED(parent);
hgs
parents:
diff changeset
   157
    if(mModel)
hgs
parents:
diff changeset
   158
        {
hgs
parents:
diff changeset
   159
        return (mModel->index(row,column));
hgs
parents:
diff changeset
   160
        }
hgs
parents:
diff changeset
   161
    else
hgs
parents:
diff changeset
   162
        {
hgs
parents:
diff changeset
   163
        return QModelIndex();
hgs
parents:
diff changeset
   164
        }
hgs
parents:
diff changeset
   165
    }
hgs
parents:
diff changeset
   166
hgs
parents:
diff changeset
   167
void GlxModelWrapper::modelDestroyed()
hgs
parents:
diff changeset
   168
    {
hgs
parents:
diff changeset
   169
    disConnectFromModel();
hgs
parents:
diff changeset
   170
    mModel = NULL;
hgs
parents:
diff changeset
   171
    resetTheModel();
hgs
parents:
diff changeset
   172
    }
hgs
parents:
diff changeset
   173
hgs
parents:
diff changeset
   174
void GlxModelWrapper::resetTheModel()
hgs
parents:
diff changeset
   175
    {
hgs
parents:
diff changeset
   176
    beginResetModel();
hgs
parents:
diff changeset
   177
    endResetModel();
hgs
parents:
diff changeset
   178
    }
hgs
parents:
diff changeset
   179
hgs
parents:
diff changeset
   180
void GlxModelWrapper::dataChangedinModel(QModelIndex startIndex, QModelIndex endIndex)
hgs
parents:
diff changeset
   181
    {
50
hgs
parents: 40
diff changeset
   182
    int aStartRow = startIndex.row();
hgs
parents: 40
diff changeset
   183
58
hgs
parents: 50
diff changeset
   184
    if(mPaintPage)
hgs
parents: 50
diff changeset
   185
        {
50
hgs
parents: 40
diff changeset
   186
    if((aStartRow  == 14) || (aStartRow+1 == rowCount()))
hgs
parents: 40
diff changeset
   187
        {
hgs
parents: 40
diff changeset
   188
        emit dataChanged(index(0,0),index(endIndex.row(),0));
58
hgs
parents: 50
diff changeset
   189
            mPaintPage = false;
50
hgs
parents: 40
diff changeset
   190
        }
hgs
parents: 40
diff changeset
   191
    else if(aStartRow  >= 15)
hgs
parents: 40
diff changeset
   192
        {
hgs
parents: 40
diff changeset
   193
        emit dataChanged(index(aStartRow,0),index(endIndex.row(),0));
hgs
parents: 40
diff changeset
   194
        }
58
hgs
parents: 50
diff changeset
   195
        }
50
hgs
parents: 40
diff changeset
   196
    else
hgs
parents: 40
diff changeset
   197
        {
58
hgs
parents: 50
diff changeset
   198
        emit dataChanged(index(aStartRow,0),index(endIndex.row(),0));
50
hgs
parents: 40
diff changeset
   199
        }
40
hgs
parents:
diff changeset
   200
    }
hgs
parents:
diff changeset
   201
hgs
parents:
diff changeset
   202
void GlxModelWrapper::rowsAboutToBeInserted(const QModelIndex &parent,int start,int end)
hgs
parents:
diff changeset
   203
    {
hgs
parents:
diff changeset
   204
    Q_UNUSED(parent);
hgs
parents:
diff changeset
   205
    Q_UNUSED(start);
hgs
parents:
diff changeset
   206
    Q_UNUSED(end);
hgs
parents:
diff changeset
   207
    }
hgs
parents:
diff changeset
   208
hgs
parents:
diff changeset
   209
void GlxModelWrapper::rowsInserted(const QModelIndex &parent, int start, int end)
hgs
parents:
diff changeset
   210
    {
hgs
parents:
diff changeset
   211
    Q_UNUSED(parent);
hgs
parents:
diff changeset
   212
    beginInsertRows(QModelIndex(), start, end);
hgs
parents:
diff changeset
   213
    endInsertRows();
hgs
parents:
diff changeset
   214
    }
hgs
parents:
diff changeset
   215
hgs
parents:
diff changeset
   216
void GlxModelWrapper::rowsAboutToBeRemoved(const QModelIndex &parent, int start, int end)
hgs
parents:
diff changeset
   217
    {
hgs
parents:
diff changeset
   218
    Q_UNUSED(parent);
hgs
parents:
diff changeset
   219
    Q_UNUSED(start);
hgs
parents:
diff changeset
   220
    Q_UNUSED(end);
hgs
parents:
diff changeset
   221
    }
hgs
parents:
diff changeset
   222
hgs
parents:
diff changeset
   223
void GlxModelWrapper::rowsRemoved(const QModelIndex &parent, int start, int end)
hgs
parents:
diff changeset
   224
    {
hgs
parents:
diff changeset
   225
    Q_UNUSED(parent);
hgs
parents:
diff changeset
   226
    beginRemoveRows(QModelIndex(), start, end);
hgs
parents:
diff changeset
   227
    endRemoveRows();
hgs
parents:
diff changeset
   228
    }
hgs
parents:
diff changeset
   229
hgs
parents:
diff changeset
   230
hgs
parents:
diff changeset
   231