Controlling light settings using CHWRMLight
Keywords (APIs, classes, methods, functions): CHWRMLight,MHWRMLightObserver,CHWRMLight::TLightStatus, CHWRMLight::ReserveLightL(), CHWRMLight::ReleaseLight(), CHWRMLight::LightOnL(), CHWRMLight::LightBlinkL(), CHWRMLight::LightOffL(), CHWRMLight::LightStatus(), MHWRMLightObserver::LightStatusChanged()
Overview
This code snippet shows how the CHWRMLight class can be used to control light settings. The example class CLightController contains methods to reserve and release light targets, set light target to on, off, or blinking, and it also receives notifications about light target status changes by implementing the interface MHWRMLightObserver.
This snippet can be self-signed.
MMP file
The following libraries are required:
LIBRARY HWRMLightClient.lib
LIBRARY avkon.lib //CAknListQueryDialog CAknNumberQueryDialog
Resource file
-------------------------------------------------------------------------------------------------
#include <eikon.rh>
#include <avkon.rsg>
#include <avkon.rh>
RESOURCE ARRAY r_lightcontroller_bool_items
{
items =
{
LBUF { txt = "EFalse"; },
LBUF { txt = "ETrue"; }
};
}
RESOURCE DIALOG r_lightcontroller_light_intensity_query
{
flags=EGeneralQueryFlags;
buttons=R_AVKON_SOFTKEYS_OK_CANCEL;
items=
{
DLG_LINE
{
type=EAknCtQuery;
id=EGeneralQuery;
control= AVKON_DATA_QUERY
{
layout = ENumberLayout;
label = "Enter light intensity (0 to 100)";
control = AVKON_INTEGER_EDWIN
{
min=0;
max=100;
};
};
}
};
}
RESOURCE DIALOG r_lightcontroller_duration_query
{
flags=EGeneralQueryFlags;
buttons=R_AVKON_SOFTKEYS_OK_CANCEL;
items=
{
DLG_LINE
{
type=EAknCtQuery;
id=EGeneralQuery;
control= AVKON_DATA_QUERY
{
layout = ENumberLayout;
label = "Enter duration (0 to 2147482)";
control = AVKON_INTEGER_EDWIN
{
min=0;
max=2147482;
};
};
}
};
}
RESOURCE ARRAY r_lightcontroller_lightstarget_items
{
items =
{
LBUF { txt = "ENoTarget"; },
LBUF { txt = "EPrimaryDisplay"; },
LBUF { txt = "EPrimaryKeyboard"; },
LBUF { txt = "EPrimaryDisplayAndKeyboard"; },
LBUF { txt = "ESecondaryDisplay"; },
LBUF { txt = "ESecondaryKeyboard"; },
LBUF { txt = "ESecondaryDisplayAndKeyboard"; },
LBUF { txt = "ECustomTarget1"; },
LBUF { txt = "ECustomTarget2"; },
LBUF { txt = "ECustomTarget3"; },
LBUF { txt = "ECustomTarget4"; }
};
}
RESOURCE DIALOG r_lightcontroller_lightstarget_list
{
flags = EGeneralQueryFlags;
buttons = R_AVKON_SOFTKEYS_OK_CANCEL;
items =
{
DLG_LINE
{
type = EAknCtListQueryControl;
id = EListQueryControl;
control = AVKON_LIST_QUERY_CONTROL
{
listtype = EAknCtSinglePopupMenuListBox;
heading = "Lights target:";
listbox = LISTBOX
{
flags = EAknListBoxSelectionList;
array_id = r_lightcontroller_lightstarget_items;
};
};
}
};
}
RESOURCE AVKON_LIST_QUERY r_lightcontroller_restore_list
{
flags = EGeneralQueryFlags;
items =
{
AVKON_LIST_QUERY_DLG_LINE
{
type = EAknCtListQueryControl;
id = EListQueryControl;
control = AVKON_LIST_QUERY_CONTROL
{
listtype = EAknCtSinglePopupMenuListBox;
heading = "Restore parameter:";
listbox = LISTBOX
{
flags = EAknListBoxSelectionList;
array_id = r_lightcontroller_bool_items;
};
};
}
};
}
RESOURCE AVKON_LIST_QUERY r_lightcontroller_noccoeenv_list
{
flags = EGeneralQueryFlags;
items =
{
AVKON_LIST_QUERY_DLG_LINE
{
type = EAknCtListQueryControl;
id = EListQueryControl;
control = AVKON_LIST_QUERY_CONTROL
{
listtype = EAknCtSinglePopupMenuListBox;
heading = "NoCCoeEnv parameter:";
listbox = LISTBOX
{
flags = EAknListBoxSelectionList;
array_id = r_lightcontroller_bool_items;
};
};
}
};
}
RESOURCE AVKON_LIST_QUERY r_lightcontroller_fade_list
{
flags = EGeneralQueryFlags;
items =
{
AVKON_LIST_QUERY_DLG_LINE
{
type = EAknCtListQueryControl;
id = EListQueryControl;
control = AVKON_LIST_QUERY_CONTROL
{
listtype = EAknCtSinglePopupMenuListBox;
heading = "Fade parameter:";
listbox = LISTBOX
{
flags = EAknListBoxSelectionList;
array_id = r_lightcontroller_bool_items;
};
};
}
};
}
Header file
-----------------------------------------------------------------------------------------
#ifndef LIGHTCONTROLLER_H
#define LIGHTCONTROLLER_H
#include <HWRMLight.h>
class CLightController : public CBase,
public MHWRMLightObserver
{
public:
static CLightController* NewL();
~CLightController();
//ask reserve parameters with dialogs
void LightsReserveL();
void LightsReserveL(TInt aTarget,
TBool aRestoreState,
TBool aForceNoCCoeEnv);
//ask light on parameters with dialogs
void LightsOnL();
void LightsOnL(TInt aTarget,
TInt aDuration,
TInt aIntensity,
TBool aFadeIn);
//ask light blink parameters with dialogs
void LightsBlinkL();
void LightsBlinkL(TInt aTarget,
TInt aDuration,
TInt aOnDuration,
TInt aOffDuration,
TInt aIntensity);
//ask light off parameters with dialogs
void LightsOffL();
void LightsOffL(TInt aTarget,
TInt aDuration,
TBool aFadeOut);
void LightsReleaseL(TInt aTarget=0);
CHWRMLight::TLightStatus LightsStatusL(TInt aTarget=0);
private:
void ConstructL();
// from MHWRMLightObserver
virtual void LightStatusChanged(TInt aTarget,
CHWRMLight::TLightStatus aStatus);
// returns the target or KErrCancel if user pressed cancel
TInt GetLightsTargetL();
private:
CHWRMLight* iLight;
};
#endif // LIGHTCONTROLLER_H
Source file
----------------------------------------------------------------------------
#include <aknNoteWrappers.h> //CAknListQueryDialog,CAknNumberQueryDialog
#include <LightController.rsg>
#include "LightController.h"
CLightController* CLightController::NewL()
{
CLightController* self=
new(ELeave) CLightController( );
CleanupStack::PushL(self);
self->ConstructL();
CleanupStack::Pop(self);
return self;
}
void CLightController::ConstructL()
{
iLight = CHWRMLight::NewL(this);
}
CLightController::~CLightController()
{
delete iLight;
}
void CLightController::LightsReserveL(TInt aTarget,
TBool aRestoreState,
TBool aForceNoCCoeEnv)
{
if(aTarget <= CHWRMLight::ENoTarget || aTarget > CHWRMLight::ECustomTarget4)
LightsReserveL();
else
iLight->ReserveLightL( aTarget, aRestoreState, aForceNoCCoeEnv );
}
void CLightController::LightsReserveL()
{
TInt item(0);
TBool restore;
TBool forceNoCCoeEnv;
TInt target(CHWRMLight::ENoTarget);
// get the lights target
target = GetLightsTargetL();
if( target == KErrCancel )
{
// no target entered, just return
return;
}
CAknListQueryDialog* listDlg = new (ELeave)CAknListQueryDialog( &item );
if( listDlg->ExecuteLD(R_LIGHTCONTROLLER_RESTORE_LIST) )
{
// got restore state parameter
item == 0 ? restore = EFalse : restore = ETrue;
//now get force no CCoeEnv parameter
listDlg = new (ELeave)CAknListQueryDialog( &item );
if( listDlg->ExecuteLD(R_LIGHTCONTROLLER_NOCCOEENV_LIST) )
{
// got ForceNoCCoeEnv parameter
item == 0 ? forceNoCCoeEnv = EFalse : forceNoCCoeEnv = ETrue;
iLight->ReserveLightL( target, restore, forceNoCCoeEnv );
}
else
{
// did not get ForceNoCCoeEnv parameter
// do not call ReserveLightL() at all
}
}
else
{
// did not get restore parameter
iLight->ReserveLightL( target );
}
}
void CLightController::LightsReleaseL(TInt aTarget)
{
TInt target(CHWRMLight::ENoTarget);
if(aTarget <= CHWRMLight::ENoTarget || aTarget > CHWRMLight::ECustomTarget4)
{
// get the lights target
target = GetLightsTargetL();
}
else
{
target = aTarget;
}
if( target == KErrCancel )
{
// no target entered
// do not call ReleaseLight at all
}
else
{
//call ReleaseLight with the given target
iLight->ReleaseLight( target );
}
}
void CLightController::LightsOnL(TInt aTarget,
TInt aDuration,
TInt aIntensity,
TBool aFadeIn)
{
if(aTarget <= CHWRMLight::ENoTarget || aTarget > CHWRMLight::ECustomTarget4 ||
aDuration < KHWRMInfiniteDuration || aDuration > KHWRMLightMaxDuration ||
aIntensity < KHWRMDefaultIntensity || aIntensity > KHWRMLightMaxIntensity)
{
LightsOnL();
}
else
{
iLight->LightOnL(aTarget, aDuration,
aIntensity, aFadeIn);
}
}
void CLightController::LightsOnL()
{
TInt item(0);
TInt duration(0);
TInt intensity(0);
TInt target(CHWRMLight::ENoTarget);
TBool fade(EFalse);
// get the lights target
target = GetLightsTargetL();
if( target == KErrCancel )
{
// no target entered
// do not call LightOnL at all
return;
}
//duration
CAknNumberQueryDialog* queryDlg = CAknNumberQueryDialog::NewL( duration );
if( queryDlg->ExecuteLD( R_LIGHTCONTROLLER_DURATION_QUERY ) )
{
// got duration so get intensity
queryDlg = CAknNumberQueryDialog::NewL( intensity );
if( queryDlg->ExecuteLD( R_LIGHTCONTROLLER_LIGHT_INTENSITY_QUERY ) )
{
// got the intensity
CAknListQueryDialog* listDlg = new (ELeave)CAknListQueryDialog( &item );
if( listDlg->ExecuteLD(R_LIGHTCONTROLLER_FADE_LIST) )
{
// got fade parameter
item == 0 ? fade = EFalse : fade = ETrue;
iLight->LightOnL( target, duration, intensity, fade );
}
else
{
// did not get fade parameter
// do not call LightOnL() at all
}
}
else
{
// user pressed cancel for intensity query
iLight->LightOnL( target, duration );
}
}
else
{
// didn't get duration so call basic API
iLight->LightOnL( target );
}
}
void CLightController::LightsBlinkL(TInt aTarget,
TInt aDuration,
TInt aOnDuration,
TInt aOffDuration,
TInt aIntensity)
{
if(aTarget <= CHWRMLight::ENoTarget || aTarget > CHWRMLight::ECustomTarget4 ||
aDuration < KHWRMInfiniteDuration || aDuration > KHWRMLightMaxDuration ||
aOnDuration < KHWRMInfiniteDuration || aOnDuration > KHWRMLightMaxDuration ||
aOffDuration < KHWRMInfiniteDuration || aOffDuration > KHWRMLightMaxDuration ||
aIntensity < KHWRMDefaultIntensity || aIntensity > KHWRMLightMaxIntensity)
{
LightsBlinkL();
}
else
{
iLight->LightBlinkL(aTarget, aDuration, aOnDuration,
aOffDuration, aIntensity);
}
}
void CLightController::LightsBlinkL()
{
TInt duration(0);
TInt onDuration(0);
TInt offDuration(0);
TInt intensity(0);
// get the lights target
TInt target = GetLightsTargetL();
if( target == KErrCancel )
{
// no target entered, just return
return;
}
// get duration
CAknNumberQueryDialog* queryDlg = CAknNumberQueryDialog::NewL( duration );
if( queryDlg->ExecuteLD( R_LIGHTCONTROLLER_DURATION_QUERY ) )
{
// got duration so get OnDuration
queryDlg = CAknNumberQueryDialog::NewL( onDuration );
CleanupStack::PushL( queryDlg );
_LIT(KEnterONDuration, "Enter ON duration (0 to 2147482)");
queryDlg->SetPromptL( KEnterONDuration );
CleanupStack::Pop( queryDlg );
if( queryDlg->ExecuteLD( R_LIGHTCONTROLLER_DURATION_QUERY ) )
{
// got OnDuration so get OffDuration
queryDlg = CAknNumberQueryDialog::NewL( offDuration );
CleanupStack::PushL( queryDlg );
_LIT(KEnterOFFDuration, "Enter OFF duration (0 to 2147482)");
queryDlg->SetPromptL( KEnterOFFDuration );
CleanupStack::Pop( queryDlg );
if( queryDlg->ExecuteLD( R_LIGHTCONTROLLER_DURATION_QUERY ) )
{
// got OffDuration so get intensity
queryDlg = CAknNumberQueryDialog::NewL( intensity );
if( queryDlg->ExecuteLD( R_LIGHTCONTROLLER_LIGHT_INTENSITY_QUERY ) )
{
// got the intenstity
iLight->LightBlinkL( target, duration, onDuration,
offDuration, intensity );
}
else
{
// user pressed cancel for intensity
// do not call LightBlinkL() at all
}
}
else
{
// user pressed cancel for OffDuration
// do not call LightBlinkL() at all
}
}
else
{
// user pressed cancel for OnDuration
iLight->LightBlinkL( target, duration );
}
}
else
{
// user pressed cancel for Duration
iLight->LightBlinkL( target );
}
}
void CLightController::LightsOffL(TInt aTarget,
TInt aDuration,
TBool aFadeOut)
{
if(aTarget <= CHWRMLight::ENoTarget || aTarget > CHWRMLight::ECustomTarget4 ||
aDuration < KHWRMInfiniteDuration || aDuration > KHWRMLightMaxDuration)
{
LightsOffL();
}
else
{
iLight->LightOffL(aTarget, aDuration, aFadeOut);
}
}
void CLightController::LightsOffL()
{
TInt item(0);
TInt duration(0);
TInt target(CHWRMLight::ENoTarget);
TBool fade(EFalse);
// get the lights target
target = GetLightsTargetL();
if( target == KErrCancel )
{
// no target entered, just return
return;
}
//duration
CAknNumberQueryDialog* queryDlg = CAknNumberQueryDialog::NewL( duration );
if( queryDlg->ExecuteLD( R_LIGHTCONTROLLER_DURATION_QUERY ) )
{
// got duration so get fade
CAknListQueryDialog* listDlg = new (ELeave)CAknListQueryDialog( &item );
if( listDlg->ExecuteLD(R_LIGHTCONTROLLER_FADE_LIST) )
{
// got fade parameter
item == 0 ? fade = EFalse : fade = ETrue;
iLight->LightOffL( target, duration, fade );
}
else
{
// did not get fade parameter
iLight->LightOffL( target, duration );
}
}
else
{
// didn't get duration so call basic API
iLight->LightOffL( target );
}
}
CHWRMLight::TLightStatus CLightController::LightsStatusL(TInt aTarget)
{
TInt target(CHWRMLight::ENoTarget);
if(aTarget <= CHWRMLight::ENoTarget || aTarget > CHWRMLight::ECustomTarget4)
{
// get the lights target
target = GetLightsTargetL();
}
else
{
target = aTarget;
}
if( target == KErrCancel )
{
// no target entered
return CHWRMLight::ELightStatusUnknown;
}
else
{
return iLight->LightStatus( target );
}
}
TInt CLightController::GetLightsTargetL()
{
TInt item(0);
TInt ret(KErrCancel);
CAknListQueryDialog* listDlg = new (ELeave)CAknListQueryDialog( &item );
if( listDlg->ExecuteLD(R_LIGHTCONTROLLER_LIGHTSTARGET_LIST) )
{
// This is a lookup table for the items defined in the
// resource array r_lightcontroller_lightstarget_items
switch ( item )
{
case 0: // ENoTarget
{
ret = CHWRMLight::ENoTarget;
break;
}
case 1: // EPrimaryDisplay
{
ret = CHWRMLight::EPrimaryDisplay;
break;
}
case 2: // EPrimaryKeyboard
{
ret = CHWRMLight::EPrimaryKeyboard;
break;
}
case 3: // EPrimaryDisplayAndKeyboard
{
ret = CHWRMLight::EPrimaryDisplayAndKeyboard;
break;
}
case 4: // ESecondaryDisplay
{
ret = CHWRMLight::ESecondaryDisplay;
break;
}
case 5: // ESecondaryKeyboard
{
ret = CHWRMLight::ESecondaryKeyboard;
break;
}
case 6: // ESecondaryDisplayAndKeyboard
{
ret = CHWRMLight::ESecondaryDisplayAndKeyboard;
break;
}
case 7: // ECustomTarget1
{
ret = CHWRMLight::ECustomTarget1;
break;
}
case 8: // ECustomTarget2
{
ret = CHWRMLight::ECustomTarget2;
break;
}
case 9: // ECustomTarget3
{
ret = CHWRMLight::ECustomTarget3;
break;
}
case 10: // ECustomTarget4
{
ret = CHWRMLight::ECustomTarget4;
break;
}
default:
break;
}
}
else
{
// no target entered
ret = KErrCancel;
}
return ret;
}
void CLightController::LightStatusChanged(TInt aTarget,
CHWRMLight::TLightStatus aStatus)
{
if(!aTarget)
{
//No target specified
}
switch ( aStatus )
{
case CHWRMLight::ELightOn:
{
//ELightOn do something...
break;
}
case CHWRMLight::ELightOff:
{
//ELightOff do something...
break;
}
case CHWRMLight::ELightBlink:
{
//ELightBlink do something...
break;
}
case CHWRMLight::ELightStatusUnknown:
{
//ELightStatusUnknown do something...
break;
}
default:
{
//Lights status undefined do something...
break;
}
}
}
Using CLightController class
In the header file:
----------------------------------------------------------------------------------------------------------
class CLightController;
class CTestingAppUi : public CAknAppUi
{
//...
private:
//...
CLightController* iLightController;
};
In the source file:
--------------------------------------------------------------------------------------------------------
#include "LightController.h"
#include <HWRMLight.h>
void CTestingAppUi::ConstructL()
{
iLightController = CLightController::NewL();
}
CTestingAppUi::~CTestingAppUi()
{
delete iLightController;
}
void CTestingAppUi::ControlLightsL()
{
CHWRMLight::TLightTarget target = CHWRMLight::EPrimaryDisplayAndKeyboard;
// == RESERVE ==
/*
1. target - the light device that should be controlled (display, keyboard,
hardware-specific custom target)
2. param - restore: if ETrue is selected, the light state on last release
will be restored
upon successful reservation.
3. param - NoCCoeEnv: if EFalse is selected, the light target will be automatically
released when the
application goes to background and reserved when the application is restored
to foreground.
*/
//show dialogs to ask values
iLightController->LightsReserveL();
//...or set values without dialogs
iLightController->LightsReserveL(target, EFalse, EFalse);
// == LIGHTS ON ==
/*
1. param - target: the light device that should be controlled (display,
keyboard, hardware specific custom target)
2. param - duration: time in milliseconds light target will be active
3. param - intensity: percentage of full light intensity
4. param - fade: if ETrue is selected, the light target will be
turned on/off gradually (fade-in/fade-out)
*/
//show dialogs to ask values
iLightController->LightsOnL();
//...or set values without dialogs
iLightController->LightsOnL(target, 2000, 50, EFalse);
// == LIGHTS BLINK ==
/*
1. param - target: the light device that should be controlled (display,
keyboard, hardware-specific custom target)
2-4. - params durations: times in milliseconds that the light target will be active
5. param - intensity: percentage of full light intensity
*/
//show dialogs to ask values
iLightController->LightsBlinkL();
//...or set values without dialogs
iLightController->LightsBlinkL(target, 2000, 1000, 1000, 50);
// == LIGHTS OFF ==
/*
1. param - target: the light device that should be controlled (display, keyboard,
hardware-specific custom target)
2. param - duration: time in milliseconds that the light target will be active
3. param - fade: if ETrue is selected, the light target will be turned
on/off gradually (fade-in/fade-out)
*/
//show dialogs to ask values
iLightController->LightsOffL();
//...or set values without dialogs
iLightController->LightsOffL(target, 2000, EFalse);
// == RELEASE ==
//show dialogs to ask target
iLightController->LightsReleaseL();
//...or set target without a dialog
iLightController->LightsReleaseL(target);
// == GET STATUSES
//show dialog to ask target
CHWRMLight::TLightStatus status(CHWRMLight::ELightStatusUnknown);
status = iLightController->LightsStatusL();
//...or set target without a dialog
status = iLightController->LightsStatusL(target);
}
Postconditions
The CLightController class controls light settings and receives information on light target status changes.