?? csmshandler.cpp
字號:
// -----------------------------------------------------------------------------
//
void CSmsHandler::AccessMtmL()
{
// Create an MTM Registry object.
iMtmRegistry = CClientMtmRegistry::NewL( *iSession );
// Create an SMS Client MTM object.
iSmsMtm = STATIC_CAST( CSmsClientMtm*, iMtmRegistry->NewMtmL( KUidMsgTypeSMS ) );
}
// -----------------------------------------------------------------------------
// CSmsHandler::SendL()
// Starts the process of creating and sending an SMS message.
// -----------------------------------------------------------------------------
//
TBool CSmsHandler::SendL( const TDesC& aRecipientNumber,
const TDesC& aMessageText )
{
iRecipientNumber = aRecipientNumber;
iMessageText = aMessageText;
if ( CreateMsgL() )
{
return ETrue;
}
return EFalse;
}
// -----------------------------------------------------------------------------
// CSmsHandler::CreateMsgL()
// Create an SMS message.
// -----------------------------------------------------------------------------
//
TBool CSmsHandler::CreateMsgL()
{
// Current entry is the Draft folder.
iSmsMtm->SwitchCurrentEntryL( KMsvDraftEntryId );
// Create a new SMS message entry as a child of the current context.
iSmsMtm->CreateMessageL( KUidMsgTypeSMS.iUid );
CMsvEntry& serverEntry = iSmsMtm->Entry();
TMsvEntry entry( serverEntry.Entry() );
CRichText& body = iSmsMtm->Body(); // the body of the message
body.Reset();
// Insert the message text gotten as input from user.
body.InsertL( 0, iMessageText );
// Message will be sent immediately.
entry.SetSendingState( KMsvSendStateWaiting );
entry.iDate.HomeTime(); // insert current time
// Set the SMS message settings for the message.
CSmsHeader& header = iSmsMtm->SmsHeader();
CSmsSettings* settings = CSmsSettings::NewL();
CleanupStack::PushL( settings );
settings->CopyL( iSmsMtm->ServiceSettings() ); // restore settings
settings->SetDelivery( ESmsDeliveryImmediately ); // to be delivered immediately
header.SetSmsSettingsL( *settings ); // new settings
// Let's check if there is a service center address.
if ( header.Message().ServiceCenterAddress().Length() == 0 )
{
// No, there isn't. We assume there is at least one service center
// number set and use the default service center number.
CSmsSettings* serviceSettings = &( iSmsMtm->ServiceSettings() );
// Check if number of service center addresses in the list is null.
if ( !serviceSettings->NumSCAddresses() )
{
HBufC* text = StringLoader::LoadLC( R_SMS_SC_NBR_MISSING );
CAknWarningNote* warningNote = new ( ELeave ) CAknWarningNote;
warningNote->ExecuteLD( *text );
CleanupStack::PopAndDestroy( text );
// Remember to pop settings even if this branch is taken.
CleanupStack::PopAndDestroy( settings );
return EFalse; // quit creating the message
}
else
{
// Set service center address to default.
// The caller does not take ownership of the returned object.
CSmsNumber* smsCenter =
&( serviceSettings->SCAddress( serviceSettings->DefaultSC() ) );
header.Message().SetServiceCenterAddressL( smsCenter->Address() );
}
}
CleanupStack::PopAndDestroy( settings );
// Recipient number is displayed also as the recipient alias.
entry.iDetails.Set( iRecipientNumber );
// Add addressee.
iSmsMtm->AddAddresseeL( iRecipientNumber, entry.iDetails );
// Validate message.
if ( !ValidateL() )
{
return EFalse;
}
entry.SetVisible( ETrue ); // set message as visible
entry.SetInPreparation( EFalse ); // set together with the visibility flag
serverEntry.ChangeL( entry ); // commit changes
iSmsMtm->SaveMessageL(); // save message
TMsvSelectionOrdering selection;
CMsvEntry* parentEntry =
CMsvEntry::NewL( iSmsMtm->Session(), KMsvDraftEntryId, selection );
CleanupStack::PushL( parentEntry );
// Move message to Outbox.
iOperation =
parentEntry->MoveL( entry.Id(), KMsvGlobalOutBoxIndexEntryId, iStatus );
CleanupStack::PopAndDestroy( parentEntry );
iState = EWaitingForMoving;
SetActive();
return ETrue;
}
// -----------------------------------------------------------------------------
// CSmsHandler::ValidateL()
// Validate an SMS message.
// -----------------------------------------------------------------------------
//
TBool CSmsHandler::ValidateL()
{
// Empty part list to hold the result.
TMsvPartList result( KMsvMessagePartNone );
// Validate message body.
result = iSmsMtm->ValidateMessage( KMsvMessagePartBody );
if ( result != KMsvMessagePartNone )
{
HBufC* text = StringLoader::LoadLC( R_SMS_MSG_BODY );
CAknWarningNote* warningNote = new ( ELeave ) CAknWarningNote;
warningNote->ExecuteLD( *text );
CleanupStack::PopAndDestroy( text );
return EFalse;
}
// Validate recipient.
result = iSmsMtm->ValidateMessage( KMsvMessagePartRecipient );
if ( result != KMsvMessagePartNone )
{
HBufC* text = StringLoader::LoadLC( R_SMS_RECIPIENT_NBR );
CAknWarningNote* warningNote = new ( ELeave ) CAknWarningNote;
warningNote->ExecuteLD( *text );
CleanupStack::PopAndDestroy( text );
return EFalse;
}
return ETrue;
}
// -----------------------------------------------------------------------------
// CSmsHandler::ScheduleL()
// Schedule an SMS message for sending.
// -----------------------------------------------------------------------------
//
void CSmsHandler::ScheduleL()
{
CMsvEntrySelection* selection = new ( ELeave ) CMsvEntrySelection;
CleanupStack::PushL( selection );
selection->AppendL( iSmsMtm->Entry().EntryId() ); // add message to selection
// Add entry to task scheduler.
TBuf8<1> dummyParams; // dummy parameters needed for InvokeAsyncFunctionL
iOperation = iSmsMtm->InvokeAsyncFunctionL( ESmsMtmCommandScheduleCopy,
*selection, dummyParams, iStatus );
CleanupStack::PopAndDestroy( selection );
iState = EWaitingForScheduling;
SetActive();
}
// -----------------------------------------------------------------------------
// CSmsHandler::MessageReceivedL()
// Handles a received SMS message.
// -----------------------------------------------------------------------------
//
void CSmsHandler::MessageReceivedL( TMsvId aEntryId )
{
CMsvEntry* serverEntry = iSession->GetEntryL( aEntryId ); // current entry
CleanupStack::PushL( serverEntry );
TMsvEntry entry = serverEntry->Entry(); // currently handled message entry
entry.SetNew( ETrue );
entry.SetUnread( ETrue );
entry.SetVisible( ETrue );
serverEntry->ChangeL( entry ); // commit changes
iSmsAppUi->MessageReceived(); // let UI know we have received a message
CleanupStack::PopAndDestroy( serverEntry );
HBufC* text = StringLoader::LoadLC( R_SMS_MSG_RECEIVED );
CAknInformationNote* informationNote =
new ( ELeave ) CAknInformationNote;
informationNote->ExecuteLD( *text );
CleanupStack::PopAndDestroy( text );
}
// -----------------------------------------------------------------------------
// CSmsHandler::ViewL()
// Dispalys a received SMS message.
// -----------------------------------------------------------------------------
//
void CSmsHandler::ViewL()
{
// There is an own registry for UI MTM's.
iMtmUiRegistry = CMtmUiRegistry::NewL( *iSession );
// We are interested in the next unread message.
TMsvId entryId( iSelection->At( iNextUnread ) );
CMsvEntry* serverEntry = iSession->GetEntryL( entryId );
CleanupStack::PushL( serverEntry );
// Create new MTM.
CBaseMtm* clientMtm = iMtmRegistry->NewMtmL( serverEntry->Entry().iMtm );
CleanupStack::PushL( clientMtm );
clientMtm->SwitchCurrentEntryL( serverEntry->EntryId() );
// Check if there are more unreads messages.
iNextUnread++;
if ( iNextUnread < iSelection->Count() )
{
iSmsAppUi->MessageReceived(); // still messages to read
}
else
{
iSmsAppUi->NoMoreUnread(); // no more messages to read
}
TMsvEntry entry( serverEntry->Entry() );
entry.SetNew( EFalse ); // message is no longer new
entry.SetUnread( EFalse ); // message is no longer unread
serverEntry->ChangeL( entry ); // commit changes
CBaseMtmUi* ui = iMtmUiRegistry->NewMtmUiL( *clientMtm ); // UI MTM for SMS
CleanupStack::PushL( ui );
// Display the SMS using the UI MTM.
iOperation = ui->ViewL( iStatus );
CleanupStack::PopAndDestroy( 3 ); // ui, clientMtm, serverEntry
SetActive();
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -