windowing/windowserver/nga/SERVER/renderorientationtracker.cpp
author hgs
Fri, 24 Sep 2010 16:44:34 +0300
changeset 188 1b081cb0800b
permissions -rw-r--r--
201026_1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
188
1b081cb0800b 201026_1
hgs
parents:
diff changeset
     1
// Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
1b081cb0800b 201026_1
hgs
parents:
diff changeset
     2
// All rights reserved.
1b081cb0800b 201026_1
hgs
parents:
diff changeset
     3
// This material, including documentation and any related
1b081cb0800b 201026_1
hgs
parents:
diff changeset
     4
// computer programs, is protected by copyright controlled by
1b081cb0800b 201026_1
hgs
parents:
diff changeset
     5
// Nokia. All rights are reserved. Copying, including
1b081cb0800b 201026_1
hgs
parents:
diff changeset
     6
// reproducing, storing, adapting or translating, any
1b081cb0800b 201026_1
hgs
parents:
diff changeset
     7
// or all of this material requires the prior written consent of
1b081cb0800b 201026_1
hgs
parents:
diff changeset
     8
// Nokia. This material also contains confidential
1b081cb0800b 201026_1
hgs
parents:
diff changeset
     9
// information which may not be disclosed to others without the
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    10
// prior written consent of Nokia.
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    11
//
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    12
// Description:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    13
// Render Orientation Tracking and Publication
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    14
// 
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    15
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    16
#include <hal.h>
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    17
#include <e32std.h>
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    18
#include "renderorientationtracker.h"
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    19
#include "rootwin.h"
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    20
#include "windowgroup.h"
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    21
#include "wstop.h"
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    22
#include "..\debuglog\DEBUGLOG.H"
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    23
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    24
extern CDebugLogBase* wsDebugLog;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    25
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    26
/** Convert a TRenderOrientation value into a TDigitiserOrientation.
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    27
Note: The algorithm used makes use of the ordering of the values of the respective enums, 
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    28
thus this is checked for (at compile time) at the start of the function.
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    29
@param aWservOrientation A value from the TRenderOrientation enums.
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    30
@return The equivalent value from the TDigitiserOrientation enums.
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    31
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    32
inline HALData::TDigitiserOrientation WservToDigitiser(TRenderOrientation aWservOrientation)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    33
	{
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    34
	__ASSERT_COMPILE(EDisplayOrientationNormal+1 == EDisplayOrientation90CW);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    35
	__ASSERT_COMPILE(EDisplayOrientationNormal+2 == EDisplayOrientation180);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    36
	__ASSERT_COMPILE(EDisplayOrientationNormal+3 == EDisplayOrientation270CW);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    37
	__ASSERT_COMPILE(HALData::EDigitiserOrientation_000+1 == HALData::EDigitiserOrientation_090);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    38
	__ASSERT_COMPILE(HALData::EDigitiserOrientation_000+2 == HALData::EDigitiserOrientation_180);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    39
	__ASSERT_COMPILE(HALData::EDigitiserOrientation_000+3 == HALData::EDigitiserOrientation_270);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    40
	HALData::TDigitiserOrientation ret=static_cast<HALData::TDigitiserOrientation>
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    41
			(HALData::EDigitiserOrientation_000 + (aWservOrientation - EDisplayOrientationNormal));
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    42
	return ret;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    43
	}
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    44
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    45
// Todo remove/undefine this for release
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    46
#define TECHVIEW_TESTMODE
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    47
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    48
CWsRenderOrienationTracker* CWsRenderOrienationTracker::NewL()
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    49
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    50
    CWsRenderOrienationTracker* self = new(ELeave)CWsRenderOrienationTracker();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    51
    CleanupStack::PushL(self);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    52
    self->ConstructL();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    53
    CleanupStack::Pop();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    54
    return self;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    55
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    56
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    57
CWsRenderOrienationTracker::CWsRenderOrienationTracker()
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    58
    : CActive(CActive::EPriorityStandard),
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    59
      iRenderOrientationTrackingType(EDisplayOrientationNormal),
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    60
      iPublishedRenderOrientation(EDisplayOrientationNormal)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    61
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    62
    CActiveScheduler::Add(this);    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    63
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    64
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    65
void CWsRenderOrienationTracker::ConstructL()
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    66
    {    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    67
    const TSecurityPolicy   KRenderOrientationReadSecurityPolicy(ECapability_None);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    68
    const TSecurityPolicy   KRenderOrientationWriteSecurityPolicy(ECapabilityWriteDeviceData);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    69
    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    70
    // Define P&S Property to publish to
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    71
    TInt error = RProperty::Define( KRenderOrientationCategory,
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    72
                                    KRenderOrientationKey,
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    73
                                    RProperty::EInt,
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    74
                                    KRenderOrientationReadSecurityPolicy,
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    75
                                    KRenderOrientationWriteSecurityPolicy);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    76
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    77
    // Attach the publisher for real-time publishing
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    78
    if(KErrNone == error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    79
        error = iRenderOrientationPublisher.Attach( KRenderOrientationCategory,
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    80
                                                    KRenderOrientationKey);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    81
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    82
    // Publish the initial value
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    83
    if(KErrNone == error)    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    84
        error = DoPublishOrientation(EDisplayOrientationNormal);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    85
    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    86
    //Set the initial value to HAL
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    87
    if(KErrNone == error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    88
        SetHALOrientation(EDisplayOrientationNormal);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    89
    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    90
    if (wsDebugLog && KErrNone!=error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    91
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    92
        _LIT(logText,"Orientation Tracker: failed to initialise with error %d");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    93
        wsDebugLog->MiscMessage(CDebugLogBase::ELogImportant,logText,error);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    94
        }    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    95
    User::LeaveIfError(error);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    96
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    97
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    98
CWsRenderOrienationTracker::~CWsRenderOrienationTracker()
1b081cb0800b 201026_1
hgs
parents:
diff changeset
    99
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   100
    Cancel();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   101
    iRenderOrientationPublisher.Delete(KRenderOrientationCategory, KRenderOrientationKey);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   102
    iRenderOrientationPublisher.Close();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   103
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   104
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   105
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   106
If the orientation of the given window group is useable updates aOrientationTrackingType with the orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   107
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   108
@param Input: the window group to check
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   109
@param Output: the window group's orientation if usable ( otherwise unchanged )
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   110
@return KErrNone if the orienation is usable, KErrNotFound if the orientation is not useable, KErrNotSupported if the orientation is unknown
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   111
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   112
TInt CWsRenderOrienationTracker::CheckWindowGroupOrientation(const CWsWindowGroup& aWinGroup, TRenderOrientationTrackingType& aOrientationTrackingType)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   113
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   114
    TInt error = KErrNone;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   115
    TRenderOrientationTrackingType tempOrientationTrackingType = static_cast<TRenderOrientationTrackingType>(aWinGroup.WsOwner()->GetIndicatedAppOrientation());
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   116
    switch(tempOrientationTrackingType)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   117
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   118
        case EDisplayOrientationNormal:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   119
        case EDisplayOrientation90CW:                
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   120
        case EDisplayOrientation180:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   121
        case EDisplayOrientation270CW:            
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   122
        case EDisplayOrientationAuto:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   123
            aOrientationTrackingType = tempOrientationTrackingType;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   124
            break;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   125
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   126
        case EDisplayOrientationIgnore:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   127
            error = KErrNotFound;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   128
            if (wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   129
                {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   130
                _LIT(logText,"Orientation Tracker: winGroup %08x orientation is set to be ignored");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   131
                wsDebugLog->MiscMessage(CDebugLogBase::ELogEverything,logText,reinterpret_cast<TInt>(&aWinGroup));
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   132
                }            
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   133
            break;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   134
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   135
        default:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   136
            error = KErrNotSupported;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   137
            if (wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   138
                {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   139
                _LIT(logText,"Orientation Tracker: winGroup %08x has undefined orientation, Error %d");                
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   140
                TBuf<LogTBufSize> buf;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   141
                buf.Format(logText, &aWinGroup, error);                
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   142
                wsDebugLog->MiscMessage(CDebugLogBase::ELogIntermediate,buf);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   143
                }                          
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   144
            break;             
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   145
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   146
    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   147
    return error;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   148
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   149
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   150
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   151
Checks that the given group window is appropriate for dictating the render orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   152
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   153
@param Input:  The group window to check
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   154
@return ETrue is the group window is usable, else EFalse  
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   155
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   156
TBool CWsRenderOrienationTracker::UseableGroupWindow(const CWsWindowGroup& aWinGroup) const
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   157
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   158
#ifdef TECHVIEW_TESTMODE
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   159
    // for some reason IsFocusable seems to return 0 and 2, not 0 and 1
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   160
    return NULL!=aWinGroup.Child() &&
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   161
            (aWinGroup.IsFocusable() ? ETrue : EFalse);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   162
#else    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   163
    return (NULL!=aWinGroup.Child());     
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   164
#endif
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   165
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   166
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   167
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   168
Finds the topmost usable windowgroup which has a usable orientation, and outputs that orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   169
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   170
@param Output: The current render orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   171
@return KErrNone if successful, KErrNotFound if the focus window group is not usable, KErrNotSupported if an invalid orientation is found
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   172
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   173
TInt CWsRenderOrienationTracker::GetFocusWindowOrientation(TRenderOrientationTrackingType& aOrientationTrackingType)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   174
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   175
    TInt error = KErrNone;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   176
    CWsWindowGroup* focusWinGroup = CWsTop::FocusWindowGroup();    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   177
    if(!focusWinGroup)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   178
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   179
        _LIT(logText,"Orientation Tracker: focusWinGroup not found");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   180
        wsDebugLog->MiscMessage(CDebugLogBase::ELogEverything,logText);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   181
        error = KErrNotFound;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   182
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   183
    else
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   184
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   185
        error = CheckWindowGroupOrientation(*focusWinGroup, aOrientationTrackingType);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   186
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   187
    return error;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   188
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   189
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   190
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   191
Finds the topmost usable windowgroup which has a usable orientation, and outputs that orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   192
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   193
@param Output: The current render orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   194
@return KErrNone if successful, KErrNotSupported if an invalid orientation is found
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   195
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   196
TInt CWsRenderOrienationTracker::FindOrientationFromWindowTree(TRenderOrientationTrackingType& aOrientationTrackingType)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   197
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   198
    TInt error = KErrNone;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   199
    TRenderOrientationTrackingType tempOrientationTrackingType = iRenderOrientationTrackingType;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   200
    CWsRootWindow* rootWin = CWsTop::CurrentFocusScreen()->RootWindow();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   201
    TBool finished = EFalse;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   202
    for(CWsWindowGroup* winGroup = rootWin->Child(); !finished && NULL != winGroup; winGroup = winGroup->NextSibling())
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   203
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   204
        if (wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   205
            {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   206
            _LIT(logText,"Orientation Tracker: winGroup %08x has priority %d, Orientation %d, Focusable %d, Child %08x");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   207
            TBuf<LogTBufSize> buf;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   208
            buf.Format(logText, winGroup, winGroup->OrdinalPriority(), winGroup->WsOwner()->GetIndicatedAppOrientation(),
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   209
                    winGroup->IsFocusable()?ETrue:EFalse, winGroup->Child());                                
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   210
            wsDebugLog->MiscMessage(CDebugLogBase::ELogEverything,buf);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   211
            }               
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   212
        // winGroup is a higher priority ordinal, so see if it has an orientation that can be used
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   213
        // although we're only interested in window groups with child windows otherwise nothing is visible anyway        
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   214
        if(UseableGroupWindow(*winGroup))
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   215
            {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   216
            error = CheckWindowGroupOrientation(*winGroup, tempOrientationTrackingType);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   217
            switch(error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   218
                {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   219
                case KErrNone:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   220
                    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   221
                    // List is in order, so just find the first one
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   222
                    if (wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   223
                        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   224
                        _LIT(logText,"Orientation Tracker: Found winGroup %08x with Orientation %d");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   225
                        TBuf<LogTBufSize> buf;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   226
                        buf.Format(logText, winGroup, winGroup->WsOwner()->GetIndicatedAppOrientation());                    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   227
                        wsDebugLog->MiscMessage(CDebugLogBase::ELogEverything,buf);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   228
                        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   229
                    finished = ETrue;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   230
                    break;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   231
                    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   232
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   233
                case KErrNotFound:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   234
                    // so keep searching
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   235
                    break;                    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   236
                    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   237
                case KErrNotSupported:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   238
                default:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   239
                    finished = ETrue;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   240
                    break;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   241
                    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   242
                }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   243
            
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   244
            }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   245
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   246
    // Safe even in error code as won't have been changed by CheckWindowGroupOrientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   247
    aOrientationTrackingType = tempOrientationTrackingType;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   248
    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   249
    return error;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   250
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   251
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   252
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   253
First checks to see if the focus window group has a usable orientation, if so that is output.
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   254
Otherwise, finds the topmost usable windowgroup which has a usable orientation, and outputs that
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   255
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   256
@param Output: The current render orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   257
@return KErrNone if successful, KErrNotSupported if an invalid orientation is found 
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   258
 */
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   259
TInt CWsRenderOrienationTracker::GetIndicatedOrientation(TRenderOrientationTrackingType& aOrientationTrackingType)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   260
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   261
    // First check the focus window group
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   262
    TInt error = GetFocusWindowOrientation(aOrientationTrackingType);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   263
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   264
    // Don't look for another window if the focus window is usable
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   265
    // or if an error has occured, then don't change current orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   266
    switch(error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   267
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   268
        case KErrNone:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   269
            {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   270
            if(wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   271
                {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   272
                _LIT(logText,"Orientation Tracker: Using focus window %08x for orientation");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   273
                wsDebugLog->MiscMessage(CDebugLogBase::ELogEverything,logText,reinterpret_cast<TInt>(CWsTop::FocusWindowGroup()));
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   274
                }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   275
            break;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   276
            }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   277
        
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   278
        case KErrNotFound:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   279
            {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   280
            // Can't use focus window group, so find the topmost windowgroup with a valid orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   281
            error = FindOrientationFromWindowTree(aOrientationTrackingType);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   282
            break;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   283
            }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   284
            
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   285
        default:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   286
            // Unrecoverable error, abort and leave published orientation unchanged
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   287
            break;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   288
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   289
    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   290
    return error;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   291
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   292
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   293
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   294
Checks to see if the render orientation has changed, and publishes any new orientaion
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   295
via publish and subscribe
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   296
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   297
@see KRenderOrientationCategory
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   298
@see KRenderOrientationKey 
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   299
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   300
void CWsRenderOrienationTracker::CheckRenderOrientation()
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   301
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   302
    TRenderOrientationTrackingType newOrientationTrackingType = iRenderOrientationTrackingType;    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   303
    TInt error = GetIndicatedOrientation(newOrientationTrackingType);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   304
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   305
    // if the tracking type has changed...
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   306
    if(KErrNone == error && iRenderOrientationTrackingType != newOrientationTrackingType)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   307
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   308
        if(EDisplayOrientationAuto == iRenderOrientationTrackingType)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   309
            {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   310
            // change from auto type, so we need to cancel request for updates from the theme server        
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   311
            Cancel();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   312
            }    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   313
        iRenderOrientationTrackingType = newOrientationTrackingType;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   314
        if(EDisplayOrientationAuto == iRenderOrientationTrackingType)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   315
            {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   316
            // Change to auto type, so we need to request updates from the theme server            
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   317
            // Attach to the Theme server to get orientation change updates
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   318
            error = iThemeOrientationProperty.Attach( KThemeOrientationCategory, KThemeOrientationKey );
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   319
            if (wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   320
                {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   321
                if(KErrNone == error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   322
                    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   323
                    // Information Log
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   324
                    _LIT(logText,"Orientation Tracker: Attached to theme orientation property");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   325
                    wsDebugLog->MiscMessage(CDebugLogBase::ELogEverything,logText);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   326
                    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   327
                else
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   328
                    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   329
                    // Error Log
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   330
                    _LIT(logText,"Orientation Tracker: Error %d attaching to theme orientation property");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   331
                    wsDebugLog->MiscMessage(CDebugLogBase::ELogIntermediate,logText, error);                
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   332
                    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   333
                }              
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   334
            
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   335
            RequestDeviceOrientationNotification();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   336
            }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   337
        // See if the  has changed, and publish if it has        
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   338
        error = DoOrientationTracking();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   339
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   340
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   341
    if (wsDebugLog && KErrNone != error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   342
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   343
        _LIT(logText,"Orientation Tracker: Error %d Checking Render Orientation");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   344
        wsDebugLog->MiscMessage(CDebugLogBase::ELogImportant,logText, error);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   345
        }  
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   346
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   347
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   348
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   349
Requests notification of change of the theme server orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   350
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   351
@Pre iThemeOrientationProperty has had Attach called on it
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   352
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   353
void CWsRenderOrienationTracker::RequestDeviceOrientationNotification()
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   354
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   355
    if(!IsActive())
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   356
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   357
        if (wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   358
            {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   359
            _LIT(logText,"Orientation Tracker: Subscribing to theme orientation property");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   360
            wsDebugLog->MiscMessage(CDebugLogBase::ELogEverything,logText);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   361
            }          
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   362
        // Request for Theme Server Orientation P&S  
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   363
        iThemeOrientationProperty.Subscribe(iStatus);        
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   364
        SetActive();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   365
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   366
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   367
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   368
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   369
Cancels and closes (detaches) from the theme orientation publish and subscribe
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   370
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   371
void CWsRenderOrienationTracker::CancelDeviceOrientationNotification()
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   372
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   373
    // Cancel Request for Theme Server Orientation P&S  
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   374
    iThemeOrientationProperty.Cancel();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   375
    iThemeOrientationProperty.Close();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   376
    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   377
    if (wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   378
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   379
        _LIT(logText,"Orientation Tracker: Cancelled/closed theme orientation property");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   380
        wsDebugLog->MiscMessage(CDebugLogBase::ELogEverything,logText);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   381
        }      
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   382
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   383
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   384
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   385
Called when the theme servers orientation has changed.
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   386
Re-requests unless cancelled
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   387
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   388
void CWsRenderOrienationTracker::RunL()
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   389
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   390
    TInt error = iStatus.Int();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   391
    if(KErrNone == error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   392
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   393
        // Re-request
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   394
        RequestDeviceOrientationNotification();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   395
    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   396
        TInt error = DoOrientationTracking();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   397
        if (wsDebugLog && KErrNone != error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   398
            {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   399
            _LIT(logText,"Orientation Tracker: Error %d processing theme orientation property");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   400
            wsDebugLog->MiscMessage(CDebugLogBase::ELogImportant,logText, error);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   401
            }         
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   402
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   403
    else if (wsDebugLog && KErrCancel != error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   404
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   405
        _LIT(logText,"Orientation Tracker: Error %d from theme orientation property, not resubscribed");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   406
        wsDebugLog->MiscMessage(CDebugLogBase::ELogImportant,logText, error);     
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   407
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   408
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   409
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   410
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   411
Cancels the request for notification for changes to theme orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   412
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   413
void CWsRenderOrienationTracker::DoCancel()
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   414
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   415
    CancelDeviceOrientationNotification();
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   416
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   417
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   418
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   419
Gets the orientation published from theme server
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   420
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   421
@param Output: the theme server orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   422
@return KErrNone if successful, KErrNotSupported if the theme server returns an unknown orientation, else any of the system wide error codes 
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   423
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   424
TInt CWsRenderOrienationTracker::GetThemeOrientation(TRenderOrientation& aThemeOrientation)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   425
    { 
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   426
    TInt themeOrientation=EDisplayOrientationNormal;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   427
    TInt error = iThemeOrientationProperty.Get(themeOrientation);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   428
    if(wsDebugLog && KErrNone != error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   429
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   430
        _LIT(logText,"Orientation Tracker: Error %d getting theme orientation property");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   431
        wsDebugLog->MiscMessage(CDebugLogBase::ELogIntermediate,logText, error);     
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   432
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   433
    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   434
    if(KErrNone == error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   435
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   436
        // Translate the received orientation    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   437
        switch(themeOrientation)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   438
            {           
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   439
            case EDisplayOrientationNormal:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   440
            case EDisplayOrientation90CW:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   441
            case EDisplayOrientation180:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   442
            case EDisplayOrientation270CW:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   443
                // only update if orientation is supported
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   444
                aThemeOrientation = static_cast<TRenderOrientation>(themeOrientation);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   445
                break;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   446
            
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   447
            default:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   448
                error = KErrNotSupported;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   449
                if (wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   450
                    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   451
                    _LIT(logText,"Orientation Tracker: Unsupported orientation %d from theme orientation property, Error %d");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   452
                    TBuf<LogTBufSize> buf;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   453
                    buf.Format(logText, themeOrientation, error);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   454
                    wsDebugLog->MiscMessage(CDebugLogBase::ELogIntermediate,buf);     
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   455
                    }                
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   456
                break;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   457
            }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   458
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   459
    return error;  
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   460
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   461
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   462
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   463
Processes the indicated orientation into an actual orientation
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   464
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   465
@return KErrNone for success, KErrNotSupported if the orientation is unknown, else any of the system wide error codes
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   466
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   467
TInt CWsRenderOrienationTracker::DoOrientationTracking()
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   468
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   469
    TInt error = KErrNone;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   470
    TRenderOrientation newDeviceOrientation;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   471
    switch(iRenderOrientationTrackingType)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   472
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   473
        case EDisplayOrientationNormal:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   474
        case EDisplayOrientation90CW:                
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   475
        case EDisplayOrientation180:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   476
        case EDisplayOrientation270CW:            
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   477
            newDeviceOrientation = iRenderOrientationTrackingType;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   478
            break;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   479
            
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   480
        case EDisplayOrientationAuto:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   481
            error = GetThemeOrientation(newDeviceOrientation);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   482
            break;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   483
                      
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   484
        default:
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   485
            error = KErrNotSupported;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   486
            if (wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   487
                {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   488
                _LIT(logText,"Orientation Tracker: Unsupported orientation tracking type %d, error %d");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   489
                TBuf<LogTBufSize> buf;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   490
                buf.Format(logText, iRenderOrientationTrackingType, error);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   491
                wsDebugLog->MiscMessage(CDebugLogBase::ELogIntermediate,buf);     
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   492
                }              
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   493
            break;            
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   494
        }    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   495
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   496
    if(KErrNone == error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   497
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   498
        error = PublishOrientation(newDeviceOrientation);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   499
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   500
    
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   501
    return error;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   502
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   503
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   504
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   505
Publishes the given value
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   506
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   507
@param The render orientation to publish
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   508
@return KErrNone for success, else any of the system wide erro codes
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   509
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   510
TInt CWsRenderOrienationTracker::DoPublishOrientation(const TRenderOrientation aRenderOrientation)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   511
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   512
    TInt error = iRenderOrientationPublisher.Set(aRenderOrientation);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   513
         
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   514
    // if it's published OK, then remember the newly published value
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   515
    if(KErrNone == error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   516
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   517
        iPublishedRenderOrientation = aRenderOrientation;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   518
        if(wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   519
            {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   520
            _LIT(logText,"Orientation Tracker: Published render orientation %d");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   521
            wsDebugLog->MiscMessage(CDebugLogBase::ELogEverything, logText, aRenderOrientation);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   522
            }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   523
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   524
    else if(wsDebugLog)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   525
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   526
        _LIT(logText,"Orientation Tracker: Error %d setting render orientation property");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   527
        wsDebugLog->MiscMessage(CDebugLogBase::ELogIntermediate, logText, error);                   
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   528
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   529
    return error;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   530
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   531
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   532
void CWsRenderOrienationTracker::SetHALOrientation(const TRenderOrientation aRenderOrientation)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   533
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   534
    // If the render orientation is EDisplayOrientationAuto then don't update HAL
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   535
    // The application and HAL should always have the same state for the orientation.
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   536
    if(EDisplayOrientationAuto != aRenderOrientation)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   537
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   538
        TInt error = HAL::Set(CWsTop::CurrentFocusScreen()->ScreenNumber(), HALData::EDigitiserOrientation, WservToDigitiser(iPublishedRenderOrientation));
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   539
        //Just log the error if there is one.
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   540
        if(wsDebugLog && error != KErrNone)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   541
            {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   542
            _LIT(logText,"Orientation Tracker: Error %d setting digitiser orientation");
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   543
            wsDebugLog->MiscMessage(CDebugLogBase::ELogIntermediate, logText, error);           
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   544
            } 
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   545
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   546
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   547
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   548
/**
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   549
If the current orientation differs from the previously published value then publishes the current value
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   550
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   551
@param The render orientation to check and publish
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   552
@return KErrNone for success, else any of the system wide erro codes
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   553
*/
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   554
TInt CWsRenderOrienationTracker::PublishOrientation(const TRenderOrientation aRenderOrientation)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   555
    {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   556
    TInt error = KErrNone;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   557
  
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   558
    if(aRenderOrientation != iPublishedRenderOrientation)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   559
        {
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   560
        // If the device Orientation has changed, publish it
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   561
        error = DoPublishOrientation(aRenderOrientation);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   562
        if(KErrNone == error)
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   563
            SetHALOrientation(aRenderOrientation);
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   564
        }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   565
    return error;
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   566
    }
1b081cb0800b 201026_1
hgs
parents:
diff changeset
   567