locationtriggering/ltserver/ltserverlogic/src/lbtcreatetriggeraooperation.cpp
author hgs
Wed, 03 Nov 2010 23:28:39 +0530
changeset 56 4e949f03ecc5
permissions -rw-r--r--
201044
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2007 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:  Active Object operation for serving server logic requests
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
// INCLUDE FILES
hgs
parents:
diff changeset
    21
#include <e32cmn.h>
hgs
parents:
diff changeset
    22
#include <lbttriggerentry.h>
hgs
parents:
diff changeset
    23
#include <lbtgeoareabase.h>
hgs
parents:
diff changeset
    24
#include <lbtgeocircle.h>
hgs
parents:
diff changeset
    25
#include <lbtgeoareabase.h>
hgs
parents:
diff changeset
    26
#include <lbttriggerconditionbase.h>
hgs
parents:
diff changeset
    27
#include <lbttriggerconditionarea.h>
hgs
parents:
diff changeset
    28
#include <lbttriggerdynamicinfo.h>
hgs
parents:
diff changeset
    29
#include <s32mem.h>
hgs
parents:
diff changeset
    30
#include <lbtsessiontrigger.h>
hgs
parents:
diff changeset
    31
#include <lbtstartuptrigger.h>
hgs
parents:
diff changeset
    32
#include <lbterrors.h>
hgs
parents:
diff changeset
    33
#include "lbtcreatetriggeraooperation.h"
hgs
parents:
diff changeset
    34
#include "lbtaoobserver.h"
hgs
parents:
diff changeset
    35
#include "lbtserverconsts.h"
hgs
parents:
diff changeset
    36
#include "lbtglobal.h"
hgs
parents:
diff changeset
    37
#include "lbtcontainertriggerentry.h"
hgs
parents:
diff changeset
    38
#include "lbtcontainer.h"
hgs
parents:
diff changeset
    39
#include "lbtcontainerextendedtriggerinfo.h"
hgs
parents:
diff changeset
    40
#include "lbtsettingsmanager.h"
hgs
parents:
diff changeset
    41
#include "lbtlogger.h"
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
// CONSTANTS
hgs
parents:
diff changeset
    44
const TInt KCircleRadiusCutoff(500);
hgs
parents:
diff changeset
    45
const TReal KMinHysteresisArea(20);
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
// ===================== MEMBER FUNCTIONS =====================
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    51
// CLbtCreateTriggerAOOperation::NewL
hgs
parents:
diff changeset
    52
// Symbian Two - phase constructor
hgs
parents:
diff changeset
    53
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    54
//
hgs
parents:
diff changeset
    55
CLbtCreateTriggerAOOperation* CLbtCreateTriggerAOOperation::NewL(MLbtAOObserver& aObserver,
hgs
parents:
diff changeset
    56
															     const RMessage2& aMessage,
hgs
parents:
diff changeset
    57
															     CLbtContainer& aContainer,
hgs
parents:
diff changeset
    58
															     TInt aClientType,
hgs
parents:
diff changeset
    59
															     CLbtSettingsManager& aSettingsManager )
hgs
parents:
diff changeset
    60
	{
hgs
parents:
diff changeset
    61
	FUNC_ENTER("CLbtCreateTriggerAOOperation::NewL");
hgs
parents:
diff changeset
    62
	CLbtCreateTriggerAOOperation* self = new (ELeave) CLbtCreateTriggerAOOperation(aObserver, 
hgs
parents:
diff changeset
    63
																				   aMessage, 
hgs
parents:
diff changeset
    64
																				   aContainer, 
hgs
parents:
diff changeset
    65
																				   aClientType,
hgs
parents:
diff changeset
    66
																				   aSettingsManager);
hgs
parents:
diff changeset
    67
	CleanupStack::PushL(self);
hgs
parents:
diff changeset
    68
	self->ConstructL();
hgs
parents:
diff changeset
    69
	CleanupStack::Pop(); // self
hgs
parents:
diff changeset
    70
	return self;
hgs
parents:
diff changeset
    71
	}
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    74
// CLbtCreateTriggerAOOperation::~CLbtCreateTriggerAOOperation
hgs
parents:
diff changeset
    75
// Destructor
hgs
parents:
diff changeset
    76
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    77
//
hgs
parents:
diff changeset
    78
CLbtCreateTriggerAOOperation::~CLbtCreateTriggerAOOperation()
hgs
parents:
diff changeset
    79
	{
hgs
parents:
diff changeset
    80
	FUNC_ENTER("CLbtCreateTriggerAOOperation::~CLbtCreateTriggerAOOperation");
hgs
parents:
diff changeset
    81
	iContainer.RemoveObserver(this);
hgs
parents:
diff changeset
    82
	// Call cancel operation
hgs
parents:
diff changeset
    83
	if( IsActive() )
hgs
parents:
diff changeset
    84
	    {
hgs
parents:
diff changeset
    85
	    Cancel();
hgs
parents:
diff changeset
    86
	    }
hgs
parents:
diff changeset
    87
	delete iContainerTriggerEntry;
hgs
parents:
diff changeset
    88
	}
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    91
// CLbtCreateTriggerAOOperation::CLbtCreateTriggerAOOperation
hgs
parents:
diff changeset
    92
// C++ Default constructor
hgs
parents:
diff changeset
    93
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    94
//
hgs
parents:
diff changeset
    95
CLbtCreateTriggerAOOperation::CLbtCreateTriggerAOOperation(MLbtAOObserver& aObserver,
hgs
parents:
diff changeset
    96
														   const RMessage2& aMessage,
hgs
parents:
diff changeset
    97
														   CLbtContainer& aContainer,
hgs
parents:
diff changeset
    98
														   TInt aClientType,
hgs
parents:
diff changeset
    99
														   CLbtSettingsManager& aSettingsManager)
hgs
parents:
diff changeset
   100
	: CLbtAOOperationBase(aObserver, aMessage, aContainer, aClientType),
hgs
parents:
diff changeset
   101
	  iSettingsManager(aSettingsManager)
hgs
parents:
diff changeset
   102
	{
hgs
parents:
diff changeset
   103
	FUNC_ENTER("CLbtCreateTriggerAOOperation::CLbtCreateTriggerAOOperation");
hgs
parents:
diff changeset
   104
	}
hgs
parents:
diff changeset
   105
hgs
parents:
diff changeset
   106
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   107
// CLbtCreateTriggerAOOperation::ConstructL
hgs
parents:
diff changeset
   108
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   109
//
hgs
parents:
diff changeset
   110
void CLbtCreateTriggerAOOperation::ConstructL()
hgs
parents:
diff changeset
   111
	{
hgs
parents:
diff changeset
   112
	FUNC_ENTER("CLbtCreateTriggerAOOperation::ConstructL");
hgs
parents:
diff changeset
   113
	CActiveScheduler::Add(this);
hgs
parents:
diff changeset
   114
	}
hgs
parents:
diff changeset
   115
	
hgs
parents:
diff changeset
   116
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   117
// CLbtCreateTriggerAOOperation::RunL
hgs
parents:
diff changeset
   118
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   119
//
hgs
parents:
diff changeset
   120
void CLbtCreateTriggerAOOperation::RunL()
hgs
parents:
diff changeset
   121
	{
hgs
parents:
diff changeset
   122
	FUNC_ENTER("CLbtCreateTriggerAOOperation::RunL");	
hgs
parents:
diff changeset
   123
	switch(iFunction)
hgs
parents:
diff changeset
   124
		{
hgs
parents:
diff changeset
   125
		case ELbtCreateTrigger:
hgs
parents:
diff changeset
   126
			{
hgs
parents:
diff changeset
   127
			if(iStatus.Int() == KErrNone)
hgs
parents:
diff changeset
   128
				{
hgs
parents:
diff changeset
   129
				LOGSTRING("Trigger created: \"%S\" ", &(iContainerTriggerEntry->TriggerEntry()->Name()));
hgs
parents:
diff changeset
   130
				LOG1("Trigger Id:%d",iContainerTriggerEntry->TriggerEntry()->Id());
hgs
parents:
diff changeset
   131
				LOG1("Trigger state:%d",iContainerTriggerEntry->TriggerEntry()->State());
hgs
parents:
diff changeset
   132
				// For create trigger server has to write the trigger id back to the client
hgs
parents:
diff changeset
   133
				TPckg<TUint32> triggerId(iContainerTriggerEntry->TriggerEntry()->Id());
hgs
parents:
diff changeset
   134
				LbtGlobal::Write(iMessage, KParamTriggerId,triggerId);
hgs
parents:
diff changeset
   135
				}
hgs
parents:
diff changeset
   136
			LbtGlobal::RequestComplete(iMessage, iStatus.Int());			
hgs
parents:
diff changeset
   137
			break;
hgs
parents:
diff changeset
   138
			}
hgs
parents:
diff changeset
   139
		default:
hgs
parents:
diff changeset
   140
			{
hgs
parents:
diff changeset
   141
			// Handle the completion of request. Ideally this should not execute
hgs
parents:
diff changeset
   142
			LbtGlobal::RequestComplete(iMessage, iStatus.Int());
hgs
parents:
diff changeset
   143
			break;
hgs
parents:
diff changeset
   144
			}
hgs
parents:
diff changeset
   145
		}
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
	iObserver.HandleOperationClosureL(this, iStatus.Int());
hgs
parents:
diff changeset
   148
	}
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   151
// CLbtCreateTriggerAOOperation::DoCancel
hgs
parents:
diff changeset
   152
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   153
//
hgs
parents:
diff changeset
   154
void CLbtCreateTriggerAOOperation::DoCancel()
hgs
parents:
diff changeset
   155
	{
hgs
parents:
diff changeset
   156
	FUNC_ENTER("CLbtCreateTriggerAOOperation::DoCancel");
hgs
parents:
diff changeset
   157
	// Cancel container notifications
hgs
parents:
diff changeset
   158
	iContainer.CancelAsyncOperation(iAOIdentificationNum);
hgs
parents:
diff changeset
   159
	iMessage.Complete( iStatus.Int() );
hgs
parents:
diff changeset
   160
	}
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   163
// CLbtCreateTriggerAOOperation::StartOperationL
hgs
parents:
diff changeset
   164
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   165
//
hgs
parents:
diff changeset
   166
void CLbtCreateTriggerAOOperation::StartOperationL()
hgs
parents:
diff changeset
   167
	{
hgs
parents:
diff changeset
   168
	FUNC_ENTER("CLbtCreateTriggerAOOperation::StartOperationL");
hgs
parents:
diff changeset
   169
	switch(iFunction)
hgs
parents:
diff changeset
   170
		{
hgs
parents:
diff changeset
   171
		case ELbtCreateTrigger:
hgs
parents:
diff changeset
   172
			{
hgs
parents:
diff changeset
   173
			if( CheckTriggerCap() )
hgs
parents:
diff changeset
   174
				{
hgs
parents:
diff changeset
   175
				CreateTriggerL();
hgs
parents:
diff changeset
   176
				}
hgs
parents:
diff changeset
   177
			else
hgs
parents:
diff changeset
   178
				{
hgs
parents:
diff changeset
   179
				LbtGlobal::RequestComplete(iMessage, KLbtErrMaxEnabledValidTriggersLimitExceeded );
hgs
parents:
diff changeset
   180
				iObserver.HandleOperationClosureL(this, KLbtErrMaxEnabledValidTriggersLimitExceeded );
hgs
parents:
diff changeset
   181
				}
hgs
parents:
diff changeset
   182
			break;
hgs
parents:
diff changeset
   183
			}
hgs
parents:
diff changeset
   184
		default:
hgs
parents:
diff changeset
   185
			{
hgs
parents:
diff changeset
   186
			break;
hgs
parents:
diff changeset
   187
			}
hgs
parents:
diff changeset
   188
		}
hgs
parents:
diff changeset
   189
	}
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   192
// CLbtCreateTriggerAOOperation::CheckTriggerCap()
hgs
parents:
diff changeset
   193
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   194
//
hgs
parents:
diff changeset
   195
TBool CLbtCreateTriggerAOOperation::CheckTriggerCap()
hgs
parents:
diff changeset
   196
	{
hgs
parents:
diff changeset
   197
	TUint enabledValidTriggerCount = iContainer.GetCountOfEnabledAndValidTriggers();
hgs
parents:
diff changeset
   198
	
hgs
parents:
diff changeset
   199
	if( iSettingsManager.EnabledValidTriggerCount() > enabledValidTriggerCount )
hgs
parents:
diff changeset
   200
		{
hgs
parents:
diff changeset
   201
		// More triggers can be created. Return true
hgs
parents:
diff changeset
   202
		return ETrue;
hgs
parents:
diff changeset
   203
		}
hgs
parents:
diff changeset
   204
	return EFalse;
hgs
parents:
diff changeset
   205
	}
hgs
parents:
diff changeset
   206
hgs
parents:
diff changeset
   207
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   208
// CLbtCreateTriggerAOOperation::CreateTriggerL()
hgs
parents:
diff changeset
   209
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   210
//
hgs
parents:
diff changeset
   211
void CLbtCreateTriggerAOOperation::CreateTriggerL()
hgs
parents:
diff changeset
   212
	{
hgs
parents:
diff changeset
   213
	FUNC_ENTER("CLbtCreateTriggerAOOperation::CreateTriggerL");
hgs
parents:
diff changeset
   214
	// Copy the trigger entry object descriptor from the client IPC message
hgs
parents:
diff changeset
   215
	HBufC8* triggerEntryBuffer = LbtGlobal::CopyClientBuffer8LC(iMessage, KParamTriggerEntry);
hgs
parents:
diff changeset
   216
	
hgs
parents:
diff changeset
   217
	if( triggerEntryBuffer == NULL )
hgs
parents:
diff changeset
   218
		{
hgs
parents:
diff changeset
   219
		iObserver.HandleOperationClosureL(this, KErrBadDescriptor);
hgs
parents:
diff changeset
   220
		return;
hgs
parents:
diff changeset
   221
		}
hgs
parents:
diff changeset
   222
	
hgs
parents:
diff changeset
   223
	TLbtTriggerCreationInfo triggerCreationInfo;
hgs
parents:
diff changeset
   224
	
hgs
parents:
diff changeset
   225
	TPckg<TLbtTriggerCreationInfo> des(triggerCreationInfo);
hgs
parents:
diff changeset
   226
	LbtGlobal::Read(iMessage,2,des);
hgs
parents:
diff changeset
   227
hgs
parents:
diff changeset
   228
		
hgs
parents:
diff changeset
   229
	// Read the buffer into a stream
hgs
parents:
diff changeset
   230
	RDesReadStream stream(*triggerEntryBuffer);
hgs
parents:
diff changeset
   231
	CleanupClosePushL(stream);
hgs
parents:
diff changeset
   232
	
hgs
parents:
diff changeset
   233
	// Create the trigger entry object based on the type of trigger
hgs
parents:
diff changeset
   234
	CLbtTriggerEntry* trigger;
hgs
parents:
diff changeset
   235
	if( triggerCreationInfo.iTriggerType== CLbtTriggerEntry::ETypeStartup)
hgs
parents:
diff changeset
   236
		{
hgs
parents:
diff changeset
   237
		trigger = CLbtStartupTrigger::NewLC();
hgs
parents:
diff changeset
   238
		}
hgs
parents:
diff changeset
   239
	else
hgs
parents:
diff changeset
   240
		{
hgs
parents:
diff changeset
   241
		trigger = CLbtSessionTrigger::NewLC();
hgs
parents:
diff changeset
   242
		}
hgs
parents:
diff changeset
   243
		
hgs
parents:
diff changeset
   244
	// Internalize the trigger entry class since it is a "C" class
hgs
parents:
diff changeset
   245
	trigger->InternalizeL(stream);	
hgs
parents:
diff changeset
   246
		
hgs
parents:
diff changeset
   247
	// Fill the extended trigger info required by Stratergy
hgs
parents:
diff changeset
   248
	CLbtExtendedTriggerInfo::TLbtTriggerRectArea area;
hgs
parents:
diff changeset
   249
		
hgs
parents:
diff changeset
   250
	if(trigger->GetCondition()->Type() == CLbtTriggerConditionBase::ETriggerConditionArea)
hgs
parents:
diff changeset
   251
		{
hgs
parents:
diff changeset
   252
		// Get the condition area base
hgs
parents:
diff changeset
   253
		CLbtTriggerConditionArea* conditionArea = 
hgs
parents:
diff changeset
   254
				static_cast<CLbtTriggerConditionArea*>(trigger->GetCondition());
hgs
parents:
diff changeset
   255
		
hgs
parents:
diff changeset
   256
		// Check if the area is a circle
hgs
parents:
diff changeset
   257
		if(conditionArea->TriggerArea()->Type() == CLbtGeoAreaBase::ECircle)
hgs
parents:
diff changeset
   258
			{
hgs
parents:
diff changeset
   259
			CLbtGeoCircle* circle = static_cast<CLbtGeoCircle*>(conditionArea->TriggerArea());
hgs
parents:
diff changeset
   260
			
hgs
parents:
diff changeset
   261
			// If the triggering area specified is less than the minimum triggering area
hgs
parents:
diff changeset
   262
			// the return KErrTriggerAreaTooSmall
hgs
parents:
diff changeset
   263
			
hgs
parents:
diff changeset
   264
			if(circle->Radius() < iSettingsManager.MinimumTriggeringArea())
hgs
parents:
diff changeset
   265
				{
hgs
parents:
diff changeset
   266
				CleanupStack::PopAndDestroy( 3 ); // trigger,stream,triggerEntry
hgs
parents:
diff changeset
   267
				LbtGlobal::RequestComplete(iMessage, KErrTriggerAreaTooSmall);
hgs
parents:
diff changeset
   268
				iObserver.HandleOperationClosureL(this, KErrTriggerAreaTooSmall);
hgs
parents:
diff changeset
   269
				return;
hgs
parents:
diff changeset
   270
				}
hgs
parents:
diff changeset
   271
hgs
parents:
diff changeset
   272
            CalculateRectangularArea(area, circle);
hgs
parents:
diff changeset
   273
			}
hgs
parents:
diff changeset
   274
		}
hgs
parents:
diff changeset
   275
		
hgs
parents:
diff changeset
   276
	// Create the extended trigger info
hgs
parents:
diff changeset
   277
	CLbtExtendedTriggerInfo* extendedTriggerInfo = 
hgs
parents:
diff changeset
   278
							CLbtExtendedTriggerInfo::NewL(area,
hgs
parents:
diff changeset
   279
														  CalculateHysteresisAreaForTrigger(*trigger),
hgs
parents:
diff changeset
   280
														  EFalse,
hgs
parents:
diff changeset
   281
														  KNullDesC8,
hgs
parents:
diff changeset
   282
														  iMessage.SecureId(),
hgs
parents:
diff changeset
   283
														  triggerCreationInfo.iFireOnCreation);
hgs
parents:
diff changeset
   284
	CleanupStack::PushL(extendedTriggerInfo);
hgs
parents:
diff changeset
   285
	
hgs
parents:
diff changeset
   286
	TLbtTriggerDynamicInfo* dynInfo = new (ELeave) TLbtTriggerDynamicInfo;
hgs
parents:
diff changeset
   287
	CleanupStack::PushL(dynInfo);
hgs
parents:
diff changeset
   288
	dynInfo->iValidity = TLbtTriggerDynamicInfo::EValid;
hgs
parents:
diff changeset
   289
	
hgs
parents:
diff changeset
   290
hgs
parents:
diff changeset
   291
		
hgs
parents:
diff changeset
   292
	// Create trigger class of Container. Container takes ownership of trigger and all info sent to it
hgs
parents:
diff changeset
   293
	iContainerTriggerEntry = CLbtContainerTriggerEntry::NewL(trigger, dynInfo, extendedTriggerInfo);
hgs
parents:
diff changeset
   294
	
hgs
parents:
diff changeset
   295
	// Register for container change event observer
hgs
parents:
diff changeset
   296
    TLbtTriggerEventMask eventMask = 0;
hgs
parents:
diff changeset
   297
    eventMask|= CLbtContainer::ELbtConTriggerCreated;
hgs
parents:
diff changeset
   298
                
hgs
parents:
diff changeset
   299
    iContainer.SetChangeObserver( this ,eventMask );
hgs
parents:
diff changeset
   300
	
hgs
parents:
diff changeset
   301
	// Creates the trigger in the container		
hgs
parents:
diff changeset
   302
	iContainer.CreateTrigger(*iContainerTriggerEntry,iAOIdentificationNum,iStatus);
hgs
parents:
diff changeset
   303
	SetActive();
hgs
parents:
diff changeset
   304
	
hgs
parents:
diff changeset
   305
	CleanupStack::Pop(5); //trigger, stream, triggerEntryBuffer, dynInfo and extendedTriggerInfo
hgs
parents:
diff changeset
   306
	stream.Close();
hgs
parents:
diff changeset
   307
	delete triggerEntryBuffer;
hgs
parents:
diff changeset
   308
	}
hgs
parents:
diff changeset
   309
hgs
parents:
diff changeset
   310
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   311
// CLbtCreateTriggerAOOperation::CancelCreateTrigger
hgs
parents:
diff changeset
   312
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   313
//
hgs
parents:
diff changeset
   314
void CLbtCreateTriggerAOOperation::CancelCreateTrigger()
hgs
parents:
diff changeset
   315
	{
hgs
parents:
diff changeset
   316
	FUNC_ENTER("CLbtCreateTriggerAOOperation::CancelCreateTrigger");
hgs
parents:
diff changeset
   317
	Cancel();
hgs
parents:
diff changeset
   318
	}
hgs
parents:
diff changeset
   319
	
hgs
parents:
diff changeset
   320
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   321
// CLbtCreateTriggerAOOperation::GetTriggerId
hgs
parents:
diff changeset
   322
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   323
//
hgs
parents:
diff changeset
   324
TLbtTriggerId CLbtCreateTriggerAOOperation::GetTriggerId()
hgs
parents:
diff changeset
   325
	{
hgs
parents:
diff changeset
   326
	FUNC_ENTER("CLbtCreateTriggerAOOperation::GetTriggerId");
hgs
parents:
diff changeset
   327
	return iContainerTriggerEntry->TriggerEntry()->Id();
hgs
parents:
diff changeset
   328
	}
hgs
parents:
diff changeset
   329
hgs
parents:
diff changeset
   330
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   331
// CLbtCreateTriggerAOOperation::CalculateHysteresisAreaForTrigger
hgs
parents:
diff changeset
   332
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   333
//
hgs
parents:
diff changeset
   334
TInt CLbtCreateTriggerAOOperation::CalculateHysteresisAreaForTrigger(
hgs
parents:
diff changeset
   335
    CLbtTriggerEntry& aTrigger)
hgs
parents:
diff changeset
   336
	{
hgs
parents:
diff changeset
   337
	FUNC_ENTER("CLbtCreateTriggerAOOperation::CalculateHysteresisAreaForTrigger");
hgs
parents:
diff changeset
   338
	// The Hysteresis for trigger is calculated as per this formula
hgs
parents:
diff changeset
   339
	// If radius <= 500 
hgs
parents:
diff changeset
   340
	//      hysteresis = radius / 4.
hgs
parents:
diff changeset
   341
	// Else
hgs
parents:
diff changeset
   342
	//      hysteresis = radius / Ln(radius/10) ( Log to the base e)
hgs
parents:
diff changeset
   343
	// After the formula 
hgs
parents:
diff changeset
   344
	// if hysteresis < MinimumHysteresisRadius
hgs
parents:
diff changeset
   345
	//      hysteresis is taken to be the minimumHysteresis radius.
hgs
parents:
diff changeset
   346
	
hgs
parents:
diff changeset
   347
	// The constant values have to be store in cenrep and read
hgs
parents:
diff changeset
   348
	// from there.
hgs
parents:
diff changeset
   349
	
hgs
parents:
diff changeset
   350
	TReal hysteresis = 0;
hgs
parents:
diff changeset
   351
	CLbtTriggerConditionBase* conditionBase = aTrigger.GetCondition();
hgs
parents:
diff changeset
   352
	TReal radius = 0.0;
hgs
parents:
diff changeset
   353
	
hgs
parents:
diff changeset
   354
	// Fist find the type of the trigger
hgs
parents:
diff changeset
   355
	if(conditionBase->Type() == 
hgs
parents:
diff changeset
   356
	                    CLbtTriggerConditionBase::ETriggerConditionArea)
hgs
parents:
diff changeset
   357
		{
hgs
parents:
diff changeset
   358
		CLbtTriggerConditionArea* basicCondition = 
hgs
parents:
diff changeset
   359
		                static_cast<CLbtTriggerConditionArea*>(conditionBase);
hgs
parents:
diff changeset
   360
		if(basicCondition->TriggerArea()->Type() == CLbtGeoAreaBase::ECircle)
hgs
parents:
diff changeset
   361
			{
hgs
parents:
diff changeset
   362
			// The trigger area is circular. Apply hysteresis formula for a circular area
hgs
parents:
diff changeset
   363
			CLbtGeoCircle* circle = 
hgs
parents:
diff changeset
   364
			        static_cast<CLbtGeoCircle*>(basicCondition->TriggerArea());
hgs
parents:
diff changeset
   365
			
hgs
parents:
diff changeset
   366
			radius = circle->Radius();
hgs
parents:
diff changeset
   367
			
hgs
parents:
diff changeset
   368
			if(radius > KCircleRadiusCutoff)
hgs
parents:
diff changeset
   369
				{
hgs
parents:
diff changeset
   370
				TReal logRadius;				
hgs
parents:
diff changeset
   371
				Math::Ln(logRadius, radius / 10 );
hgs
parents:
diff changeset
   372
				hysteresis = radius / logRadius;
hgs
parents:
diff changeset
   373
				}
hgs
parents:
diff changeset
   374
			else
hgs
parents:
diff changeset
   375
				{
hgs
parents:
diff changeset
   376
				hysteresis = radius / 4;
hgs
parents:
diff changeset
   377
				}
hgs
parents:
diff changeset
   378
			}
hgs
parents:
diff changeset
   379
		}
hgs
parents:
diff changeset
   380
		
hgs
parents:
diff changeset
   381
	if(hysteresis < KMinHysteresisArea)
hgs
parents:
diff changeset
   382
		{
hgs
parents:
diff changeset
   383
		hysteresis = KMinHysteresisArea;
hgs
parents:
diff changeset
   384
		}
hgs
parents:
diff changeset
   385
hgs
parents:
diff changeset
   386
	return (hysteresis + radius);
hgs
parents:
diff changeset
   387
	}
hgs
parents:
diff changeset
   388
hgs
parents:
diff changeset
   389
hgs
parents:
diff changeset
   390
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   391
// CLbtCreateTriggerAOOperation::CalculateRectangularArea
hgs
parents:
diff changeset
   392
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   393
//
hgs
parents:
diff changeset
   394
void CLbtCreateTriggerAOOperation::CalculateRectangularArea(
hgs
parents:
diff changeset
   395
    CLbtExtendedTriggerInfo::TLbtTriggerRectArea& aArea,
hgs
parents:
diff changeset
   396
    CLbtGeoCircle* aCircle)
hgs
parents:
diff changeset
   397
    {
hgs
parents:
diff changeset
   398
    FUNC_ENTER("CLbtCreateTriggerAOOperation::CalculateRectangularArea");
hgs
parents:
diff changeset
   399
	TCoordinate center = aCircle->Center();
hgs
parents:
diff changeset
   400
	TCoordinate tmp = center;
hgs
parents:
diff changeset
   401
	// Get the North Latitude of the ractangular area by moving north
hgs
parents:
diff changeset
   402
	// (by using a bearing of 0).
hgs
parents:
diff changeset
   403
	tmp.Move(0, aCircle->Radius());
hgs
parents:
diff changeset
   404
	aArea.iTrigAreaNorthLat = tmp.Latitude();
hgs
parents:
diff changeset
   405
hgs
parents:
diff changeset
   406
	// From the previous point, Move west(by using a bearing of 270).
hgs
parents:
diff changeset
   407
	// This gives the West Longitude.
hgs
parents:
diff changeset
   408
	tmp.Move(270,aCircle->Radius());
hgs
parents:
diff changeset
   409
	aArea.iTrigAreaWestLong = tmp.Longitude();
hgs
parents:
diff changeset
   410
	
hgs
parents:
diff changeset
   411
hgs
parents:
diff changeset
   412
	// Reset tmp to the center
hgs
parents:
diff changeset
   413
	tmp = center;
hgs
parents:
diff changeset
   414
hgs
parents:
diff changeset
   415
	// Get the South Latitude by moving south
hgs
parents:
diff changeset
   416
	// (by using a bearing of 180).
hgs
parents:
diff changeset
   417
	tmp.Move(180, aCircle->Radius());
hgs
parents:
diff changeset
   418
	aArea.iTrigAreaSouthLat = tmp.Latitude();
hgs
parents:
diff changeset
   419
hgs
parents:
diff changeset
   420
	// From the previous point, Move east(by using a bearing of 90).
hgs
parents:
diff changeset
   421
	// This gives the Eest Longitude.
hgs
parents:
diff changeset
   422
	tmp.Move(90,aCircle->Radius());
hgs
parents:
diff changeset
   423
	aArea.iTrigAreaEastLong = tmp.Longitude();
hgs
parents:
diff changeset
   424
	
hgs
parents:
diff changeset
   425
	return;
hgs
parents:
diff changeset
   426
    }
hgs
parents:
diff changeset
   427
// end of file