Utilising media keys on S60 devices

本文介绍如何在S60第三版设备上通过Remote Control API捕获媒体按键事件,如音量增减等,并提供了实现代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Description

Key presses of media keys cannot be detected in the same way as other key events. Media keys, such as Play/Pause, Stop, Volume Up/Down, Rewind, and Forward keys featured on some S60 3rd Edition devices do not generate normal key events that could be handled within the application framework, for example, in HandleKeyEventL() or OfferKeyEventL() .

Solution

Events from media keys can be handled with the Remote Control API . Below is a code snippet that demonstrates this.

Remote Control API requires ReadUserData capability.

 

To handle hardware keys the following approach can be followed.

1) Derive a class from MRemConCoreApiTargetObserver

2) Use the following code snippet in your class.
CRemConInterfaceSelector* iSelector;
CRemConCoreApiTarget* iTarget;

//preferably in the constructL()
iSelector=CRemConInterfaceSelector::NewL();
iTarget = CRemConCoreApiTarget::NewL( *iSelector, *this );
iSelector->OpenTargetL();


3) MrccatoCommand() api is an virtual method in MRemConCoreApiTargetObserver which should be implemented.This is a callback method which will be called by the framework when a hardware key is pressed.

void MrccatoCommand(TRemConCoreApiOperationId aOperationId,TRemConCoreApiButtonAction aButtonAct)
{

switch(aOperationId)
{
case ERemConCoreApiVolumeDown:
{
//do your own stuff
break;
}
case ERemConCoreApiVolumeUp:
{
//do your own stuff
break;
}
}
}

4) Header file for CRemConInterfaceSelector: remconinterfaceselector.h
Library: remconinterfacebase.lib
Header file for CRemConCoreApiTarget: remconcoreapitarget.h
Library:remconcoreapi.lib

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值