# HG changeset patch # User Dominic Pinkman # Date 1278071496 -3600 # Node ID 5072524fcc7971cb6e13ae797e9b1c05ae631a13 # Parent d4524d6a4472757948c886154391fb050644b6ca Fixing terminology diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-17C64C2F-9426-4B41-9F0A-23060289D644.dita --- a/Symbian3/PDK/Source/GUID-17C64C2F-9426-4B41-9F0A-23060289D644.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-17C64C2F-9426-4B41-9F0A-23060289D644.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,88 +1,98 @@ - - - - - -Multi-touch -

Multi-touch is an enhancement to the touch screen, which provides -the user with the ability to apply elaborate finger gestures onto -the display as commands to the device.

-

Multi-touch is implemented based on the size and type of interfaces. -When a finger or an object touches the display causing the light to -scatter, the reflection is caught by the sensors. The response for -the touch is sent back based on the type of reflection measured.

-

Only the devices with multi-touch support have 'Pinch Stroke' as -a touch stroke.

-
Pinch -StrokePinch stroke is invoked by two separate but simultaneously -active touch down events and dragging movements along the line that -goes through both touch down points. On release, the pinch in or pinch -out state is maintained. Pinch stroke can be utilized, for example, -in Photo viewer to zoom in and zoom out. - -

The following table lists the default touch-events for pinch-stroke:

Default -touch events for pinch-stroke - - - -

User action

-

State change

-

Feedback

-
- - - -

First touch down

-

No action.

-

Tactile:

    -
  • First touch down tactile feedback follows the context-based -feedback.

  • -
  • Audio feedback is provided with touch down.

  • -

-
- -

Second simultaneous touch down

-

Activates multi-touch mode for the content defined.

-

Tactile:

    -
  • When second finger is touched down multi-touch recognition, -two sensitive pulses effect is provided.

  • -
  • Audio feedback is provided with touch down.

  • -

-
- -

Pinch in

-

Moving the touch points (directly) closer to each other -is recognized as pinch in. Application can use it, for example, for -zooming out a picture. The behavior should be in relation to the speed -and size of the stroke.

-

Tactile: Smooth pinch effect is provided while moving the -fingers.

No audio feedback is provided.

-
- -

Pinch out

-

Moving the touch points (directly) away from each other -is recognized as pinch out. Application can use it, for example, for -zooming in a picture. The behavior should be in relation to the speed -and size of the stroke.

-

Tactile: Smooth pinch effect is provided while moving the -fingers.

No audio feedback is provided.

-
- -

Touch release

-

Releasing one or both fingers stops the pinch.

-

No tactile or audio feedback given.

-
- - -
-
Using multi-touch in applicationsFor multi-touch, -use classes TRawEvent and TAdvancedPointerEvent (which extends TPointerEvent). For more information, -see Advanced -pointers section.
-
\ No newline at end of file + + + + +Mu<?Pub Caret?>ltiple touch + + + + +

Multiple touch is an enhancement to the touch screen, which provides +the user with the ability to apply elaborate finger gestures onto +the display as commands to the device.

+

Multiple touch is implemented based on the size and type of interfaces. +When a finger or an object touches the display causing the light to +scatter, the reflection is caught by the sensors. The response for +the touch is sent back based on the type of reflection measured.

+

Only the devices with multiple touch support have 'Pinch Stroke' +as a touch stroke.

+
Pinch +StrokePinch stroke is invoked by two separate but simultaneously +active touch down events and dragging movements along the line that +goes through both touch down points. On release, the pinch in or pinch +out state is maintained. Pinch stroke can be utilized, for example, +in Photo viewer to zoom in and zoom out.

The following table lists the +default touch-events for pinch-stroke:

+Default touch events for pinch-stroke + + + +

User action

+

State change

+

Feedback

+
+ + + +

First touch down

+

No action.

+

Tactile:

    +
  • First touch down tactile feedback follows the context-based +feedback.

  • +
  • Audio feedback is provided with touch down.

  • +

+
+ +

Second simultaneous touch down

+

Activates multiple touch mode for the content defined.

+

Tactile:

    +
  • When second finger is touched down, two sensitive pulses effect +is provided.

  • +
  • Audio feedback is provided with touch down.

  • +

+
+ +

Pinch in

+

Moving the touch points (directly) closer to each other +is recognized as pinch in. Application can use it, for example, for +zooming out a picture. The behavior should be in relation to the speed +and size of the stroke.

+

Tactile: Smooth pinch effect is provided while moving the +fingers.

No audio feedback is provided.

+
+ +

Pinch out

+

Moving the touch points (directly) away from each other +is recognized as pinch out. Application can use it, for example, for +zooming in a picture. The behavior should be in relation to the speed +and size of the stroke.

+

Tactile: Smooth pinch effect is provided while moving the +fingers.

No audio feedback is provided.

+
+ +

Touch release

+

Releasing one or both fingers stops the pinch.

+

No tactile or audio feedback given.

+
+ + +
+
Using +multiple touch in applicationsFor multiple touch, use classes TRawEvent and TAdvancedPointerEvent (which extends TPointerEvent). For more information, see Advanced pointers section.
+
+
+ diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-1FCD0312-7B28-47F9-BE54-822B74A8934C.dita --- a/Symbian3/PDK/Source/GUID-1FCD0312-7B28-47F9-BE54-822B74A8934C.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-1FCD0312-7B28-47F9-BE54-822B74A8934C.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,78 +1,84 @@ - - - - - -Designing -applications for touch UI -

Both touch screens and hybrid devices are supported by Symbian platform. -Touch screen enables direct manipulation of content and objects, allowing -for far more natural interaction with the device. This means a completely -different user experience and interaction style compared to using a hardware -keypad.

- - - -

All applications must be touch-enabled, which means that they can be used -with the touch screen alone, regardless of the presence of a keypad. In Symbian -platform-based touch devices, the important hardware keys are Send, End, Multi-tasking -and Power key.

-

The application features must follow the platform support for different -hardware. When designing a touch-enabled Symbian application, the UI must -be designed so that everything can be accomplished by using the touch screen -interface, as the potential target devices may or may not have a hardware -keyboard.

-

The touch UI in the Symbian platform is based on the use of resistive and -capacitive touch screens. In resistive touch screen technology, two -conductive and resistive layers are separated by a thin space. When an object -touches this kind of touch panel, the layers are connected at a certain point, -and a touch event is registered. This allows efficient stylus control, in -addition to finger touch - unlike capacitive panels, which usually register -only finger touch. Additionally, resistive touch screen offers a higher resolution -and more durability. In capacitive touch screen technology, the panel -consists of an insulator such as glass, coated with a transparent conductor -(such as indium tin oxide (ITO)). When an object touches the surface of the -screen, it results in a distortion of the local electrostatic field, measurable -as a change in capacitance. Then a touch controller measures the frequency -variations to ascertain the co-ordinates of the object's touch. Capacitive -touch screen supports multi-touch.

-

The hardware is supported by various:

-
    -
  • touch-specific components (see Touch -support for common UI components)

  • -
  • component and UI behavior changes

  • -
  • layout changes, and

  • -
  • additions to the interaction style.

  • -
-

The touch UI is designed to enable full task flow with touch, with minimal -need to switch to hardware keys. Thus, the design ensures that users can complete -a task with the chosen interaction method from start to finish.

-

While designing and implementing applications for touch screen devices -based on the Symbian platform, consider interactions that benefit the most -from the touch UI.

-

If you can apply direct manipulation of the UI, for example when moving -items from one place to another, or scrolling a page, do not confine the user -with unnecessary scrollbars or have the user resort to options list commands.

-

Instead, enable the user to view pages larger than a screen by panning -them directly, and dragging and dropping items rather than marking them and -using menu options.

-
    -
  • Remember that the most intuitive touch screen interactions that can -be performed using a finger are tapping, stroking up/down/left/right, and -the long tap.

  • -
  • Utilize strokes that are easily discovered to the users in the given -context. It should be explicit to the user where strokes can be performed.

  • -
  • Design to ensure that users can complete a task with the same interaction -method from start to finish - touch or hardware keys, stylus, or finger, and -using one hand or both hands.

  • -
  • Aim to optimize system performance and battery consumption to provide -a fluid and reliable touch user experience.

  • -
-

See Also:

-
\ No newline at end of file + + + + +Designing applications for touch UI + + + + +

Both touch screens and hybrid devices are supported by Symbian +platform. Touch screen enables direct manipulation of content and +objects, allowing for far more natural interaction with the device. +This means a completely different user experience and interaction +style compared to using a hardware keypad.

+ +

All applications must be touch-enabled, which means that they can +be used with the touch screen alone, regardless of the presence of +a keypad. In Symbian platform-based touch devices, the important hardware +keys are Send, End, Multi-tasking and Power key.

+

The application features must follow the platform support for different +hardware. When designing a touch-enabled Symbian application, the +UI must be designed so that everything can be accomplished by using +the touch screen interface, as the potential target devices may or +may not have a hardware keyboard.

+

The touch UI in the Symbian platform is based on the use of resistive +and capacitive touch screens. In resistive touch screen technology, +two conductive and resistive layers are separated by a thin space. +When an object touches this kind of touch panel, the layers are connected +at a certain point, and a touch event is registered. This allows efficient +stylus control, in addition to finger touch - unlike capacitive panels, +which usually register only finger touch. Additionally, resistive +touch screen offers a higher resolution and more durability. In capacitive touch screen technology, the panel consists of an +insulator such as glass, coated with a transparent conductor (such +as indium tin oxide (ITO)). When an object touches the surface of +the screen, it results in a distortion of the local electrostatic +field, measurable as a change in capacitance. Then a touch controller +measures the frequency variations to ascertain the co-ordinates of +the object's touch. Capacitive touch screen supports multiple touch.

+

The hardware is supported by various:

+
    +
  • touch-specific components (see Touch support +for common UI components)

  • +
  • component and UI behavior changes

  • +
  • layout changes, and

  • +
  • additions to the interaction style.

  • +
+

The touch UI is designed to enable full task flow with touch, with +minimal need to switch to hardware keys. Thus, the design ensures +that users can complete a task with the chosen interaction method +from start to finish.

+

While designing and implementing applications for touch screen +devices based on the Symbian platform, consider interactions that +benefit the most from the touch UI.

+

If you can apply direct manipulation of the UI, for example when +moving items from one place to another, or scrolling a page, do not +confine the user with unnecessary scrollbars or have the user resort +to options list commands.

+

Instead, enable the user to view pages larger than a screen by +panning them directly, and dragging and dropping items rather than +marking them and using menu options.

+
    +
  • Remember that the most intuitive touch screen interactions +that can be performed using a finger are tapping, stroking up/down/left/right, +and the long tap.

  • +
  • Utilize strokes that are easily discovered to the users in +the given context. It should be explicit to the user where strokes +can be performed.

  • +
  • Design to ensure that users can complete a task with the same +interaction method from start to finish - touch or hardware keys, +stylus, or finger, and using one hand or both hands.

  • +
  • Aim to optimize system performance and battery consumption +to provide a fluid and reliable touch user experience.

  • +
+

See Also:

+
+
+ diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-2C0C173D-C659-4011-8B7A-8EB35E64D150.dita --- a/Symbian3/PDK/Source/GUID-2C0C173D-C659-4011-8B7A-8EB35E64D150.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-2C0C173D-C659-4011-8B7A-8EB35E64D150.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,37 +1,42 @@ - - - - - -Touch -gestures -

The touch gestures (finger movements on the device display area) are interpreted -using touch gesture framework provided by UI framework. The UI FW listens -to the pointer events and notifies the client after recognizing the gestures. -The client can enable listening of desired gestures.

-

The touch gesture framework supports the following single touch gestures:

    + + + + +Touch gestures + + + + +

    The touch gestures (finger movements on the device display area) +are interpreted using touch gesture framework provided by UI framework. + The UI FW listens to the pointer events and notifies the client after +recognizing the gestures. The client can enable listening of desired +gestures.

    +

    The touch gesture framework supports the following single touch +gestures:

    • Tap

    • Double tap

    • Drag

    • Flick

    • Swipe (up, down, left and right)

    • -
    Gesture Framework can provide swipe speed that can be used as input -to inertia based effects. Two finger pinch (zoom) multi-touch gesture is also -recognized.

    -

    Additionally, there is an option to support drag and drop. It is initiated -by holding the touch position for a short time in the same place. The holding -mode is active until the user releases the touch.

    -
    Using -touch gestures in C++ applications

    The API to use for recognizing -touch gestures is Touch Gesture API.

    Touch Gesture Framework contains -a pointer to a control (derived from CCoeControl) where -gestures are recognized. These gestures are reported to the gesture observer. -Based on the gesture interest set by the gesture observer, CAknTouchGestureFw converts -the pointer events to the logical gesture.

    -
    \ No newline at end of file +
Gesture Framework can provide swipe speed that can be used as +input to inertia based effects. Two finger pinch (zoom) multiple touch gesture is also recognized.

+

Additionally, there is an option to support drag and drop. It +is initiated by holding the touch position for a short time in the +same place. The holding mode is active until the user releases the +touch.

+
Using touch gestures in C++ applications

The API to use +for recognizing touch gestures is Touch Gesture API.

Touch Gesture +Framework contains a pointer to a control (derived from CCoeControl) where gestures are recognized. These gestures are reported +to the gesture observer. Based on the gesture interest set by the +gesture observer, CAknTouchGestureFw converts the pointer events to the logical gesture.

+
+
+ diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-3E7A9A92-F217-4BD1-82CE-227931CFB8ED.dita --- a/Symbian3/PDK/Source/GUID-3E7A9A92-F217-4BD1-82CE-227931CFB8ED.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-3E7A9A92-F217-4BD1-82CE-227931CFB8ED.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,22 +1,25 @@ - - - - - -Multi-Touch -Support in the EmulatorThis section introduces multi-touch support in the emulator which -uses multiple mice to simulate human fingers. The multi-touch environment -in the emulator allows application developers to test their multi-touch related -UI features when hardware devices are not available. -

Variant: ScreenPlay. Target -audience: Application developers.

-
-Advanced -Pointers -
\ No newline at end of file + + + + +Suppo<?Pub Caret?>rt for Multiple Pointers in the Emulator +This section introduces support for multiple pointers in +the emulator which uses multiple mice to simulate human fingers. The +multiple pointer environment in the emulator allows application developers +to test multiple pointer UI features when hardware devices are not +available. + + + + +

Variant: ScreenPlay. Target audience: Application developers.

+
+ +Advanced Pointers + +
+ diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-581A8E4B-12BE-41C0-A20E-3087A80FEECF.dita --- a/Symbian3/PDK/Source/GUID-581A8E4B-12BE-41C0-A20E-3087A80FEECF.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-581A8E4B-12BE-41C0-A20E-3087A80FEECF.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,253 +1,285 @@ - - - - - -Tactile -feedback -

There are two cases where vibration or audio of the device is used as an -output method:

-
    -
  • As a tacticon to inform users through physical feedback, that -an important event is occurring in the device. For example, when a new message -arrives or a warning note is displayed.

  • -
  • As tactile feedback to indicate to the user that an interaction -event has been made. For example, users receive tactile feedback when they -press a button on the touch screen.

  • -
-

As with sounds, tactile feedback must be used carefully so as not to desensitize -the user to the vibration; the attention grabbing quality remains and functions -so long as the feedback is not too frequent.

-

Tactile feedback is enabled for all the Symbian platform UI components. -Tactile feedback can be disabled for the common UI components in an application. -However, this is acceptable only if tactile feedback causes interference with -other device functions.

-

The user can choose the level of tactile feedback and turn tacticons ON -and OFF.

-

The following table lists the tactile feedback effects:

-

Tactile feedback -effects - - - -

Effects

-

Description

-
- - - -

Sensitive button

-

Provides single pulse effect on repeated key presses with buttons. -It is also possible with other similar components.

-
- -

Basic button

-

Provides stronger single pulse effect to buttons. It is also possible -with other similar components.

-
- -

Sensitive list

-

Provides single pulse effect to lists and grids. Effect is used -with move (drag and flick) when new item appears on the screen.

-
- -

Basic list

-

Provides stronger single pulse effect to lists and grids. Effect -is used with touch down and release when tap makes an action.

In hierarchical -list, collapsing/expanding item provides basic list effect with touch down -and release.

-
- -

Bounce effect

-

Provides pulse effect when list returns to its normal state after -boundary effect.

-
- -

Sensitive slider

-

Provides pulse effect with scrollbar and slider thumbs. Effect is -provided with touch down and release in thumb area.

-
- -

Smooth slider

-

Provides continuous smooth feedback when dragging scrollbar or slider -thumb. This can also be increasing or decreasing depending of the slider type.

-
- -

Hold slider

-

Provides sensitive pulse effect when touch down and hold on the -slider or scrollbar area. Slider thumb starts moving step by step towards -the touch point. Every step gives one sensitive pulse. If slider thumb moves -directly to the touch point, then basic slider effect is provided.

-
- -

Pop-up

-

Provides sensitive pulse effect when pop-up is opened or closed. -If the theme animations are ON, then pop-up effect is used with opening event -after increasing long touch effect. In this scenario, there is no pop-up effect -. All pop-ups do not have theme animation.

-
- -

Pop-up close

-

Provides decreasing smooth feedback a pop-up and when theme animations -are ON.

-
- -

Increasing long touch

-

Provides increasing smooth feedback. This can be used with either -long tap animation or pop-up opening theme effects. If the theme effects are -ON and long tap opens a pop-up, then feedback is provided only with long tap. -This is followed by pop-up.

-
- -

Basic tab

-

Provides strong pulse effect with touch down event in tab area.

-
- -

Smooth flick

-

Provides smooth feedback with drag when horizontal movement is possible.

-
- -

Sensitive flick

-

Provides sensitive pulse effect with touch release when horizontal -movement is possible.

-
- -

Sensitive edit

-

Provides sensitive pulse effect in editors with touch down and release.

-
- -

Text edit

-

Provides pulse effect when painting the text. Effect is provided -with every character while painting the text.

-
- -

Blank edit

-

Provides pulse effect when painting blank character. By default, -it is none.

-
- -

Line edit

-

Provides pulse effect when painting a line.

-
- -

Empty line

-

Provides pulse effect when painting an empty line. By default, it -is none.

-
- -

Check box

-

Provides pulse effect when marking/unmarking a check box.

-
- -

Multi-touch recognition

-

Provides double pulse (sensitive + sensitive) effect when multi-touch -is recognized (generally, when second finger is touched down).

-
- -

Smooth pinch

-

Provides smooth continuous feedback while moving fingers in multi-touch -pinch situation.

-
- -

Smooth rotate

-

Provides smooth continuous feedback while moving fingers in multi-touch -rotate situation.

-
- - -

-
Haptics concept

The different senses associated -to the skin are called cutaneous senses. These senses are temperature, pressure -(touch itself), pain, tickle, itch and vibration senses. We can characterize -touch as passive or active. Passive touch means the sense of touch itself, -whereas active touch means the touch action.

To communicate through -the sense of touch, we have to stimulate some of the cutaneous senses or the -movement sense. The stimulation of the cutaneous senses or one of them by -a product is called tactile stimulation. Respectively, the stimulation of -the movement sense by a product is called haptic stimulation or just haptics. -Haptics is also used as general term for all issues related to sense of touch, -both human and machine.

Haptic feedback, often referred to as "Haptics", -is the use of the sense of touch in a user interface design to provide information -to an end user. In mobile phones, this generally means the use of vibrations -from the device's vibration alarm to denote that a touch screen button has -been pressed. In this particular example, the phone would vibrate slightly -in response to the user's activation of an on-screen control, making up for -the lack of a normal tactile response that the user would experience when -pressing a physical button.

-
Characteristics -of haptics related APIs

You can use the following APIs to create -haptic effects:

    -
  • Tactile Feedback -Client API

      -
    • Available from S60 5th Edition onwards.

    • -
    • It can be used on all S60 5th Edition or later mobile devices. However, -the feedback is played only on touch enabled layouts.

    • -
    • Provides simple functions for triggering various predefined tactile -feedback (vibration or audio) effects.

    • -
    • Enables a consistent user experience in all applications of the mobile -device (an application gives a logical feedback type as an input and the actual -physical effect depends on the mobile device configuration and end user settings).

    • -
    • When the area feedback is used, latency is low for the feedback triggering -(a tactile feedback can already be triggered at the window server level prior -to the corresponding pointer event being delivered to the visible application).

    • -
    • Direct feedback can be easily integrated into CCoeControl::HandlePointerEventL().

    • -
    • An application can select the logical tactile feedback from certain -types. The produced effect may be different on various mobile devices.

    • -
  • -
  • Haptics -API

      -
    • Available from S60 5th Edition, FP2 onwards.

    • -
    • It can be used in touch and hybrid mobile devices.

    • -
    • Provides an interface for accessing Haptics player that can control -different actuator types.

    • -
    • Enables producing of complex vibrator effects, such as an explosion -or machine gun effect in a game, bass boost for a music player, advanced ringing -tone vibration, and so on.

    • -
    • Enables simultaneous playing of different kinds of basis effects and -modifying them when played.

    • -
    • Allows the design of complex effects (using a separate PC application) -that can be loaded on Haptics player for playing.

    • -
    • It may require a special license key for third-party applications -(to be set at runtime) to enable the Haptics player functionality.

    • -
  • -
  • Vibra API

      -
    • Available from S60 3.0 onwards.

    • -
    • It can be used for running device vibrator with given intensity for -a given period of time.

    • -
    • It can be used by a privileged client application to play pulse effects, -which have a very short duration (as the ones used for tactile feedback).

    • -
  • -
-
When to use -Tactile Feedback Client API, Haptics API, and Vibra API

    -
  • Tactile Feedback Client API for providing tactile feedback in custom -controls (grids, lists, and so on), which will comply with the style of Core -UI components to ensure a uniform user experience among applications.

  • -
  • Haptics API on touch and hybrid mobile devices for producing complex -vibration feedback, which cannot be achieved with Tactile Framework (games, -simulations, demos, and so on).

  • -
  • Vibra API for producing haptic effects such as ringing tone vibration -in those mobile devices where Haptics API is not available or functional.

  • -

-
Using -tactile feedback in applications

The API to use for tactile feedback -is the Tactile feedback -client API.

The Symbian platform includes a tactile feedback -interface to add, modify and remove feedback areas in the registry. There -is also an option to trigger direct feedback and bypass the registry. MTouchFeedback::Instance() is -used for acquiring a pointer to a touch feedback instance. When touch feedback -is activated, the mobile device users get a slight vibration when the control -with the feedback interface is touched.

Tactile feedback can -be set and disabled in a client application or a mobile device in some scenarios, -for example, during phone calls.

Client applications cannot determine -the actual physical feedback that is generated. It depends on device configuration -and current settings. In current devices, the user changeable settings include -vibration and audio feedback intensity level.

For more information, -see Feedback.

-
\ No newline at end of file + + + + +Tactile feedback + + + + +

There are two cases where vibration or audio of the device is used +as an output method:

+
    +
  • As a tacticon to inform users through physical feedback, +that an important event is occurring in the device. For example, when +a new message arrives or a warning note is displayed.

  • +
  • As tactile feedback to indicate to the user that an +interaction event has been made. For example, users receive tactile +feedback when they press a button on the touch screen.

  • +
+

As with sounds, tactile feedback must be used carefully so as not +to desensitize the user to the vibration; the attention grabbing quality +remains and functions so long as the feedback is not too frequent.

+

Tactile feedback is enabled for all the Symbian platform UI components. +Tactile feedback can be disabled for the common UI components in an +application. However, this is acceptable only if tactile feedback +causes interference with other device functions.

+

The user can choose the level of tactile feedback and turn tacticons +ON and OFF.

+

The following table lists the tactile feedback effects:

+

+Tactile feedback effects + + + +

Effects

+

Description

+
+ + + +

Sensitive button

+

Provides single pulse effect on repeated key presses with +buttons. It is also possible with other similar components.

+
+ +

Basic button

+

Provides stronger single pulse effect to buttons. It is +also possible with other similar components.

+
+ +

Sensitive list

+

Provides single pulse effect to lists and grids. Effect +is used with move (drag and flick) when new item appears on the screen.

+
+ +

Basic list

+

Provides stronger single pulse effect to lists and grids. +Effect is used with touch down and release when tap makes an action.

In hierarchical list, collapsing/expanding item provides basic +list effect with touch down and release.

+
+ +

Bounce effect

+

Provides pulse effect when list returns to its normal state +after boundary effect.

+
+ +

Sensitive slider

+

Provides pulse effect with scrollbar and slider thumbs. +Effect is provided with touch down and release in thumb area.

+
+ +

Smooth slider

+

Provides continuous smooth feedback when dragging scrollbar +or slider thumb. This can also be increasing or decreasing depending +of the slider type.

+
+ +

Hold slider

+

Provides sensitive pulse effect when touch down and hold +on the slider or scrollbar area. Slider thumb starts moving step by +step towards the touch point. Every step gives one sensitive pulse. +If slider thumb moves directly to the touch point, then basic slider +effect is provided.

+
+ +

Pop-up

+

Provides sensitive pulse effect when pop-up is opened or +closed. If the theme animations are ON, then pop-up effect is used +with opening event after increasing long touch effect. In this scenario, +there is no pop-up effect . All pop-ups do not have theme animation.

+
+ +

Pop-up close

+

Provides decreasing smooth feedback a pop-up and when theme +animations are ON.

+
+ +

Increasing long touch

+

Provides increasing smooth feedback. This can be used with +either long tap animation or pop-up opening theme effects. If the +theme effects are ON and long tap opens a pop-up, then feedback is +provided only with long tap. This is followed by pop-up.

+
+ +

Basic tab

+

Provides strong pulse effect with touch down event in tab +area.

+
+ +

Smooth flick

+

Provides smooth feedback with drag when horizontal movement +is possible.

+
+ +

Sensitive flick

+

Provides sensitive pulse effect with touch release when +horizontal movement is possible.

+
+ +

Sensitive edit

+

Provides sensitive pulse effect in editors with touch down +and release.

+
+ +

Text edit

+

Provides pulse effect when painting the text. Effect is +provided with every character while painting the text.

+
+ +

Blank edit

+

Provides pulse effect when painting blank character. By +default, it is none.

+
+ +

Line edit

+

Provides pulse effect when painting a line.

+
+ +

Empty line

+

Provides pulse effect when painting an empty line. By default, +it is none.

+
+ +

Check box

+

Provides pulse effect when marking/unmarking a check box.

+
+ +

Multiple touch recognition

+

Provides double pulse (sensitive + sensitive) effect when +multiple touch is recognized (generally, when second finger is touched +down).

+
+ +

Smooth pinch

+

Provides smooth continuous feedback while moving fingers +in multiple touch pinch situation.

+
+ +

Smooth rotate

+

Provides smooth continuous feedback while moving fingers +in multiple touch rotate situation.

+
+ + +

+
Haptics +concept

The different senses associated to the skin are +called cutaneous senses. These senses are temperature, pressure (touch +itself), pain, tickle, itch and vibration senses. We can characterize +touch as passive or active. Passive touch means the sense of touch +itself, whereas active touch means the touch action.

To communicate +through the sense of touch, we have to stimulate some of the cutaneous +senses or the movement sense. The stimulation of the cutaneous senses +or one of them by a product is called tactile stimulation. Respectively, +the stimulation of the movement sense by a product is called haptic +stimulation or just haptics. Haptics is also used as general term +for all issues related to sense of touch, both human and machine.

Haptic feedback, often referred to as "Haptics", is the use of +the sense of touch in a user interface design to provide information +to an end user. In mobile phones, this generally means the use of +vibrations from the device's vibration alarm to denote that a touch +screen button has been pressed. In this particular example, the phone +would vibrate slightly in response to the user's activation of an +on-screen control, making up for the lack of a normal tactile response +that the user would experience when pressing a physical button.

+
Characteristics +of haptics related APIs

You can use the following APIs +to create haptic effects:

    +
  • Tactile Feedback Client API

      +
    • Available from S60 5th Edition onwards.

    • +
    • It can be used on all S60 5th Edition or later mobile devices. +However, the feedback is played only on touch enabled layouts.

    • +
    • Provides simple functions for triggering various predefined +tactile feedback (vibration or audio) effects.

    • +
    • Enables a consistent user experience in all applications of +the mobile device (an application gives a logical feedback type as +an input and the actual physical effect depends on the mobile device +configuration and end user settings).

    • +
    • When the area feedback is used, latency is low for the feedback +triggering (a tactile feedback can already be triggered at the window +server level prior to the corresponding pointer event being delivered +to the visible application).

    • +
    • Direct feedback can be easily integrated into CCoeControl::HandlePointerEventL().

    • +
    • An application can select the logical tactile feedback from +certain types. The produced effect may be different on various mobile +devices.

    • +
  • +
  • Haptics API

      +
    • Available from S60 5th Edition, FP2 onwards.

    • +
    • It can be used in touch and hybrid mobile devices.

    • +
    • Provides an interface for accessing Haptics player that can +control different actuator types.

    • +
    • Enables producing of complex vibrator effects, such as an explosion +or machine gun effect in a game, bass boost for a music player, advanced +ringing tone vibration, and so on.

    • +
    • Enables simultaneous playing of different kinds of basis effects +and modifying them when played.

    • +
    • Allows the design of complex effects (using a separate PC application) +that can be loaded on Haptics player for playing.

    • +
    • It may require a special license key for third-party applications +(to be set at runtime) to enable the Haptics player functionality.

    • +
  • +
  • Vibra API

      +
    • Available from S60 3.0 onwards.

    • +
    • It can be used for running device vibrator with given intensity +for a given period of time.

    • +
    • It can be used by a privileged client application to play pulse +effects, which have a very short duration (as the ones used for tactile +feedback).

    • +
  • +
+
When +to use Tactile Feedback Client API, Haptics API, and Vibra API

    +
  • Tactile Feedback Client API for providing tactile feedback +in custom controls (grids, lists, and so on), which will comply with +the style of Core UI components to ensure a uniform user experience +among applications.

  • +
  • Haptics API on touch and hybrid mobile devices for producing +complex vibration feedback, which cannot be achieved with Tactile +Framework (games, simulations, demos, and so on).

  • +
  • Vibra API for producing haptic effects such as ringing tone +vibration in those mobile devices where Haptics API is not available +or functional.

  • +

+
Using +tactile feedback in applications

The API to use for tactile +feedback is the Tactile feedback +client API.

The Symbian platform includes a tactile feedback +interface to add, modify and remove feedback areas in the registry. +There is also an option to trigger direct feedback and bypass the +registry. MTouchFeedback::Instance() is used for +acquiring a pointer to a touch feedback instance. When touch feedback +is activated, the mobile device users get a slight vibration when +the control with the feedback interface is touched.

Tactile +feedback can be set and disabled in a client application or a mobile +device in some scenarios, for example, during phone calls.

Client applications cannot determine the actual physical feedback +that is generated. It depends on device configuration and current +settings. In current devices, the user changeable settings include +vibration and audio feedback intensity level.

For more information, +see Feedback.

+
+
+ diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-6F1ED7D0-5F41-4587-89AA-8DDE7AEC916F.dita --- a/Symbian3/PDK/Source/GUID-6F1ED7D0-5F41-4587-89AA-8DDE7AEC916F.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-6F1ED7D0-5F41-4587-89AA-8DDE7AEC916F.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,385 +1,430 @@ - - - - - -What's new in Symbian^3Symbian^3 introduces a lot of new features that enhance -communication, connectivity, multimedia, graphics, security and the -overall usability of Symbian devices. These features benefit operators, -application developers and device creators by making it easier to -create feature-rich devices and applications. -

If you are moving from a older version of Symbian platform to Symbian^3, -see Porting -applications to Symbian^3.

- - - - -Technology Domain -New Features - - - - -Data Communications -
    -
  • FreeWay or Three Plane Comms Architecture: The Symbian -platform now supports a new IP networking architecture. The new architecture -significantly improves data flow performance and makes it easier for -third-party developers to integrate new technologies, for example -firewalls and hotspot authenticators. It also implements automatic -roaming between different access points, for example WLAN and GPRS. -For more information, see Goals of the Comms -Architecture.

  • -
  • One-Click Connectivity (OCC): The Symbian platform now -provides a new way of managing data connections on the Symbian platform. -OCC builds on the existing Application Level Roaming (ALR) solution. -This feature makes the user's interaction with "connecting" and "select -access point" dialogs significantly simple and easier. For more information, -see Extended -Connection Preferences.

  • -
-
- -Device Connectivity -
    - - - -
  • MTP Device Services Extension Specification: The Symbian -MTP implementation now supports the MTP device services extension -to the Media Transfer Protocol (MTP). For more information, -see MTP Device Services Extension Specification.

  • -
  • AVRCP (Audio/Video Remote Control Profile) v1.4 Support: A Symbian device user can now see music track names and browse playlists -directly from the screen of a AVRCP v1.4 enabled Bluetooth headset -or remote control.

  • -
  • Centralized AT-command Handling: The Symbian platform -now enables all AT commands to be handled using the same mechanism -regardless of the connection type. For more information, refer to -the AT Extension Plug-in API.

  • -
-
- -Device Management -
    -
  • Support for Open Mobile Alliance (OMA) Management Objects -(MO): The Symbian platform now supports OMA MO like Software Component -Management Object (SCOMO) v1.0, Device Capability Management Object -(DCMO) v1.0 and Connectivity Management Object (ConnMO). It also supports -Nokia Standard Streaming MO. Some enhancements have been made to Browser -MO and Email MO.

  • -
  • Other Device Management Enhancements: The Symbian platform -now provides an improved device Lock with security and an enhanced -firmware update installation experience.

  • -
-
- -Location -
    -
  • Landmark-based URL Parser: The Symbian platform now -supports a parser that converts between landmark objects and URLs. -The parser supports a URL format that is compliant with Ovi Maps. -For more information, see CPosLandmarkParser.

  • -
  • New Management Object (MO) for A-GPS: The Symbian platform -now provides an enhancement to Secure User Plane Location (SUPL) now -allows the service provider to provide two access points for a SUPL -server in the MO. This improves the system stability because it acts -as a fallback mechanism in case one of the access points is unavailable.

  • -
  • Support for Application Processor Engine (APE) Centric Location -Architecture: Symbian devices can now use the new architecture -based on the APE that offers standardized session IDs on network privacy -and classes that use the SUPL. The architecture converges technology -from OS, middleware and application software layers.

  • -
  • Support for Location Based Services (LBS) SUPL Positioning -Module (PSY): The Symbian platform now enables the LBS SUPL PSY -to allow GPS-enabled devices to handle network-based SUPL location -requests. This includes Cell ID based positioning and assistance data -exchange as part of SUPL v2.0. For more information, see SUPL Protocol Module.

  • -
  • Support for GPSCost5.0D and GPSCost4.0D GPS chipsets: The Symbian platform now uses the APE-centric architecture to support -GPSCost5.0D and GPSCost4.0D chipsets. A new A-GPS Nokia Positioning -Engine (NPE) integration module replaces the OS LBS subsystem reference -A-GPS version.

  • -
  • Support for LBS SUPL Radio Resource LCS Protocol (RRLP): The Symbian platform now uses the APE-centric architecture to support -NPE and RRLP on GPS-enabled device.

  • -
  • SUPL 2.0 Trigger Support: The Symbian platform now provides -SUPL 2.0 trigger support that allows the requester to receive location -updates periodically, which is both network and device initiated.

  • -
  • Location-based Triggering Enhancements: The Symbian -platform now includes key enhancements that enable integration with -an Context framework to develop plug-ins and increase support for -total and active triggers. An enhanced, dedicated common gateway interface -enables the client to provide multiple CGIs to create a trigger, which -is fired on successful matching with at least one CGI.

  • -
  • Enhanced Location Acquisition API to support LocationKnownPositionArea.

  • -
  • Here and Now: The Symbian platform now includes Here -and now that offers easy-to-use Web services related to the user's -current location. Here and now allows the user to check the local -weather and get other topical information while on the move.

  • -
-
- -Multimedia -
    -
  • Mobile TV DVB-H Receiver HAI: Mobile TV Receiver is -a small internal system but does so much more than traditional TV. -It is broadcasted in a multi-grounded environment with high speed -by using low battery power and low memory usage. For more information, see Mobile TV DVBH Receiver -HAI Component.

  • -
  • OpenMAX IL: OpenMAX IL is a low-level interface used -in mobile devices that allows the Multimedia Device Framework (MDF) -to load, control, connect and unload audio, video and imaging components. For more information, see OpenMAX IL Collection.

  • -
  • Thin Adaptation of A3F DevSound: The A3F DevSound is -one of the key component in the Sound Device collection that provides -access to the hardware accelerator in audio technology. For more information, -see A3F DevSound -Component.

  • -
  • Image Processor library: The Image Processor is an independent -and high-level API and framework which is developed for mobile imaging. -The Image Processor has some pluggable advanced image editing libraries -to perform the Panoramic Stitching function and the Speed View function. -For more information, see Image Processor Library.

  • -
  • Camera API Extensions: The Camera API is extended to -support the features such as background processing, continuous digital -zooming, time nudge image capturing and automatic aperture setting. -For more information, see Camera Library.

  • -
  • Camera Support for Video Encoding: The Camera supports -mobile device to capture video frames which are encoded in the H264 -format. For more information, see Using the Encoded -H264 Video Frames to Capture Video.

  • -
  • 3GP File Format Library: The 3GP Library component is -a Multimedia plug-in which supports for reading and writing 3GP, 3G2, -and MP4 files. The 3GP Library is also extended to support larger -3GP or MP4 files. For more -information, see 3GP Library Component.

  • -
  • Video Playback from Non-user Interface Thread: Media -Client Video Display is a standalone library used by the Video Client -library to support video playback. For more information, see Media Client Video -Display Library.

  • -
  • Video Subtitle CRP: Displays artwork on a video window -using the Video Subtitle CRP component. The Subtitle Graphic library -displays subtitles artwork on the screen through its interaction with -Client Process, Controller Process and WServ Process. For more information, -see Video Subtitle -CRP Component.

  • -
  • Dolby Digital Audio Support: The Symbian platform now -supports codecs that enable support for Dolby Digital Audio on Symbian -devices. For more information, -see Supported -Audio Codecs.

  • -
  • True Pause in Audio Playback: In the audio playback -request the true pause feature is implemented to stop the audio data -at the physical sound device without stopping the buffer traffic. -For more information, see Pausing and Resuming -Audio Play.

  • -
  • Global Surface Updates: The Video Render component is -extended to support the global surface updates. For more information, -see Global -Surface Updates.

  • -
  • Metadata Utility Library: The Metadata Utility library -belongs to the Metadata Utility Framework (MUF) component that provides -fast metadata access to audio, video and image media files. For more -information, see the Metadata Utility -Library section.

  • -
  • UI Patterns or Thumbnails Enhancement: This is a Multimedia -specific pattern enhancement, which includes many UI (User Interface) -features, listed below:

      -
    • Multiple customized Home Screens with 6 different widget enabled -screens.

    • -
    • Pinch zoom, kinetic scrolling and single-click features.

    • -
    • Good screen view with a new UI theme, and renewed icons.

    • -
    • Hardware acceleration with fast and responsive UI that creates -new transition effects.

    • -
    • Multitasking with Teleport visual task swapper.

    • -
    • Intelligent slide functionality for Hybrid touch and QWERTY -slider devices. Video Graphics Array (VGA) Touch supports for VGA -QWERTY mono blocks.

    • -
    • VGA Touch helps to control Music player.

    • -
  • -
  • Mobile TV: Mobile TV uses DVB-H receiver to consume -broadcast digital mobile television. The Symbian platform provides -fast and easy access to all videos and TV media content. One key press -opens videos and TV application suite, and user scrolls and selects -the desired video functionality. This media experience is built with -major components such as Videos and TV, video player and Mobile TV. -Videos and TV support high quality video up to 720 per resolution -at 12 Mbps and 30 frames per second.

  • -
  • Image Viewer Application: The Image Viewer application -is used when the client opens an image file for viewing. File Manager, -Messaging, Camcorder and Browser S60 components use the Image Viewer -application. It supports Extended ICL JPEG API, which enables a faster -and less memory-consuming way to rotate and zoom images.

  • -
  • FM Radio: The FM Radio application is used to listen -FM radio broadcast over the air. FM radio broadcast is a free service.

  • -
  • Video Sharing: Using the video sharing service, both -call users can start sharing their device live camera view or pre-recorded -video clip during a normal circuit switched (CS) voice call. The video -sharing feature allows the user to upgrade and downgrade their call -with one-way video at times of need. The video sharing application -uses the Multimedia Comms Engine API.

  • -
-
- -Multimedia Applications -
    -
  • High-Definition Multimedia Interface (HDMI): The Symbian -platform now supports HDMI technology. HDMI is supported as an external -accessory for audio and video playback for a great television playback -experience. It provides improved data performance and is ideal for -streaming high definition audio and video. The 720p resolution is -supported in still image and video viewing. 5+1 channel audio is also -supported.

  • -
  • Home Music Widgets: The Symbian platform now provides -music information through Home Screen Music Widgets. The Home Music -Widgets controls from the Home Screen menu system enables to play -and pause the playing track. The Music Widget supports the Radio Player -and includes the Music Suite Matrix Menu. This menu is configured -through XML and by default supports to launch the functionality listed -below:

      -
    • The last played song

    • -
    • The music collection view

    • -
    • A music shop, or to open the FM radio

    • -
  • -
  • Fusion Player Application: The Symbian platform now -introduces the Fusion Player, which replaces the existing Media Player -and Video Center applications. It enables access to both online video -services and locally stored videos. If DVB-H device is available, -live TV viewing is also possible. The main features supported by the -Fusion player application are as follows:

      -
    • To browse stored videos and to see metadata features of the -video, such as title, thumbnail DRM info, size or play-time.

    • -
    • To check videos that are pre-installed with the device.

    • -
    • To play stored video file in the device.

    • -
  • -
-
- -OS Base Services -
    -
  • Writable Data Paging (WDP): The Symbian platform now -supports WDP. This enables efficient use of memory and allows multiple -applications to run at the same time without physically adding more -RAM to the hardware. This leads to a more responsive system when switching -between a number of running applications. For more information, see Writable Data Paging.

  • -
  • Symmetric multiprocessor (SMP): The Symbian platform -now supports SMP for multi-core processors, such as the ARM Cortex -A9. This allows device integrators to prototype and prove ARM-based -SMP platforms. For more information, -see SMP.

  • -
  • 64-bit file server: The Symbian platform now supports -files larger than 2 GB. For -more information, see Large File Access.

  • -
-
- -Productivity -
    -
  • Nokia Messaging for Social Networks: Nokia Messaging -Social Networking service is a Nokia-hosted consumer service that -provides easy and affordable mobile access to popular social networking -communities.

  • -
  • Enhanced Calendar UI Architecture: Calendar UI architecture -has changed to improve flexibility of calendar for regional, religious, -custom-tailors and xSP calendar service needs. Multiple storages are -also supported. For more information, see Calendar Guide.

  • -
  • CalDAV Protocol: Calendar application now supports the -CalDAV Protocol, which is an open calendar synchronization standard -contributed by SUN Microsystems. This enables a user to access scheduling -information on remote servers.

  • -
  • Enhanced Contacts Application: The Contacts application -in this release includes the following changes:

      -
    • Integration with social media.

    • -
    • Support for Remote Contacts Lookup, for example, from post-installed -Mail for Exchange account.

    • -
    • Virtual Phonebook API (supports getting access to the user’s -own contact card).

    • -
    • Own contact card.

    • -
  • -
-
- -Runtimes -
    -
  • The Symbian platform now supports the Open Source based Java -MIDP 2.1.

  • -
  • The Symbian platform now supports Browser Application v7.2 -(with Web Run Time 7.2) that includes the following features:

      -
    • Browser Control

    • -
    • Browser core features

    • -
    • Browser Customization

    • -
    • Browser plug-ins

    • -
    • Browser with touch screen

    • -
    • Content Download

    • -
    • URI Schemes

    • -
    • Display Resolution Optimizations

    • -
    • Optical Finger Navigation (OFN)

    • -
    • FlashLite 3.1

    • -
    • Search Client Integration

    • -
    • Expanding Language and Character Set Support

    • -
    • Improved Security Prompting

    • -
    • Updated Platform Service APIs

    • -
    • Visual Task Swapper Support

    • -
    • Performance Optimizations

    • -
    • Multi-touch/pinch zooming

    • -
  • -
-
- -Security -The Symbian platform now provides an enhanced Security subsystem -that enables device creators to integrate hardware acceleration modules, -which improves the performance of cryptographic algorithms. This is -particularly valuable in intensive real-time use-cases, such as streaming -audio or video over a secure link, where bulk data needs to be encrypted -and decrypted. - - -User Interface -
    -
  • ScreenPlay, also known as the New Graphics Architecture -(NGA): This new graphics architecture enables device creators -to take advantage of improved software performance, hardware acceleration -and third party graphics engines. It makes it possible to combine -UI components, graphics and video to create highly innovative UIs. -For more information, see The ScreenPlay Graphics -Architecture.

  • -
  • Extended Bitmaps: The Font and Bitmap Server provides a framework for device creators -to add support for their own types of bitmap compression. Bitmaps -that use compression formats that are provided by device creators -are known as extended bitmaps. For more information, see Extended Bitmaps.

  • -
  • Dynamic Direct Screen -Access (DSA) Allocation: The Symbian platform now supports the -dynamic allocation of the DSA buffer. For more information, see Implementing Dynamic -DSA Allocation.

  • -
  • Multi-Touch Support: The ScreenPlay version of the Window -Server has been extended to support multiple advanced pointers, with -support for proximity and pressure. The emulator now also supports -multiple advanced pointers. For more information, see Advanced Pointers.

  • - -
  • Enhanced Touch UI: The touch UI includes the following -improvements:

      -
    • Multi-page Home Screen enables the user to navigate between -widgets with a simple flick gesture

    • -
    • Capacitive multi-touch events are supported.

    • -
    • Tactile Feedback utilizes advanced haptics effects.

    • -
  • -

For more information about the new features in Graphics, see What's New in Graphics -in Symbian^3.

-
- - -
- -New -C++ APIs in Symbian^3 -Porting -applications to Symbian^3 -Introduction -to Symbian^3 - -
\ No newline at end of file + + + + +What's new in Symbian^3 +Symbian^3 introduces a lot of new features that enhance +communication, connectivity, multimedia, graphics, security and the +overall usability of Symbian devices. These features benefit operators, +application developers and device creators by making it easier to +create feature-rich devices and applications. + + + + +

If you are moving from a older version of Symbian platform to Symbian^3, +see Porting +applications to Symbian^3.

+ + + + +Technology Domain +New Features + + + + +Data Communications +
    +
  • FreeWay or Three Plane Comms Architecture: The Symbian +platform now supports a new IP networking architecture. The new architecture +significantly improves data flow performance and makes it easier for +third-party developers to integrate new technologies, for example +firewalls and hotspot authenticators. It also implements automatic +roaming between different access points, for example WLAN and GPRS. +For more information, see Goals of the +Comms Architecture.

  • +
  • One-Click Connectivity (OCC): The Symbian platform now +provides a new way of managing data connections on the Symbian platform. +OCC builds on the existing Application Level Roaming (ALR) solution. +This feature makes the user's interaction with "connecting" and "select +access point" dialogs significantly simple and easier. For more information, +see Extended +Connection Preferences.

  • +
+
+ +Device Connectivity +
    +
  • MTP Device Services Extension Specification: The Symbian +MTP implementation now supports the MTP device services extension +to the Media Transfer Protocol (MTP). For more information, see MTP Device Services Extension Specification.

  • +
  • AVRCP (Audio/Video Remote Control Profile) v1.4 Support: A Symbian device user can now see music track names and browse playlists +directly from the screen of a AVRCP v1.4 enabled Bluetooth headset +or remote control.

  • +
  • Centralized AT-command Handling: The Symbian platform +now enables all AT commands to be handled using the same mechanism +regardless of the connection type. For more information, refer to +the AT Extension Plug-in API.

  • +
+
+ +Device Management +
    +
  • Support for Open Mobile Alliance (OMA) Management Objects +(MO): The Symbian platform now supports OMA MO like Software Component +Management Object (SCOMO) v1.0, Device Capability Management Object +(DCMO) v1.0 and Connectivity Management Object (ConnMO). It also supports +Nokia Standard Streaming MO. Some enhancements have been made to Browser +MO and Email MO.

  • +
  • Other Device Management Enhancements: The Symbian platform +now provides an improved device Lock with security and an enhanced +firmware update installation experience.

  • +
+
+ +Location +
    +
  • Landmark-based URL Parser: The Symbian platform now +supports a parser that converts between landmark objects and URLs. +The parser supports a URL format that is compliant with Ovi Maps. +For more information, see CPosLandmarkParser.

  • +
  • New Management Object (MO) for A-GPS: The Symbian platform +now provides an enhancement to Secure User Plane Location (SUPL) now +allows the service provider to provide two access points for a SUPL +server in the MO. This improves the system stability because it acts +as a fallback mechanism in case one of the access points is unavailable.

  • +
  • Support for Application Processor Engine (APE) Centric Location +Architecture: Symbian devices can now use the new architecture +based on the APE that offers standardized session IDs on network privacy +and classes that use the SUPL. The architecture converges technology +from OS, middleware and application software layers.

  • +
  • Support for Location Based Services (LBS) SUPL Positioning +Module (PSY): The Symbian platform now enables the LBS SUPL PSY +to allow GPS-enabled devices to handle network-based SUPL location +requests. This includes Cell ID based positioning and assistance data +exchange as part of SUPL v2.0. For more information, see SUPL Protocol +Module.

  • +
  • Support for GPSCost5.0D and GPSCost4.0D GPS chipsets: The Symbian platform now uses the APE-centric architecture to support +GPSCost5.0D and GPSCost4.0D chipsets. A new A-GPS Nokia Positioning +Engine (NPE) integration module replaces the OS LBS subsystem reference +A-GPS version.

  • +
  • Support for LBS SUPL Radio Resource LCS Protocol (RRLP): The Symbian platform now uses the APE-centric architecture to support +NPE and RRLP on GPS-enabled device.

  • +
  • SUPL 2.0 Trigger Support: The Symbian platform now provides +SUPL 2.0 trigger support that allows the requester to receive location +updates periodically, which is both network and device initiated.

  • +
  • Location-based Triggering Enhancements: The Symbian +platform now includes key enhancements that enable integration with +an Context framework to develop plug-ins and increase support for +total and active triggers. An enhanced, dedicated common gateway interface +enables the client to provide multiple CGIs to create a trigger, which +is fired on successful matching with at least one CGI.

  • +
  • Enhanced Location Acquisition API to support LocationKnownPositionArea.

  • +
  • Here and Now: The Symbian platform now includes Here +and now that offers easy-to-use Web services related to the user's +current location. Here and now allows the user to check the local +weather and get other topical information while on the move.

  • +
+
+ +Multimedia +
    +
  • Mobile TV DVB-H Receiver HAI: Mobile TV Receiver is +a small internal system but does so much more than traditional TV. +It is broadcasted in a multi-grounded environment with high speed +by using low battery power and low memory usage. For more information, +see Mobile +TV DVBH Receiver HAI Component.

  • +
  • OpenMAX IL: OpenMAX IL is a low-level interface used +in mobile devices that allows the Multimedia Device Framework (MDF) +to load, control, connect and unload audio, video and imaging components. For more information, see OpenMAX IL Collection.

  • +
  • Thin Adaptation of A3F DevSound: The A3F DevSound is +one of the key component in the Sound Device collection that provides +access to the hardware accelerator in audio technology. For more information, +see A3F +DevSound Component.

  • +
  • Image Processor library: The Image Processor is an independent +and high-level API and framework which is developed for mobile imaging. +The Image Processor has some pluggable advanced image editing libraries +to perform the Panoramic Stitching function and the Speed View function. +For more information, see Image Processor +Library.

  • +
  • Camera API Extensions: The Camera API is extended to +support the features such as background processing, continuous digital +zooming, time nudge image capturing and automatic aperture setting. +For more information, see Camera Library.

  • +
  • Camera Support for Video Encoding: The Camera supports +mobile device to capture video frames which are encoded in the H264 +format. For more information, see Using the Encoded +H264 Video Frames to Capture Video.

  • +
  • 3GP File Format Library: The 3GP Library component is +a Multimedia plug-in which supports for reading and writing 3GP, 3G2, +and MP4 files. The 3GP Library is also extended to support larger +3GP or MP4 files. For more information, see 3GP Library +Component.

  • +
  • Video Playback from Non-user Interface Thread: Media +Client Video Display is a standalone library used by the Video Client +library to support video playback. For more information, see Media Client +Video Display Library.

  • +
  • Video Subtitle CRP: Displays artwork on a video window +using the Video Subtitle CRP component. The Subtitle Graphic library +displays subtitles artwork on the screen through its interaction with +Client Process, Controller Process and WServ Process. For more information, +see Video +Subtitle CRP Component.

  • +
  • Dolby Digital Audio Support: The Symbian platform now +supports codecs that enable support for Dolby Digital Audio on Symbian +devices. For more information, see Supported Audio +Codecs.

  • +
  • True Pause in Audio Playback: In the audio playback +request the true pause feature is implemented to stop the audio data +at the physical sound device without stopping the buffer traffic. +For more information, see Pausing and +Resuming Audio Play.

  • +
  • Global Surface Updates: The Video Render component is +extended to support the global surface updates. For more information, +see Global +Surface Updates.

  • +
  • Metadata Utility Library: The Metadata Utility library +belongs to the Metadata Utility Framework (MUF) component that provides +fast metadata access to audio, video and image media files. For more +information, see the Metadata Utility +Library section.

  • +
  • UI Patterns or Thumbnails Enhancement: This is a Multimedia +specific pattern enhancement, which includes many UI (User Interface) +features, listed below:

      +
    • Multiple customized Home Screens with 6 different widget enabled +screens.

    • +
    • Pinch zoom, kinetic scrolling and single-click features.

    • +
    • Good screen view with a new UI theme, and renewed icons.

    • +
    • Hardware acceleration with fast and responsive UI that creates +new transition effects.

    • +
    • Multitasking with Teleport visual task swapper.

    • +
    • Intelligent slide functionality for Hybrid touch and QWERTY +slider devices. Video Graphics Array (VGA) Touch supports for VGA +QWERTY mono blocks.

    • +
    • VGA Touch helps to control Music player.

    • +
  • +
  • Mobile TV: Mobile TV uses DVB-H receiver to consume +broadcast digital mobile television. The Symbian platform provides +fast and easy access to all videos and TV media content. One key press +opens videos and TV application suite, and user scrolls and selects +the desired video functionality. This media experience is built with +major components such as Videos and TV, video player and Mobile TV. +Videos and TV support high quality video up to 720 per resolution +at 12 Mbps and 30 frames per second.

  • +
  • Image Viewer Application: The Image Viewer application +is used when the client opens an image file for viewing. File Manager, +Messaging, Camcorder and Browser S60 components use the Image Viewer +application. It supports Extended ICL JPEG API, which enables a faster +and less memory-consuming way to rotate and zoom images.

  • +
  • FM Radio: The FM Radio application is used to listen +FM radio broadcast over the air. FM radio broadcast is a free service.

  • +
  • Video Sharing: Using the video sharing service, both +call users can start sharing their device live camera view or pre-recorded +video clip during a normal circuit switched (CS) voice call. The video +sharing feature allows the user to upgrade and downgrade their call +with one-way video at times of need. The video sharing application +uses the Multimedia Comms Engine API.

  • +
+
+ +Multimedia Applications +
    +
  • High-Definition Multimedia Interface (HDMI): The Symbian +platform now supports HDMI technology. HDMI is supported as an external +accessory for audio and video playback for a great television playback +experience. It provides improved data performance and is ideal for +streaming high definition audio and video. The 720p resolution is +supported in still image and video viewing. 5+1 channel audio is also +supported.

  • +
  • Home Music Widgets: The Symbian platform now provides +music information through Home Screen Music Widgets. The Home Music +Widgets controls from the Home Screen menu system enables to play +and pause the playing track. The Music Widget supports the Radio Player +and includes the Music Suite Matrix Menu. This menu is configured +through XML and by default supports to launch the functionality listed +below:

      +
    • The last played song

    • +
    • The music collection view

    • +
    • A music shop, or to open the FM radio

    • +
  • +
  • Fusion Player Application: The Symbian platform now +introduces the Fusion Player, which replaces the existing Media Player +and Video Center applications. It enables access to both online video +services and locally stored videos. If DVB-H device is available, +live TV viewing is also possible. The main features supported by the +Fusion player application are as follows:

      +
    • To browse stored videos and to see metadata features of the +video, such as title, thumbnail DRM info, size or play-time.

    • +
    • To check videos that are pre-installed with the device.

    • +
    • To play stored video file in the device.

    • +
  • +
+
+ +OS Base Services +
    +
  • Writable Data Paging (WDP): The Symbian platform now +supports WDP. This enables efficient use of memory and allows multiple +applications to run at the same time without physically adding more +RAM to the hardware. This leads to a more responsive system when switching +between a number of running applications. For more information, +see Writable +Data Paging.

  • +
  • Symmetric multiprocessor (SMP): The Symbian platform +now supports SMP for multi-core processors, such as the ARM Cortex +A9. This allows device integrators to prototype and prove ARM-based +SMP platforms. For more information, see SMP.

  • +
  • 64-bit file server: The Symbian platform now supports +files larger than 2 GB. For more information, see Large File Access.

  • +
+
+ +Productivity +
    +
  • Nokia Messaging for Social Networks: Nokia Messaging +Social Networking service is a Nokia-hosted consumer service that +provides easy and affordable mobile access to popular social networking +communities.

  • +
  • Enhanced Calendar UI Architecture: Calendar UI architecture +has changed to improve flexibility of calendar for regional, religious, +custom-tailors and xSP calendar service needs. Multiple storages are +also supported. For more information, see Calendar Guide.

  • +
  • CalDAV Protocol: Calendar application now supports the +CalDAV Protocol, which is an open calendar synchronization standard +contributed by SUN Microsystems. This enables a user to access scheduling +information on remote servers.

  • +
  • Enhanced Contacts Application: The Contacts application +in this release includes the following changes:

      +
    • Integration with social media.

    • +
    • Support for Remote Contacts Lookup, for example, from post-installed +Mail for Exchange account.

    • +
    • Virtual Phonebook API (supports getting access to the user’s +own contact card).

    • +
    • Own contact card.

    • +
  • +
+
+ +Runtimes +
    +
  • The Symbian platform now supports the Open Source based Java +MIDP 2.1.

  • +
  • The Symbian platform now supports Browser Application v7.2 +(with Web Run Time 7.2) that includes the following features:

      +
    • Browser Control

    • +
    • Browser core features

    • +
    • Browser Customization

    • +
    • Browser plug-ins

    • +
    • Browser with touch screen

    • +
    • Content Download

    • +
    • URI Schemes

    • +
    • Display Resolution Optimizations

    • +
    • Optical Finger Navigation (OFN)

    • +
    • FlashLite 3.1

    • +
    • Search Client Integration

    • +
    • Expanding Language and Character Set Support

    • +
    • Improved Security Prompting

    • +
    • Updated Platform Service APIs

    • +
    • Visual Task Swapper Support

    • +
    • Performance Optimizations

    • +
    • Multiple touch/pinch zooming

    • +
  • +
+
+ +Security +The Symbian platform now provides an enhanced Security subsystem +that enables device creators to integrate hardware acceleration modules, +which improves the performance of cryptographic algorithms. This is +particularly valuable in intensive real-time use-cases, such as streaming +audio or video over a secure link, where bulk data needs to be encrypted +and decrypted. + + +User Interface +
    +
  • ScreenPlay, also known as the New Graphics Architecture +(NGA): This new graphics architecture enables device creators +to take advantage of improved software performance, hardware acceleration +and third party graphics engines. It makes it possible to combine +UI components, graphics and video to create highly innovative UIs. +For more information, see The ScreenPlay +Graphics Architecture.

  • +
  • Extended Bitmaps: The Font and Bitmap Server provides +a framework for device creators to add support for their own types +of bitmap compression. Bitmaps that use compression formats that are +provided by device creators are known as extended bitmaps. For more +information, see Extended Bitmaps.

  • +
  • Dynamic Direct Screen Access (DSA) Allocation: The Symbian +platform now supports the dynamic allocation of the DSA buffer. For +more information, see Implementing +Dynamic DSA Allocation.

  • +
  • Multiple Touch Support: The ScreenPlay version of the +Window Server has been extended to support multiple advanced pointers, +with support for proximity and pressure. The emulator now also supports +multiple advanced pointers. For more information, see Advanced Pointers.

  • +
  • Enhanced Touch UI: The touch UI includes the following +improvements:

      +
    • Multi-page Home Screen enables the user to navigate between +widgets with a simple flick gesture

    • +
    • Capacitive multiple touch events are supported.

    • +
    • Tactile Feedback utilizes advanced haptics effects.

    • +
  • +

For more information about the new features in Graphics, see What's New in +Graphics in Symbian^3.

+
+ + +
+
+ + +New C++ APIs in Symbian^3 +Porting applications to Symbian^3 +Introduction to Symbian^3 + + +
+ diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-9126A296-0301-4077-A183-3D703F77C548.dita --- a/Symbian3/PDK/Source/GUID-9126A296-0301-4077-A183-3D703F77C548.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-9126A296-0301-4077-A183-3D703F77C548.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,90 +1,113 @@ - - - - - -Multi-Touch -Support in the Emulator OverviewThis topic provides an overview of multi-touch support in the emulator. -Two mice are used to provide two independent pointer positions. The emulator -responds to the mice’s individual button-clicks, moves, and mouse wheel scrolls -as if two human fingers are moving, touching or hovering over the screen. -

The emulator can be extended to support more than two mice or other pointer -devices.

-

Variant: ScreenPlay. Target -audience: Application developers.

-

The following figure shows two Windows pointers on the emulator screen, -each representing a mouse device. The ordinal integer (starting from 0) beside -each pointer is the unique device identifier. The position of each mouse on -the screen is represented by the X and Y coordinates. The pressure (a positive -value) and proximity (a negative value) information captured by the mouse -wheel is represented by the Z coordinate. Notice that the status bar shows -the identifier and the dynamic X, Y and Z values of each pointer.

- -Two pointers are displayed in the emulator - - -

The delivery of pointer events from the emulator driver to the Window Server -is the same in the multi-touch environment as in the single pointer environment. -This means the raw events for a mouse move, button click and mouse wheel movement -are delivered to the Window Server as usual. Each mouse has a unique device -identifier, which makes it possible to ascertain which mouse the events relate -to. The raw events for each individual mouse include the following:

-
    -
  • TRawEvent::EPointerMove indicates a mouse move or -a mouse wheel movement event.

  • -
  • TRawEvent::EButton1Down indicates that the left mouse -button is pressed down.

  • -
  • TRawEvent::EButton1Up indicates that the left mouse -button is released.

  • -
  • TRawEvent::EPointerOutOfRange indicates that the proximity -of a mouse is out of range. This means that the Z coordinate value of the -mouse has reached HALData::EPointer3DMaxProximity.

  • -
-
Pressure -and proximity emulation

The Z coordinate value is used to represent -the pressure and proximity to the screen. In the emulator, the Z value is -captured and tuned by the mouse wheel movement.

    -
  • Z < 0 indicates the proximity of the device from the screen.

  • -
  • Z > 0 indicates pressure.

  • -

See Advanced -Pointer Overview for more information about pressure and proximity.

The -mouse wheel combines the features of a wheel and a mouse button. The wheel -has discrete, evenly spaced notches. Rotating the wheel backwards or forwards -has the effect of changing the pressure or proximity.

    -
  • When the mouse wheel is rotated, a device-specific message is sent -to the emulator window that has focus as each notch is encountered.

  • -
  • The Z coordinate is initiated as 0. Then when the wheel is moved forward, -the Z value enters the pressure range and increases by one pressure step. -When the wheel is moved backward, the Z value enters the proximity range and -decreases by one proximity step.

    The pressure or proximity step can -be customized in the epoc.ini file. See Enabling -Multi-Touch in the Emulator Tutorial for more information.

  • -
  • When the Z value is in the pressure range (Z > 0), moving the wheel -forward by one notch increases Z by one pressure step. Moving the wheel backward -by one notch decreases Z by one pressure step, until Z returns to 0.

  • -
  • When the Z value is in the proximity range (Z < 0), moving the wheel -backward by one notch decreases Z by one proximity step. Moving the wheel -forward by one notch increases Z by one proximity step, until Z returns to -0.

  • -
  • There are limits to the values of the Z coordinate. This -means that the Symbian emulator does not allow Z to exceed the upper boundary HALData::EPointer3DMaxPressure (a -positive value) and lower boundary HALData::EPointer3DMaxProximity (a -negative value). If Z is at the lower boundary, when the mouse wheel is moved -backward next time, Z does not change. A new Out of Range pointer -event is generated and sent to the Window Server. Similarly when Z is at the -upper boundary, Z does not change when the mouse wheel is moved forward.

  • -
  • When the mouse button down or up event (TRawEvent::EButton1Down or TRawEvent::EButton1Up) -is generated, Z is reset to 0.

  • -
-
-Advanced -Pointers -Enabling -Multi-Touch in the Emulator Tutorial -
\ No newline at end of file + + + + +Support for Multiple Pointers in the Emulator Overview +This topic provides an overview of support for multiple +pointers in the emulator. Two mice are used to provide two independent +pointer positions. The emulator responds to the mice’s individual +button-clicks, moves, and mouse wheel scrolls as if two human fingers +are moving, touching or hovering over the screen. + + + + +

The emulator can be extended to support more than two mice or other +pointer devices.

+

Variant: ScreenPlay. Target audience: Application developers.

+

The following figure shows two Windows pointers on the emulator +screen, each representing a mouse device. The ordinal integer (starting +from 0) beside each pointer is the unique device identifier. The position +of each mouse on the screen is represented by the X and Y coordinates. +The pressure (a positive value) and proximity (a negative value) information +captured by the mouse wheel is represented by the Z coordinate. Notice +that the status bar shows the identifier and the dynamic X, Y and +Z values of each pointer.

+ +Two pointers are displayed in the emulator + +

The delivery of pointer events from the emulator driver to the +Window Server is the same when there are multiple pointers as in the +single pointer environment. This means the raw events for a mouse +move, button click and mouse wheel movement are delivered to the Window +Server as usual. Each mouse has a unique device identifier, which +makes it possible to ascertain which mouse the events relate to. The +raw events for each individual mouse include the following:

+
    +
  • TRawEvent::EPointerMove indicates a mouse +move or a mouse wheel movement event.

  • +
  • TRawEvent::EButton1Down indicates that the +left mouse button is pressed down.

  • +
  • TRawEvent::EButton1Up indicates that the left +mouse button is released.

  • +
  • TRawEvent::EPointerOutOfRange indicates that +the proximity of a mouse is out of range. This means that the Z coordinate +value of the mouse has reached HALData::EPointer3DMaxProximity.

  • +
+
Pressure and proximity emulation

The Z coordinate +value is used to represent the pressure and proximity to the screen. +In the emulator, the Z value is captured and tuned by the mouse wheel +movement.

    +
  • Z < 0 indicates the proximity of the device from the screen.

  • +
  • Z > 0 indicates pressure.

  • +

See Advanced Pointer Overview for more information about pressure +and proximity.

The mouse wheel combines the features of a wheel +and a mouse button. The wheel has discrete, evenly spaced notches. +Rotating the wheel backwards or forwards has the effect of changing +the pressure or proximity.

    +
  • When the mouse wheel is rotated, a device-specific message +is sent to the emulator window that has focus as each notch is encountered.

  • +
  • The Z coordinate is initiated as 0. Then when the wheel is +moved forward, the Z value enters the pressure range and increases +by one pressure step. When the wheel is moved backward, the Z value +enters the proximity range and decreases by one proximity step.

    The pressure or proximity step can be customized in the epoc.ini file. See Enabling Multiple +Pointers in the Emulator Tutorial for more information.

  • +
  • When the Z value is in the pressure range (Z > 0), moving the +wheel forward by one notch increases Z by one pressure step. Moving +the wheel backward by one notch decreases Z by one pressure step, +until Z returns to 0.

  • +
  • When the Z value is in the proximity range (Z < 0), moving +the wheel backward by one notch decreases Z by one proximity step. +Moving the wheel forward by one notch increases Z by one proximity +step, until Z returns to 0.

  • +
  • There are limits to the values of the Z coordinate. This means +that the Symbian emulator does not allow Z to exceed the upper boundary HALData::EPointer3DMaxPressure (a positive +value) and lower boundary HALData::EPointer3DMaxProximity (a negative +value). If Z is at the lower boundary, when the mouse wheel is moved +backward next time, Z does not change. A new Out of Range pointer event is generated and sent to the Window Server. Similarly +when Z is at the upper boundary, Z does not change when the mouse +wheel is moved forward.

  • +
  • When the mouse button down or up event (TRawEvent::EButton1Down or TRawEvent::EButton1Up) is generated, Z is reset +to 0.

  • +
+
+ +Advanced Pointers +Enabling Multiple Pointers in the Emulator Tutorial + + +
+ diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-930F1E88-2A03-4BD1-AA2A-3A0128A844BD.dita --- a/Symbian3/PDK/Source/GUID-930F1E88-2A03-4BD1-AA2A-3A0128A844BD.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-930F1E88-2A03-4BD1-AA2A-3A0128A844BD.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,58 +1,76 @@ - - - - - -Enabling -Multi-Touch in the Emulator TutorialThis topic describes how to configure the Symbian emulator to enable -a multi-touch environment. -

Variant: ScreenPlay. Target -audience: Application developers.

-

This topic builds on Multi-Touch -Support in the Emulator Overview.

-
Configuring -the emulator

Make sure that two or more mice are plugged in and -detected on the Windows PC on which the emulator will run. The number of -detected mice can be from two up to the maximum number defined in the HAL HALData::EPointerMaxPointers attribute.

    -
  1. Add the following lines -to the \epoc32\data\epoc.ini file. These lines enable -ScreenPlay and multi-touch.

    SYMBIAN_BASE_USE_GCE ON -EnableMultiTouch ON
  2. -
  3. Specify the MultiTouchProximityStep and MultiTouchPressureStep values in the \epoc32\data\epoc.ini file to define -the proximity and pressure steps.

    MultiTouchProximityStep 10 -MultiTouchPressureStep 200 -

    If the above two options are not defined in the epoc.ini file, -the default proximity and pressure steps are taken from the following HAL -attributes.

    HALData::EPointer3DProximityStep -HALData::EPointer3DPressureStep
  4. -

Result: Launch the emulator to verify that the mice are detected -and displayed inside the application window area. When you move a mouse or -scroll the mouse wheel, its X, Y and Z values are reflected in the status -bar.

-
Enabling -and disabling multi-touch

Multi-touch is only required by UI applications. -Therefore, multi-touch is enabled inside the orange rectangular area shown -on the following diagram. Inside the area two Windows pointers are displayed. -The one numbered zero is the system pointer and the other is used only for -multi-touch purposes. The first mouse to report events to the emulator is -automatically taken as the primary mouse, which owns the Windows system pointer.

-Multi-touch area - -

System pointer. Once the system pointer moves outside multi-touch -area, multi-touch is temporarily disabled and standard emulator pointer behavior -is resumed. This means that only one Windows system pointer is displayed and -it is controlled by both mice.

Non-system pointer. If the -non-system pointer moves out of the multi-touch area, the pointer just disappears -from the screen. Disabling multi-touch is then not necessary because the system -pointer behaves normally inside the multi-touch area. Moving the non-system -pointer back into the area makes it reappear on the screen.

-
-Multi-Touch -Support in the Emulator Overview -
\ No newline at end of file + + + + +Enabling Multi<?Pub Caret?>ple Pointers in the Emulator Tutorial +This topic describes how to configure the Symbian emulator +to enable a multiple pointer environment. + + + + +

Variant: ScreenPlay. Target audience: Application developers.

+

This topic builds on Support for +Multiple Pointers in the Emulator Overview.

+
Configuring the emulator

Make sure that two or more mice +are plugged in and detected on the Windows PC on which the emulator +will run. The number of detected mice can be from two up to the maximum +number defined in the HAL HALData::EPointerMaxPointers attribute.

    +
  1. Add the following +lines to the \epoc32\data\epoc.ini file. These +lines enable ScreenPlay and multiple pointers.

    SYMBIAN_BASE_USE_GCE ON +EnableMultiTouch ON
  2. +
  3. Specify the MultiTouchProximityStep and MultiTouchPressureStep values in the \epoc32\data\epoc.ini file to +define the proximity and pressure steps.

    MultiTouchProximityStep 10 +MultiTouchPressureStep 200 +

    If the above two options are not defined in the epoc.ini file, the default proximity and pressure steps +are taken from the following HAL attributes.

    HALData::EPointer3DProximityStep +HALData::EPointer3DPressureStep
  4. +

Result: Launch the emulator to verify that the mice +are detected and displayed inside the application window area. When +you move a mouse or scroll the mouse wheel, its X, Y and Z values +are reflected in the status bar.

+
Enabling and disabling multiple pointers

Multiple pointers are only required by UI applications. Therefore, +they are enabled inside the orange rectangular area shown on the following +diagram. Inside the area two Windows pointers are displayed. The one +numbered zero is the system pointer and the other is used only for +emulating touch with two fingers. The first mouse to report events +to the emulator is automatically taken as the primary mouse, which +owns the Windows system pointer.

+Multiple pointer area +

System pointer. Once the +system pointer moves outside the multiple pointer area, multiple pointers +are temporarily disabled and standard emulator pointer behavior is +resumed. This means that only one Windows system pointer is displayed +and it is controlled by both mice.

Non-system pointer. If the non-system pointer moves out of the multiple pointer area, +the pointer just disappears from the screen. Disabling multiple pointers +is then not necessary because the system pointer behaves normally +inside the multiple pointer area. Moving the non-system pointer back +into the area makes it reappear on the screen.

+
+ +Support for Multiple Pointers in the Emulator Overview + + +
+ diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-9C269F45-F160-5A4B-ABF8-896D2A538E3B.dita --- a/Symbian3/PDK/Source/GUID-9C269F45-F160-5A4B-ABF8-896D2A538E3B.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-9C269F45-F160-5A4B-ABF8-896D2A538E3B.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,19 +1,242 @@ - - - - - -Advanced Pointer Overview This is an overview of the Window Server extensions that support the use of advanced pointers. These extensions enable mobile devices to respond to events from multiple pointers, including their proximity and pressure. These extensions are available only in ScreenPlay.

Variant: ScreenPlay. Target audience: Application developers.

Architecture

In response to multi-touch pointer movements, an input driver generates a pointer event for each touch. The Window Server changes and delivers the pointer events to the client application, as shown in the following diagram.

- Pointer events -

Pointer-related events move from the driver to the application. The TRawEvent, TWsEvent and TPointerEvent classes encapsulate the event information.

Key concepts/terms

The following terms are introduced here and are used throughout the advanced pointer documentation:

Pointer

A device that points at the screen, for example, a mouse, pen, finger, or touchpad.

Multi-pointer support

Handling more than one pointer at the same time.

Proximity

Proximity in this context means the distance of the pointer from the mobile device. Sensors detect the value of the proximity of the pointer from the mobile device.

Pressure

Pressure in this context is a value that indicates the force applied to the mobile device by the pointer. Sensors detect the value of the pressure of the pointer on the mobile device.

Logical model of pointing devices

A logical model is used to handle all of the different pointing devices correctly. In this logical model, the pointer is performing an action when any of the following scenarios occur:

  • An EButton1Down event is sent to the client.

  • EDrag events are sent to the client (optional).

  • An EButton1Up event is sent to the client.

Pointing devices can be in one of the following states:

State Description

Out of range

Not detected by the device's sensors.

Up

Detected by sensors, coordinates available, not performing an action.

Down

Detected by sensors, coordinates available, performing an action (as defined above).

The mapping between these states and physical actions performed by the user vary for different pointing device types (mouse, finger) and different phone models. Here are two example interpretations of physical pointing device states:

  • Mouse. An example interpretation by a driver of the physical state of a mouse is as follows: It is always in the up state except when the left button is pressed, when it is in the down state. It is never out of range.

  • Fingers with proximity support. The following is an example interpretation of finger physical states when the device has proximity support (that is, it can measure the finger's proximity from the screen):

    • Out of range when proximity > 10cm

    • Up when 1cm < proximity <= 10cm

    • Down when proximity <= 1cm

    In this way the finger can perform actions (for example, press buttons, drag items) without touching the screen.

Multiple pointers

The system handles multiple pointers at the same time by identifying each one with a number and sending pointer events separately for each of them. A field (iPointerNumber) in the pointer event classes (TRawEvent and the TAdvancedPointerEvent class which extends TPointerEvent) identifies the pointer for which the event occurred. The order and frequency of pointer events depends on the driver of the pointing device.

On each phone there is a pool of available pointer numbers, ranging from 0 to HALData::EPointerNumberOfPointers - 1. Every time the driver detects a new pointer coming into the range of the device, the driver assigns a number from the pool. After the pointer goes out of the range of the device, the number no longer identifies that particular pointer and the driver sends TRawEvent::EPointer3DOutOfRange with this pointer number. The number is then released back to the pool and may be reused to identify another pointer coming into the device's range.

Pressure and proximity

The pressure of the pointer on the screen is represented as a positive integer. The proximity of the pointer to the screen is represented as a negative integer. It is up to the UI Platform to define units of pressure and proximity, which may be non-linear. In the TRawEvent class, pressure and proximity are expressed in terms of the Z coordinate of the pointer. The definition of the Z coordinate is based on the assumption that the pointer is either hovering over the screen (proximity < 0, pressure = 0) or touching the screen (proximity = 0, pressure >= 0):

  • If proximity < 0 and pressure = 0 then the Z coordinate = proximity.

  • If proximity = 0 and pressure >= 0 then the Z coordinate = pressure.

- Relationships between the pointer proximity, pressure and z - coordinate -
API summary API Description

HALData

Includes z coordinate, pressure precision and number of pointers. Also contains threshold values for proximity and pressure.

TRawEvent

Includes the pointer number and a structure for proximity and pressure data.

RWindowBase

Enables advanced pointer events for the window.

TWsEvent

Supports TAdvancedPointerEvent (derived from TPointerEvent).

TPointerEvent

Includes event types for pressing and closeness.

TAdvancedPointerEvent

Inherits from TPointerEvent.

Provides capabilities for pressure, proximity and multi-touch support.

RWsSession

Provides get and set methods to manipulate threshold values for proximity and pressure.

Typical uses
  • Enabling many pointers for a window

    Enables multiple pointers to act on one window.

  • Enabling concurrent control of many objects

    Controls many objects on one or more windows with many pointers.

  • Getting z coordinates from TPointerEvent

    Reads the pressure and proximity values for a pointer.

  • Pinch zooming

    Enables the user to zoom in and out of data by using two fingers to pinch an area of the screen. Pinch zooming is normally used in web-page, map, picture, chart and control applications.

  • Responding to high pressure events

    As the pointer state changes, the pressure value can be checked. When it passes over a threshold value, the Window Server responds appropriately to the client.

Pointer States and Event - Communication Advanced Pointer - Tutorial
\ No newline at end of file + + + + +Advanced Pointer Overview +This is an overview of the Window Server extensions that +support the use of advanced pointers. These extensions enable mobile +devices to respond to events from multiple pointers, including their +proximity and pressure. These extensions are available only in ScreenPlay. + + + + +

Variant: ScreenPlay. Target audience: Application developers.

+
Architecture

In response to multiple pointer movements, an input driver generates +a pointer event for each touch. The Window Server changes and delivers +the pointer events to the client application, as shown in the following +diagram.

+ Pointer events +

Pointer-related events move from +the driver to the application. The TRawEvent, TWsEvent and TPointerEvent classes encapsulate the event information.

+
Key concepts/terms

The following terms +are introduced here and are used throughout the advanced pointer documentation:

+ +
Pointer
+

A device that points at the screen, for example, a mouse, pen, +finger, or touchpad.

+ +
Multiple pointer support
+

Handling more than one pointer at the same time.

+
+ +
Proximity
+

Proximity in this context means the distance of the pointer +from the mobile device. Sensors detect the value of the proximity +of the pointer from the mobile device.

+ +
Pressure
+

Pressure in this context is a value that indicates the force +applied to the mobile device by the pointer. Sensors detect the value +of the pressure of the pointer on the mobile device.

+
+
+
Logical model of pointing devices

A logical +model is used to handle all of the different pointing devices correctly. +In this logical model, the pointer is performing an action when +any of the following scenarios occur:

    +
  • An EButton1Down event is sent to the client.

  • +
  • EDrag events are sent to the client (optional).

  • +
  • An EButton1Up event is sent to the client.

  • +

Pointing devices can be in one of the following states:

+ + + +State +Description + + + + +

Out of range

+

Not detected by the device's sensors.

+
+ +

Up

+

Detected by sensors, coordinates available, not performing +an action.

+
+ +

Down

+

Detected by sensors, coordinates available, performing an +action (as defined above).

+
+ + +

The mapping between these states and physical actions +performed by the user vary for different pointing device types (mouse, +finger) and different phone models. Here are two example interpretations +of physical pointing device states:

    +
  • Mouse. An example interpretation by a driver of the physical state of +a mouse is as follows: It is always in the up state except +when the left button is pressed, when it is in the down state. +It is never out of range.

  • +
  • Fingers +with proximity support. The following is an example interpretation +of finger physical states when the device has proximity support (that +is, it can measure the finger's proximity from the screen):

      +
    • Out of range when proximity > 10cm

    • +
    • Up when +1cm < proximity <= 10cm

    • +
    • Down when proximity <= 1cm

    • +

    In this way the finger can perform actions (for example, +press buttons, drag items) without touching the screen.

  • +
+
Multiple pointers

The system handles multiple +pointers at the same time by identifying each one with a number and +sending pointer events separately for each of them. A field (iPointerNumber) in the pointer event classes (TRawEvent and the TAdvancedPointerEvent class which extends TPointerEvent) identifies the pointer for which the event occurred. The +order and frequency of pointer events depends on the driver of the +pointing device.

On each phone there is a pool of available +pointer numbers, ranging from 0 to HALData::EPointerNumberOfPointers - 1. Every time the driver detects a new pointer coming into the +range of the device, the driver assigns a number from the pool. After +the pointer goes out of the range of the device, the number no longer +identifies that particular pointer and the driver sends TRawEvent::EPointer3DOutOfRange with this +pointer number. The number is then released back to the pool and may +be reused to identify another pointer coming into the device's range.

+
Pressure and proximity

The pressure of +the pointer on the screen is represented as a positive integer. The +proximity of the pointer to the screen is represented as a negative +integer. It is up to the UI Platform to define units of pressure and +proximity, which may be non-linear. In the TRawEvent class, pressure and proximity are expressed in terms of the +Z coordinate of the pointer. The definition of the Z coordinate is +based on the assumption that the pointer is either hovering over the +screen (proximity < 0, pressure = 0) or touching the screen (proximity += 0, pressure >= 0):

    +
  • If proximity +< 0 and pressure = 0 then the Z coordinate = proximity.

  • +
  • If proximity += 0 and pressure >= 0 then the Z coordinate = pressure.

  • +
+ Relationships between the pointer proximity, +pressure and z coordinate +
+
API summary + + + +API +Description + + + + +

HALData

+

Includes z coordinate, pressure precision and number of +pointers. Also contains threshold values for proximity and pressure.

+
+ +

TRawEvent

+

Includes the pointer number and a structure for proximity +and pressure data.

+
+ +

RWindowBase

+

Enables advanced pointer events for the window.

+
+ +

TWsEvent

+

Supports TAdvancedPointerEvent (derived +from TPointerEvent).

+
+ +

TPointerEvent

+

Includes event types for pressing and closeness.

+
+ +

TAdvancedPointerEvent

+

Inherits from TPointerEvent.

Provides +capabilities for pressure, proximity and multiple pointers.

+
+ +

RWsSession

+

Provides get and set methods to manipulate threshold values +for proximity and pressure.

+
+ + +
+
Typical uses
    +
  • Enabling +many pointers for a window

    Enables multiple pointers +to act on one window.

  • +
  • Enabling +concurrent control of many objects

    Controls many objects +on one or more windows with many pointers.

  • +
  • Getting +z coordinates from TPointerEvent

    Reads the pressure and +proximity values for a pointer.

  • +
  • Pinch zooming

    Enables the user to zoom in and out of data by using two +fingers to pinch an area of the screen. Pinch zooming is normally +used in web-page, map, picture, chart and control applications.

  • +
  • Responding +to high pressure events

    As the pointer state changes, +the pressure value can be checked. When it passes over a threshold +value, the Window Server responds appropriately to the client.

  • +
+
+ +Pointer States and Event Communication + +Advanced Pointer Tutorial + +
+ diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-AE6F03EB-1430-4526-B4D0-57BC6C6029D4.dita --- a/Symbian3/PDK/Source/GUID-AE6F03EB-1430-4526-B4D0-57BC6C6029D4.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-AE6F03EB-1430-4526-B4D0-57BC6C6029D4.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,54 +1,65 @@ - - - - - -Touch -UI -

When designing a Symbian application, the UI must be designed so that all -tasks can be performed with touch. Therefore, the design must not rely on -hardware keys (except for turning the power ON and OFF).

-

The touch UI in the Symbian platform involves various specific touch components, -component and UI behavior changes, layout changes and additions to the user experience. The -main differences or additions in touch UI include the following:

-
    -
  • Resistive touch screen (HW).

    For more information, see Designing applications for -touch UI

  • -
  • Capacitive touch screen (HW).

    For more information, see Designing applications for -touch UI

  • -
  • Single tap. For more information, see Single -tap.

  • -
  • Multi-touch.

    For more information, see Multi-touch.

  • -
  • Touch gestures.

    For more information, -see Touch gestures.

  • -
  • Toolbar component in touch UI

    For -more information, see Toolbar.

  • -
  • Touch input component (virtual keyboard, hand-writing recognition and -virtual ITU-T)

    For more information, -see Text -input.

  • -
  • Stylus pop-up menu component

    For -more information, see Stylus -pop-up menu.

  • -
  • On-screen dialer application

  • -
  • Additional touch functionality to some components (for example, Preview -pop-up)

    For more information, -see Preview -pop-up.

  • -
  • Touch-enabled components

    For -more information, see Touch support for UI components.

  • -
-

There are two generic layouts for touch UI -portrait orientation and landscape -orientation, see the following figure. The Status -pane in Touch UI has three variants: extended, flat and small.

- -Default Symbian Touch UI layouts for portrait and landscape - - -
\ No newline at end of file + + + + +Touch UI + + + + +

When designing a Symbian application, the UI must be designed so +that all tasks can be performed with touch. Therefore, the design +must not rely on hardware keys (except for turning the power ON and +OFF).

+

The touch UI in the Symbian platform involves various specific +touch components, component and UI behavior changes, layout changes +and additions to the user experience. The main differences or additions in touch UI include the following:

+
    +
  • Resistive touch screen (HW).

    For more information, see Designing applications +for touch UI

  • +
  • Capacitive touch screen (HW).

    For more information, +see Designing +applications for touch UI

  • +
  • Single tap. For more information, see Single tap.

  • +
  • Multiple touch.

    For more information, see Multiple touch.

  • +
  • Touch gestures.

    For more information, see Touch gestures.

  • +
  • Toolbar component in touch UI

    For more information, see Toolbar.

  • +
  • Touch input component (virtual keyboard, hand-writing recognition +and virtual ITU-T)

    For more information, see Text input.

  • +
  • Stylus pop-up menu component

    For more information, see Stylus pop-up +menu.

  • +
  • On-screen dialer application

  • +
  • Additional touch functionality to some components (for example, +Preview pop-up)

    For more information, see Preview pop-up.

  • +
  • Touch-enabled components

    For more information, see Touch support +for UI components.

  • +
+

There are two generic layouts for touch UI -portrait orientation +and landscape orientation, see the following figure. The Status pane in Touch UI has three variants: extended, flat and small.

+ +Default Symbian Touch UI layouts for portrait and landscape + +
+
+ diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-C60DC070-572B-5960-B394-550426FDB909.dita --- a/Symbian3/PDK/Source/GUID-C60DC070-572B-5960-B394-550426FDB909.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-C60DC070-572B-5960-B394-550426FDB909.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,199 +1,263 @@ - - - - - - Advanced -Pointer TutorialThis tutorial provides step-by-step instructions and sample code -to help you write applications using advanced pointers. -

Variant: ScreenPlay. Target -audience: Application developers.

-
Required background

This topic builds on the material -in the following topics:

    -
  • Advanced -Pointer Overview

  • -
  • Advanced -Pointer States and Event Communication

  • -
-
Using advanced pointers

This topic covers the following:

    -
  • Enabling multi-touch for a window

  • -
  • Getting Z coordinates from TPointerEvent

  • -
  • Pinch zooming

  • -
-
Enabling multi-touch -in a window
    -
  1. RWindow provides -a handle to a standard window. Call RWindow to create an -instance of a window.

    -RWindow window(ws); - -User::LeaveIfError(window.Construct(wg, reinterpret_cast<TUint32>(&wg) + 1)); -
  2. -
  3. Call RWindow::EnableAdvancedPointers() to -enable advanced pointers. Then call RWindowBase::Activate() to -display the window and enable the window to receive events. RWindow inherits -from RWindowBase, so you can call the Activate() function -on RWindow.

    -window.EnableAdvancedPointers(); -window.Activate(); -

    When an application needs to receive advanced pointer events -in a window, it must call RWindowBase::EnableAdvancedPointers() for -the window before it is activated.

    If advanced pointers are -not enabled for a window, it receives only standard TPointerEvent information -from a single pointer with no pressure and proximity data. The single pointer -environment rules describe the way in which pointer events coming from many -pointers in the multi-pointer model are transformed into events of one pointer. -They are necessary to ensure that old single-pointer applications work in -a multi-touch environment intuitively and as expected by the user.

    However, -the new TPointerEvent types, EEnterCloseProximity, EExitCloseProximity, EEnterHighPressure and EExitHighPressure, are delivered to all windows, -even to those that do not enable advanced pointers.

  4. -
-
Getting Z coordinates -from TPointerEvent
    -
  1. Call TPointerEvent::AdvancedPointerEvent() on -a TPointerEvent to return a pointer to a TAdvancedPointerEvent.

    -TZType aZType; -TPointerEvent& aPointerEvent; -TInt* aZ; -TInt* aPoint3D; - -TAdvancedPointerEvent *advancedP = aPointerEvent.AdvancedPointerEvent(); -

    TPointerEvent is a struct that contains -details of a pointer event. TZType is a struct provided by -the programmer containing members to hold proximity, pressure, and "proximity -and pressure" data.

  2. -
  3. Now we need to test -whether the pointer event contains advanced pointer data. If it is not an -advanced pointer, the code leaves.

    If it is an advanced pointer, we -call functions to detect proximity, pressure, "proximity and pressure" data -and coordinates.

    -if(!advancedP) - { - // The TPointerEvent isn't an instance of TAdvancedPointerEvent - User::Leave(KErrArgument); - } - -switch(aZType) - { - case EZTypeProximity: - aZ = advancedP->Proximity(); - aPoint3D = advancedP->Proximity3D(); - break; - case EZTypePressure: - aZ = advancedP->Pressure(); - aPoint3D = advancedP->Pressure3D(); - break; - case EZTypeProximityAndPressure: - aZ = advancedP->ProximityAndPressure(); - aPoint3D = advancedP->ProximityAndPressure3D(); - break; - default: - User::Leave(KErrArgument); - break; - } -
      -
    • TAdvancedPointerEvent::Proximity() returns -the proximity.

    • -
    • TAdvancedPointerEvent::Pressure() returns -the pressure.

    • -
    • TAdvancedPointerEvent::ProximityAndPressure() returns -the proximity and pressure combined.

    • -
    • TAdvancedPointerEvent:: -Position3D() returns the proximity and the X, Y and Z coordinates.

    • -
    • TAdvancedPointerEvent::Pressure3D() returns -the pressure and the X and Y coordinates.

    • -

    Proximity is always negative and pressure is always positive. -Internally they are combined together as a Z coordinate. When Z > 0, the proximity -is 0 and the Z value represents the pressure. When Z < 0, the pressure -is 0 and the Z value represents the proximity. Some APIs use only a Z coordinate -(such as the threshold getters and setters and TAdvancedPointerEvent::ProximityAndPressure()). -In these, the Z coordinate is interpreted in terms of pressure and proximity.

  4. -
- Relationships between the pointer proximity, pressure and Z - coordinate - -
-
Pinch zooming

This -example shows an easy way to pinch zoom an image when the screen receives -pointer events from two pointers. There are two functions in this code that -must be implemented by the programmer: BitmapCoordinates() and MoveBitmap(). -They are not included in the example because they involve complex calculations -that are not related to advanced pointers.

The high-level steps to -perform pinch zooming are:

    -
  1. Define the coordinates, -equivalent to the given on-screen coordinates. In the code example, this is -done using the function BitmapCoordinates().

  2. -
  3. Define the ID of the -pointer by using TAdvancedPointerEvent::PointerNumber(). -If the device can handle two pointers (two fingers) at the same time, their -numbers are 0 and 1. The pointer number enables you to distinguish a given -pointer from other pointers.

  4. -
  5. For each pointer assign -its coordinates to a local variable. We assume there are only two pointers -handled by the system here.

  6. -
  7. Use the MoveBitmap() function -to achieve the zoom effect.

    -/** -Receives pointer events from two pointers to perform Pinch Zoom of the image. -Function will finish when EButton1Up is received for any of the pointers. -@param aPointer1 Coordinates of pointer number 1 when zoom is started -@param aPointer2 Coordinates of pointer number 2 when zoom is started -*/ - -void PinchZoom(TPoint aPointer1, TPoint aPointer2) - { - TPoint actualP1 = aPointer1; - TPoint actualP2 = aPointer2; - - // translate on-screen pointer coordinates to coordinates of displayed bitmap - TPoint bitmapCatching1 = BitmapCoordinates(aPointer1); - TPoint bitmapCatching2 = BitmapCoordinates(aPointer2); - - TBool repaint = EFalse; - - while (ETrue) - { - TAdvancedPointerEvent event = GetNextPointerEvent(); - - if (event.iType == TPointerEvent::EDrag) - { - if (event.PointerNumber() == 1) - { - actualP1 = event.iPosition; - repaint = ETrue; - } - else if (event.PointerNumber() == 2) - { - actualP2 = event.iPosition; - repaint = ETrue; - } - } - else if (event.iType == TPointerEvent::EButton1Up) - { - break; - } - - if (repaint) - { - // move bitmap on the screen in the way that - // bitmapCatching1 point of the bitmap will be displayed at actualP1 screen coordinate, - // bitmapCatching2 point of the bitmap will be displayed at actualP2 screen coordinate. - MoveBitmap(bitmapCatching1, actualP1, bitmapCatching2, actualP2); - repaint = EFalse; - } - } - } -
  8. -
-
-Advanced -Pointer Overview -Advanced -Pointer States and Event Communication -
\ No newline at end of file + + + + + Advanced Pointer Tutorial +This tutorial provides step-by-step instructions and sample +code to help you write applications using advanced pointers. + + + + +

Variant: ScreenPlay. Target audience: Application developers.

+
Required background

This topic builds +on the material in the following topics:

    +
  • Advanced Pointer +Overview

  • +
  • Advanced Pointer +States and Event Communication

  • +
+
Using advanced pointers

This topic covers +the following:

    +
  • Enabling multiple pointers in a window

  • +
  • Getting Z coordinates from TPointerEvent

  • +
  • Pinch zooming

  • +
+
Enabling +multiple pointers in a window
    +
  1. RWindow provides a handle to a standard window. Call RWindow to create an instance of a window.

    +RWindow window(ws); + +User::LeaveIfError(window.Construct(wg, reinterpret_cast<TUint32>(&wg) + 1)); +
  2. +
  3. Call RWindow::EnableAdvancedPointers() to enable +advanced pointers. Then call RWindowBase::Activate() to display the +window and enable the window to receive events. RWindow inherits from RWindowBase, so you can call the Activate() function +on RWindow.

    +window.EnableAdvancedPointers(); +window.Activate(); +

    When an application needs to receive advanced pointer +events in a window, it must call RWindowBase::EnableAdvancedPointers() for the window before it is activated.

    If advanced +pointers are not enabled for a window, it receives only +standard TPointerEvent information from a single +pointer with no pressure and proximity data. The single pointer environment +rules describe the way in which pointer events coming from many pointers +in the multiple pointer model are transformed into events of one pointer. +They are necessary to ensure that old single-pointer applications +work in a multiple pointer environment intuitively and as expected +by the user.

    However, the new TPointerEvent types, EEnterCloseProximity, EExitCloseProximity, EEnterHighPressure and EExitHighPressure, are delivered to all windows, even to those that do not +enable advanced pointers.

  4. +
+
Getting +Z coordinates from TPointerEvent
    +
  1. Call TPointerEvent::AdvancedPointerEvent() on +a TPointerEvent to return a pointer to a TAdvancedPointerEvent.

    +TZType aZType; +TPointerEvent& aPointerEvent; +TInt* aZ; +TInt* aPoint3D; + +TAdvancedPointerEvent *advancedP = aPointerEvent.AdvancedPointerEvent(); +

    TPointerEvent is a struct that contains +details of a pointer event. TZType is a struct provided +by the programmer containing members to hold proximity, pressure, +and "proximity and pressure" data.

  2. +
  3. Now we need +to test whether the pointer event contains advanced pointer data. +If it is not an advanced pointer, the code leaves.

    If it is +an advanced pointer, we call functions to detect proximity, pressure, +"proximity and pressure" data and coordinates.

    +if(!advancedP) + { + // The TPointerEvent isn't an instance of TAdvancedPointerEvent + User::Leave(KErrArgument); + } + +switch(aZType) + { + case EZTypeProximity: + aZ = advancedP->Proximity(); + aPoint3D = advancedP->Proximity3D(); + break; + case EZTypePressure: + aZ = advancedP->Pressure(); + aPoint3D = advancedP->Pressure3D(); + break; + case EZTypeProximityAndPressure: + aZ = advancedP->ProximityAndPressure(); + aPoint3D = advancedP->ProximityAndPressure3D(); + break; + default: + User::Leave(KErrArgument); + break; + } +
      +
    • TAdvancedPointerEvent::Proximity() returns +the proximity.

    • +
    • TAdvancedPointerEvent::Pressure() returns +the pressure.

    • +
    • TAdvancedPointerEvent::ProximityAndPressure() returns the proximity and pressure combined.

    • +
    • TAdvancedPointerEvent:: Position3D() returns +the proximity and the X, Y and Z coordinates.

    • +
    • TAdvancedPointerEvent::Pressure3D() returns +the pressure and the X and Y coordinates.

    • +

    Proximity is always negative and pressure is always positive. Internally they are combined together as a Z coordinate. +When Z > 0, the proximity is 0 and the Z value represents the pressure. +When Z < 0, the pressure is 0 and the Z value represents the proximity. +Some APIs use only a Z coordinate (such as the threshold getters and +setters and TAdvancedPointerEvent::ProximityAndPressure()). In these, the Z coordinate is interpreted in terms of pressure +and proximity.

  4. +
+ Relationships between the pointer proximity, pressure and +Z coordinate +
+
Pinch +zooming

This example shows an easy way to pinch zoom an +image when the screen receives pointer events from two pointers. There +are two functions in this code that must be implemented by the programmer: BitmapCoordinates() and MoveBitmap(). They +are not included in the example because they involve complex calculations +that are not related to advanced pointers.

The high-level +steps to perform pinch zooming are:

    +
  1. Define the coordinates, +equivalent to the given on-screen coordinates. In the code example, +this is done using the function BitmapCoordinates().

  2. +
  3. Define the ID +of the pointer by using TAdvancedPointerEvent::PointerNumber(). +If the device can handle two pointers (two fingers) at the same time, +their numbers are 0 and 1. The pointer number enables you to distinguish +a given pointer from other pointers.

  4. +
  5. For each pointer +assign its coordinates to a local variable. We assume there are only +two pointers handled by the system here.

  6. +
  7. Use the MoveBitmap() function to achieve the zoom effect.

    +/** +Receives pointer events from two pointers to perform Pinch Zoom of the image. +Function will finish when EButton1Up is received for any of the pointers. +@param aPointer1 Coordinates of pointer number 1 when zoom is started +@param aPointer2 Coordinates of pointer number 2 when zoom is started +*/ + +void PinchZoom(TPoint aPointer1, TPoint aPointer2) + { + TPoint actualP1 = aPointer1; + TPoint actualP2 = aPointer2; + + // translate on-screen pointer coordinates to coordinates of displayed bitmap + TPoint bitmapCatching1 = BitmapCoordinates(aPointer1); + TPoint bitmapCatching2 = BitmapCoordinates(aPointer2); + + TBool repaint = EFalse; + + while (ETrue) + { + TAdvancedPointerEvent event = GetNextPointerEvent(); + + if (event.iType == TPointerEvent::EDrag) + { + if (event.PointerNumber() == 1) + { + actualP1 = event.iPosition; + repaint = ETrue; + } + else if (event.PointerNumber() == 2) + { + actualP2 = event.iPosition; + repaint = ETrue; + } + } + else if (event.iType == TPointerEvent::EButton1Up) + { + break; + } + + if (repaint) + { + // move bitmap on the screen in the way that + // bitmapCatching1 point of the bitmap will be displayed at actualP1 screen coordinate, + // bitmapCatching2 point of the bitmap will be displayed at actualP2 screen coordinate. + MoveBitmap(bitmapCatching1, actualP1, bitmapCatching2, actualP2); + repaint = EFalse; + } + } + } +
  8. +
+
+ +Advanced Pointer Overview +Advanced Pointer States and Event Communication + + +
+ diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-D0C84E1D-A625-4F79-8515-399B8153727B.dita --- a/Symbian3/PDK/Source/GUID-D0C84E1D-A625-4F79-8515-399B8153727B.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-D0C84E1D-A625-4F79-8515-399B8153727B.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,128 +1,158 @@ - - - - - -What's -New in Graphics in Symbian^3This section describes the changes introduced in the Graphics package -in Symbian^3. -
ScreenPlay

ScreenPlay -is a new graphics architecture which enables device creators to take advantage -of improved software performance, hardware acceleration and third party graphics -engines. For more information, see:

    -
  • The ScreenPlay -Graphics Architecture
  • -
  • The NonScreenPlay -Graphics Architecture
  • + + + + +What's New in Graphics in Symbian^3 +This section describes the changes introduced in the Graphics +package in Symbian^3. + + + + +
    ScreenPlay

    ScreenPlay is a new graphics architecture which enables device +creators to take advantage of improved software performance, hardware +acceleration and third party graphics engines. For more information, +see:

      +
    • The +ScreenPlay Graphics Architecture
    • +
    • The +NonScreenPlay Graphics Architecture
    • Enabling the Graphics Architecture Variants
    • -
    • Graphics Composition
    • -
    • Graphics Hardware -Acceleration
    • -
    • Dynamic Resolution -Switching
    • - +
    • Graphics +Composition
    • +
    • Graphics +Hardware Acceleration
    • +
    • Dynamic +Resolution Switching
    • Common Graphics Headers Component Overview
    • -
    • Advanced Pointer -Overview
    • -
    • External Surfaces -Overview
    • +
    • Advanced +Pointer Overview
    • +
    • External +Surfaces Overview
    • Render Stages Overview
    • MiniGUI Environment
    -
    Khronos APIs

    For -information about the supported Khronos APIs, see:

      -
    • Khronos API Support
    • -
    • OpenVG Collection
    • -
    • OpenGLES Collection
    • -
    • EGL Collection
    • +
      Khronos +APIs

      For information about the supported Khronos APIs, see:

        +
      • Khronos +API Support
      • +
      • OpenVG +Collection
      • +
      • OpenGLES +Collection
      • +
      • EGL +Collection
      • OpenWF Composition
      Other new features
        -
      • Extended Bitmaps
      • -
      • Implementing Dynamic -DSA Allocation
      • -
      • Multi-Touch -Support in the Emulator
      • +
      • Extended +Bitmaps
      • +
      • Implementing +Dynamic DSA Allocation
      • +
      • Multiple +Pointer Support in the Emulator
      -
      Interface breaks -and deprecated functionality

      The following functionality is deprecated in Symbian^3:

        -
      • DirectGDI is deprecated. See DirectGDI Component for -more information.

      • -
      • The Graphics Resource components -are deprecated and will be removed in Symbian^4. See Graphics -Resource Services Collection for more information.

      • -
      • Creating transparent windows using a mask and RWindow is -deprecated. See Transparent +

        Interface +breaks and deprecated functionality

        The following functionality +is deprecated in Symbian^3:

          +
        • DirectGDI is deprecated. See DirectGDI Component for more information.

        • +
        • The Graphics Resource components are deprecated and will be +removed in Symbian^4. See Graphics Resource +Services Collection for more information.

        • +
        • Creating transparent windows using a mask and RWindow is deprecated. See Transparent Windows for more information.

        • -
        • Backed-up windows are deprecated. See Displayable +

        • Backed-up windows are deprecated. See Displayable Windows for more information.

        -
        Guide documentation -changes

        The following documentation -has been added to the Graphics Reference:

          -
        • Graphics Components -and Their CBR Package Names
        • -
        • Pixel Formats
        • -

        The following documentation has been added to the Windowing collection:

          -
        • Window Server Component -Overview
        • -
        • Display Control -and Mapping in the Window Server Client
        • -
        • Transparent Windows
        • -
        • Redraw Drawing
        • -
        • Advanced Pointers
        • -
        • External Surfaces
        • -
        • Render-Stages
        • +
          Guide +documentation changes

          The following documentation has been +added to the Graphics Reference:

            +
          • Graphics +Components and Their CBR Package Names
          • +
          • Pixel +Formats
          • +

          The following documentation has been added to the Windowing +collection:

            +
          • Window +Server Component Overview
          • +
          • Display +Control and Mapping in the Window Server Client
          • +
          • Transparent +Windows
          • +
          • Redraw +Drawing
          • +
          • Advanced +Pointers
          • +
          • External +Surfaces
          • +
          • Render-Stages
          • Window Server Plug-in Framework Overview
          • MiniGUI Environment
          • -
          • Window Server Internals -Concepts
          • -
          • The wsini.ini File
          • +
          • Window +Server Internals Concepts
          • +
          • The +wsini.ini File
          • Window Server Plug-ins Component
          • -

          The following documentation has -been added to the Font and Bitmap Server collection:

            -
          • Creating an -Extended Bitmap Rasterizer

          • -

          The following documentation has been added to the OpenGLES collection:

            -
          • OpenGLES Collection

          • -

          The following documentation has been added to the OpenVG collection:

            -
          • OpenVG Collection

          • -

          The following documentation has been added to the EGL collection:

            -
          • EGL Collection

          • -

          The following documentation has -been added to the Graphics Utilities collection:

            -
          • Common Graphics -Headers Component Overview
          • -
          • Selection of Adaptations
          • -

          The following documentation has -been added to the Graphics Composition collection:

            -
          • Graphics Composition -Collection

          • -

          The following documentation has -been added to the Graphics Hardware Drivers collection:

            -
          • Graphics Hardware -Drivers Collection

          • +

          The following documentation has been added to the Font and +Bitmap Server collection:

            +
          • Creating an Extended Bitmap Rasterizer

          • +

          The following documentation has been added to the OpenGLES +collection:

            +
          • OpenGLES Collection

          • +

          The following documentation has been added to the OpenVG collection:

            +
          • OpenVG Collection

          • +

          The following documentation has been added to the EGL collection:

            +
          • EGL Collection

          • +

          The following documentation has been added to the Graphics +Utilities collection:

            +
          • Common +Graphics Headers Component Overview
          • +
          • Selection +of Adaptations
          • +

          The following documentation has been added to the Graphics +Composition collection:

            +
          • Graphics Composition Collection

          • +

          The following documentation has been added to the Graphics +Hardware Drivers collection:

            +
          • Graphics Hardware Drivers Collection

          The following documentation has been updated:

            -
          • Graphics and Drawing
          • -
          • The Font and Bitmap -Server Overview
          • +
          • Graphics +and Drawing
          • +
          • The +Font and Bitmap Server Overview
          - -Graphics -Guide - \ No newline at end of file + + +Graphics Guide + + + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/PDK/Source/GUID-F25C17AC-BA88-4965-BAE8-AEF0E2EA66EC.dita --- a/Symbian3/PDK/Source/GUID-F25C17AC-BA88-4965-BAE8-AEF0E2EA66EC.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/PDK/Source/GUID-F25C17AC-BA88-4965-BAE8-AEF0E2EA66EC.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,39 +1,43 @@ - - - - - -Zooming -actionsMobile device users must be able to zoom in and out consistently -within applications on a mobile device. However the zooming actions may differ -from one device model to another. -

          The product features and form factor of a mobile device determine which -zooming actions application developers should make available on it:

          + + + + +Zo<?Pub Caret?>oming actions +Mobile device users must be able to zoom in and out consistently +within applications on a mobile device. However the zooming actions +may differ from one device model to another. + + + + +

          The product features and form factor of a mobile device determine +which zooming actions application developers should make available +on it:

            -
          • If the device has an ITU-T keypad, the asterisk (*) key zooms in and -the hash mark (#) key zooms out. This functionality is not available in editors -or other states where the keys play another role. In these cases, the zoom -functions, if applicable, must be available in the Options menu.

          • -
          • If the device has a QWERTY or half-QWERTY keyboard, use the two topmost -keys at the top left of the keyboard for zooming in and out. For example, -on a Latin keyboard, use the Q key to zoom in and the A key to zoom out. Some -products might have zooming symbols printed on the keyboard to help users -find the zooming features. Again, the functions are not available in editors.

          • -
          • On touch devices, users can use touch stripes to zoom. Finger movement -along the stripe controls zooming. Applications may support different number -of zoom levels. It should be possible to zoom across the full range with one -swipe.

          • -
          • On touch devices with multi-touch support, users can use pinch zoom. -See Multi-touch section -for more details on pinch in and pinch out.

          • -
          • On touch devices, some applications may support double-tapping zoom. -A double tap can toggle between zoomed and normal view, but this depends on -the application.

          • +
          • If the device has an ITU-T keypad, the asterisk (*) key zooms +in and the hash mark (#) key zooms out. This functionality is not +available in editors or other states where the keys play another role. +In these cases, the zoom functions, if applicable, must be available +in the Options menu.

          • +
          • If the device has a QWERTY or half-QWERTY keyboard, use the +two topmost keys at the top left of the keyboard for zooming in and +out. For example, on a Latin keyboard, use the Q key to zoom in and +the A key to zoom out. Some products might have zooming symbols printed +on the keyboard to help users find the zooming features. Again, the +functions are not available in editors.

          • +
          • On touch devices, users can use touch stripes to zoom. Finger +movement along the stripe controls zooming. Applications may support +different number of zoom levels. It should be possible to zoom across +the full range with one swipe.

          • +
          • On touch devices with multiple touch support, users can use +pinch zoom. See Multiple touch section for more details on pinch in and pinch out.

          • +
          • On touch devices, some applications may support double-tapping +zoom. A double tap can toggle between zoomed and normal view, but +this depends on the application.

          -
          \ No newline at end of file +
          +
          + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/SDK/Source/GUID-17C64C2F-9426-4B41-9F0A-23060289D644.dita --- a/Symbian3/SDK/Source/GUID-17C64C2F-9426-4B41-9F0A-23060289D644.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/SDK/Source/GUID-17C64C2F-9426-4B41-9F0A-23060289D644.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,88 +1,99 @@ - - - - - -Multi-touch -

          Multi-touch is an enhancement to the touch screen, which provides -the user with the ability to apply elaborate finger gestures onto -the display as commands to the device.

          -

          Multi-touch is implemented based on the size and type of interfaces. -When a finger or an object touches the display causing the light to -scatter, the reflection is caught by the sensors. The response for -the touch is sent back based on the type of reflection measured.

          -

          Only the devices with multi-touch support have 'Pinch Stroke' as -a touch stroke.

          -
          Pinch -StrokePinch stroke is invoked by two separate but simultaneously -active touch down events and dragging movements along the line that -goes through both touch down points. On release, the pinch in or pinch -out state is maintained. Pinch stroke can be utilized, for example, -in Photo viewer to zoom in and zoom out. - -

          The following table lists the default touch-events for pinch-stroke:

          Default -touch events for pinch-stroke - - - -

          User action

          -

          State change

          -

          Feedback

          -
          - - - -

          First touch down

          -

          No action.

          -

          Tactile:

            -
          • First touch down tactile feedback follows the context-based -feedback.

          • -
          • Audio feedback is provided with touch down.

          • -

          -
          - -

          Second simultaneous touch down

          -

          Activates multi-touch mode for the content defined.

          -

          Tactile:

            -
          • When second finger is touched down multi-touch recognition, -two sensitive pulses effect is provided.

          • -
          • Audio feedback is provided with touch down.

          • -

          -
          - -

          Pinch in

          -

          Moving the touch points (directly) closer to each other -is recognized as pinch in. Application can use it, for example, for -zooming out a picture. The behavior should be in relation to the speed -and size of the stroke.

          -

          Tactile: Smooth pinch effect is provided while moving the -fingers.

          No audio feedback is provided.

          -
          - -

          Pinch out

          -

          Moving the touch points (directly) away from each other -is recognized as pinch out. Application can use it, for example, for -zooming in a picture. The behavior should be in relation to the speed -and size of the stroke.

          -

          Tactile: Smooth pinch effect is provided while moving the -fingers.

          No audio feedback is provided.

          -
          - -

          Touch release

          -

          Releasing one or both fingers stops the pinch.

          -

          No tactile or audio feedback given.

          -
          - - -
          -
          Using multi-touch in applicationsFor multi-touch, -use classes TRawEvent and TAdvancedPointerEvent (which extends TPointerEvent). For more information, -see Advanced -pointers section.
          -
          \ No newline at end of file + + + + +Multiple touch + + + + +

          Multiple touch is an enhancement to the touch screen, which provides +the user with the ability to apply elaborate finger gestures onto +the display as commands to the device.

          +

          Multiple touch is implemented based on the size and type of interfaces. +When a finger or an object touches the display causing the light to +scatter, the reflection is caught by the sensors. The response for +the touch is sent back based on the type of reflection measured.

          +

          Only the devices with multiple touch support have 'Pinch Stroke' +as a touch stroke.

          +
          Pinch +StrokePinch stroke is invoked by two separate but simultaneously +active touch down events and dragging movements along the line that +goes through both touch down points. On release, the pinch in or pinch +out state is maintained. Pinch stroke can be utilized, for example, +in Photo viewer to zoom in and zoom out.

          The following table lists the +default touch-events for pinch-stroke:

          +Default touch events for pinch-stroke + + + +

          User action

          +

          State change

          +

          Feedback

          +
          + + + +

          First touch down

          +

          No action.

          +

          Tactile:

            +
          • First touch down tactile feedback follows the context-based +feedback.

          • +
          • Audio feedback is provided with touch down.

          • +

          +
          + +

          Second simultaneous touch down

          +

          Activates multiple touch mode for the content defined.

          +

          Tactile:

            +
          • When the second finger is touched down, two sensitive pulses +effect is provided.

          • +
          • Audio feedback is provided with touch down.

          • +

          +
          + +

          Pinch in

          +

          Moving the touch points (directly) closer to each other +is recognized as pinch in. Application can use it, for example, for +zooming out a picture. The behavior should be in relation to the speed +and size of the stroke.

          +

          Tactile: Smooth pinch effect is provided while moving the +fingers.

          No audio feedback is provided.

          +
          + +

          Pinch out

          +

          Moving the touch points (directly) away from each other +is recognized as pinch out. Application can use it, for example, for +zooming in a picture. The behavior should be in relation to the speed +and size of the stroke.

          +

          Tactile: Smooth pinch effect is provided while moving the +fingers.

          No audio feedback is provided.

          +
          + +

          Touch release

          +

          Releasing one or both fingers stops the pinch.

          +

          No tactile or audio feedback given.

          +
          + + +
          +
          Using +multiple touch in applicationsFor multiple touch, use classes TRawEvent and TAdvancedPointerEvent (which extends TPointerEvent). For more information, see Advanced pointers section.
          +
          +
          + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/SDK/Source/GUID-1FCD0312-7B28-47F9-BE54-822B74A8934C.dita --- a/Symbian3/SDK/Source/GUID-1FCD0312-7B28-47F9-BE54-822B74A8934C.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/SDK/Source/GUID-1FCD0312-7B28-47F9-BE54-822B74A8934C.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,78 +1,84 @@ - - - - - -Designing -applications for touch UI -

          Both touch screens and hybrid devices are supported by Symbian platform. -Touch screen enables direct manipulation of content and objects, allowing -for far more natural interaction with the device. This means a completely -different user experience and interaction style compared to using a hardware -keypad.

          - - - -

          All applications must be touch-enabled, which means that they can be used -with the touch screen alone, regardless of the presence of a keypad. In Symbian -platform-based touch devices, the important hardware keys are Send, End, Multi-tasking -and Power key.

          -

          The application features must follow the platform support for different -hardware. When designing a touch-enabled Symbian application, the UI must -be designed so that everything can be accomplished by using the touch screen -interface, as the potential target devices may or may not have a hardware -keyboard.

          -

          The touch UI in the Symbian platform is based on the use of resistive and -capacitive touch screens. In resistive touch screen technology, two -conductive and resistive layers are separated by a thin space. When an object -touches this kind of touch panel, the layers are connected at a certain point, -and a touch event is registered. This allows efficient stylus control, in -addition to finger touch - unlike capacitive panels, which usually register -only finger touch. Additionally, resistive touch screen offers a higher resolution -and more durability. In capacitive touch screen technology, the panel -consists of an insulator such as glass, coated with a transparent conductor -(such as indium tin oxide (ITO)). When an object touches the surface of the -screen, it results in a distortion of the local electrostatic field, measurable -as a change in capacitance. Then a touch controller measures the frequency -variations to ascertain the co-ordinates of the object's touch. Capacitive -touch screen supports multi-touch.

          -

          The hardware is supported by various:

          -
            -
          • touch-specific components (see Touch -support for common UI components)

          • -
          • component and UI behavior changes

          • -
          • layout changes, and

          • -
          • additions to the interaction style.

          • -
          -

          The touch UI is designed to enable full task flow with touch, with minimal -need to switch to hardware keys. Thus, the design ensures that users can complete -a task with the chosen interaction method from start to finish.

          -

          While designing and implementing applications for touch screen devices -based on the Symbian platform, consider interactions that benefit the most -from the touch UI.

          -

          If you can apply direct manipulation of the UI, for example when moving -items from one place to another, or scrolling a page, do not confine the user -with unnecessary scrollbars or have the user resort to options list commands.

          -

          Instead, enable the user to view pages larger than a screen by panning -them directly, and dragging and dropping items rather than marking them and -using menu options.

          -
            -
          • Remember that the most intuitive touch screen interactions that can -be performed using a finger are tapping, stroking up/down/left/right, and -the long tap.

          • -
          • Utilize strokes that are easily discovered to the users in the given -context. It should be explicit to the user where strokes can be performed.

          • -
          • Design to ensure that users can complete a task with the same interaction -method from start to finish - touch or hardware keys, stylus, or finger, and -using one hand or both hands.

          • -
          • Aim to optimize system performance and battery consumption to provide -a fluid and reliable touch user experience.

          • -
          -

          See Also:

          -
          \ No newline at end of file + + + + +Designing applications for touch UI + + + + +

          Both touch screens and hybrid devices are supported by Symbian +platform. Touch screen enables direct manipulation of content and +objects, allowing for far more natural interaction with the device. +This means a completely different user experience and interaction +style compared to using a hardware keypad.

          + +

          All applications must be touch-enabled, which means that they can +be used with the touch screen alone, regardless of the presence of +a keypad. In Symbian platform-based touch devices, the important hardware +keys are Send, End, Multi-tasking and Power key.

          +

          The application features must follow the platform support for different +hardware. When designing a touch-enabled Symbian application, the +UI must be designed so that everything can be accomplished by using +the touch screen interface, as the potential target devices may or +may not have a hardware keyboard.

          +

          The touch UI in the Symbian platform is based on the use of resistive +and capacitive touch screens. In resistive touch screen technology, +two conductive and resistive layers are separated by a thin space. +When an object touches this kind of touch panel, the layers are connected +at a certain point, and a touch event is registered. This allows efficient +stylus control, in addition to finger touch - unlike capacitive panels, +which usually register only finger touch. Additionally, resistive +touch screen offers a higher resolution and more durability. In capacitive touch screen technology, the panel consists of an +insulator such as glass, coated with a transparent conductor (such +as indium tin oxide (ITO)). When an object touches the surface of +the screen, it results in a distortion of the local electrostatic +field, measurable as a change in capacitance. Then a touch controller +measures the frequency variations to ascertain the co-ordinates of +the object's touch. Capacitive touch screen supports multiple touch.

          +

          The hardware is supported by various:

          +
            +
          • touch-specific components (see Touch support +for common UI components)

          • +
          • component and UI behavior changes

          • +
          • layout changes, and

          • +
          • additions to the interaction style.

          • +
          +

          The touch UI is designed to enable full task flow with touch, with +minimal need to switch to hardware keys. Thus, the design ensures +that users can complete a task with the chosen interaction method +from start to finish.

          +

          While designing and implementing applications for touch screen +devices based on the Symbian platform, consider interactions that +benefit the most from the touch UI.

          +

          If you can apply direct manipulation of the UI, for example when +moving items from one place to another, or scrolling a page, do not +confine the user with unnecessary scrollbars or have the user resort +to options list commands.

          +

          Instead, enable the user to view pages larger than a screen by +panning them directly, and dragging and dropping items rather than +marking them and using menu options.

          +
            +
          • Remember that the most intuitive touch screen interactions +that can be performed using a finger are tapping, stroking up/down/left/right, +and the long tap.

          • +
          • Utilize strokes that are easily discovered to the users in +the given context. It should be explicit to the user where strokes +can be performed.

          • +
          • Design to ensure that users can complete a task with the same +interaction method from start to finish - touch or hardware keys, +stylus, or finger, and using one hand or both hands.

          • +
          • Aim to optimize system performance and battery consumption +to provide a fluid and reliable touch user experience.

          • +
          +

          See Also:

          +
          +
          + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/SDK/Source/GUID-3E7A9A92-F217-4BD1-82CE-227931CFB8ED.dita --- a/Symbian3/SDK/Source/GUID-3E7A9A92-F217-4BD1-82CE-227931CFB8ED.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/SDK/Source/GUID-3E7A9A92-F217-4BD1-82CE-227931CFB8ED.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,22 +1,25 @@ - - - - - -Multi-Touch -Support in the EmulatorThis section introduces multi-touch support in the emulator which -uses multiple mice to simulate human fingers. The multi-touch environment -in the emulator allows application developers to test their multi-touch related -UI features when hardware devices are not available. -

          Variant: ScreenPlay. Target -audience: Application developers.

          -
          -Advanced -Pointers -
          \ No newline at end of file + + + + +Support for Multiple Pointers in the Emulator +This section introduces support for multiple pointers in +the emulator which uses multiple mice to simulate human fingers. The +multiple pointer environment in the emulator allows application developers +to test multiple pointer UI features when hardware devices are not +available. + + + + +

          Variant: ScreenPlay. Target audience: Application developers.

          +
          + +Advanced Pointers + +
          + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/SDK/Source/GUID-581A8E4B-12BE-41C0-A20E-3087A80FEECF.dita --- a/Symbian3/SDK/Source/GUID-581A8E4B-12BE-41C0-A20E-3087A80FEECF.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/SDK/Source/GUID-581A8E4B-12BE-41C0-A20E-3087A80FEECF.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,253 +1,286 @@ - - - - - -Tactile -feedback -

          There are two cases where vibration or audio of the device is used as an -output method:

          -
            -
          • As a tacticon to inform users through physical feedback, that -an important event is occurring in the device. For example, when a new message -arrives or a warning note is displayed.

          • -
          • As tactile feedback to indicate to the user that an interaction -event has been made. For example, users receive tactile feedback when they -press a button on the touch screen.

          • -
          -

          As with sounds, tactile feedback must be used carefully so as not to desensitize -the user to the vibration; the attention grabbing quality remains and functions -so long as the feedback is not too frequent.

          -

          Tactile feedback is enabled for all the Symbian platform UI components. -Tactile feedback can be disabled for the common UI components in an application. -However, this is acceptable only if tactile feedback causes interference with -other device functions.

          -

          The user can choose the level of tactile feedback and turn tacticons ON -and OFF.

          -

          The following table lists the tactile feedback effects:

          -

          Tactile feedback -effects - - - -

          Effects

          -

          Description

          -
          - - - -

          Sensitive button

          -

          Provides single pulse effect on repeated key presses with buttons. -It is also possible with other similar components.

          -
          - -

          Basic button

          -

          Provides stronger single pulse effect to buttons. It is also possible -with other similar components.

          -
          - -

          Sensitive list

          -

          Provides single pulse effect to lists and grids. Effect is used -with move (drag and flick) when new item appears on the screen.

          -
          - -

          Basic list

          -

          Provides stronger single pulse effect to lists and grids. Effect -is used with touch down and release when tap makes an action.

          In hierarchical -list, collapsing/expanding item provides basic list effect with touch down -and release.

          -
          - -

          Bounce effect

          -

          Provides pulse effect when list returns to its normal state after -boundary effect.

          -
          - -

          Sensitive slider

          -

          Provides pulse effect with scrollbar and slider thumbs. Effect is -provided with touch down and release in thumb area.

          -
          - -

          Smooth slider

          -

          Provides continuous smooth feedback when dragging scrollbar or slider -thumb. This can also be increasing or decreasing depending of the slider type.

          -
          - -

          Hold slider

          -

          Provides sensitive pulse effect when touch down and hold on the -slider or scrollbar area. Slider thumb starts moving step by step towards -the touch point. Every step gives one sensitive pulse. If slider thumb moves -directly to the touch point, then basic slider effect is provided.

          -
          - -

          Pop-up

          -

          Provides sensitive pulse effect when pop-up is opened or closed. -If the theme animations are ON, then pop-up effect is used with opening event -after increasing long touch effect. In this scenario, there is no pop-up effect -. All pop-ups do not have theme animation.

          -
          - -

          Pop-up close

          -

          Provides decreasing smooth feedback a pop-up and when theme animations -are ON.

          -
          - -

          Increasing long touch

          -

          Provides increasing smooth feedback. This can be used with either -long tap animation or pop-up opening theme effects. If the theme effects are -ON and long tap opens a pop-up, then feedback is provided only with long tap. -This is followed by pop-up.

          -
          - -

          Basic tab

          -

          Provides strong pulse effect with touch down event in tab area.

          -
          - -

          Smooth flick

          -

          Provides smooth feedback with drag when horizontal movement is possible.

          -
          - -

          Sensitive flick

          -

          Provides sensitive pulse effect with touch release when horizontal -movement is possible.

          -
          - -

          Sensitive edit

          -

          Provides sensitive pulse effect in editors with touch down and release.

          -
          - -

          Text edit

          -

          Provides pulse effect when painting the text. Effect is provided -with every character while painting the text.

          -
          - -

          Blank edit

          -

          Provides pulse effect when painting blank character. By default, -it is none.

          -
          - -

          Line edit

          -

          Provides pulse effect when painting a line.

          -
          - -

          Empty line

          -

          Provides pulse effect when painting an empty line. By default, it -is none.

          -
          - -

          Check box

          -

          Provides pulse effect when marking/unmarking a check box.

          -
          - -

          Multi-touch recognition

          -

          Provides double pulse (sensitive + sensitive) effect when multi-touch -is recognized (generally, when second finger is touched down).

          -
          - -

          Smooth pinch

          -

          Provides smooth continuous feedback while moving fingers in multi-touch -pinch situation.

          -
          - -

          Smooth rotate

          -

          Provides smooth continuous feedback while moving fingers in multi-touch -rotate situation.

          -
          - - -

          -
          Haptics concept

          The different senses associated -to the skin are called cutaneous senses. These senses are temperature, pressure -(touch itself), pain, tickle, itch and vibration senses. We can characterize -touch as passive or active. Passive touch means the sense of touch itself, -whereas active touch means the touch action.

          To communicate through -the sense of touch, we have to stimulate some of the cutaneous senses or the -movement sense. The stimulation of the cutaneous senses or one of them by -a product is called tactile stimulation. Respectively, the stimulation of -the movement sense by a product is called haptic stimulation or just haptics. -Haptics is also used as general term for all issues related to sense of touch, -both human and machine.

          Haptic feedback, often referred to as "Haptics", -is the use of the sense of touch in a user interface design to provide information -to an end user. In mobile phones, this generally means the use of vibrations -from the device's vibration alarm to denote that a touch screen button has -been pressed. In this particular example, the phone would vibrate slightly -in response to the user's activation of an on-screen control, making up for -the lack of a normal tactile response that the user would experience when -pressing a physical button.

          -
          Characteristics -of haptics related APIs

          You can use the following APIs to create -haptic effects:

            -
          • Tactile Feedback -Client API

              -
            • Available from S60 5th Edition onwards.

            • -
            • It can be used on all S60 5th Edition or later mobile devices. However, -the feedback is played only on touch enabled layouts.

            • -
            • Provides simple functions for triggering various predefined tactile -feedback (vibration or audio) effects.

            • -
            • Enables a consistent user experience in all applications of the mobile -device (an application gives a logical feedback type as an input and the actual -physical effect depends on the mobile device configuration and end user settings).

            • -
            • When the area feedback is used, latency is low for the feedback triggering -(a tactile feedback can already be triggered at the window server level prior -to the corresponding pointer event being delivered to the visible application).

            • -
            • Direct feedback can be easily integrated into CCoeControl::HandlePointerEventL().

            • -
            • An application can select the logical tactile feedback from certain -types. The produced effect may be different on various mobile devices.

            • -
          • -
          • Haptics -API

              -
            • Available from S60 5th Edition, FP2 onwards.

            • -
            • It can be used in touch and hybrid mobile devices.

            • -
            • Provides an interface for accessing Haptics player that can control -different actuator types.

            • -
            • Enables producing of complex vibrator effects, such as an explosion -or machine gun effect in a game, bass boost for a music player, advanced ringing -tone vibration, and so on.

            • -
            • Enables simultaneous playing of different kinds of basis effects and -modifying them when played.

            • -
            • Allows the design of complex effects (using a separate PC application) -that can be loaded on Haptics player for playing.

            • -
            • It may require a special license key for third-party applications -(to be set at runtime) to enable the Haptics player functionality.

            • -
          • -
          • Vibra API

              -
            • Available from S60 3.0 onwards.

            • -
            • It can be used for running device vibrator with given intensity for -a given period of time.

            • -
            • It can be used by a privileged client application to play pulse effects, -which have a very short duration (as the ones used for tactile feedback).

            • -
          • -
          -
          When to use -Tactile Feedback Client API, Haptics API, and Vibra API

            -
          • Tactile Feedback Client API for providing tactile feedback in custom -controls (grids, lists, and so on), which will comply with the style of Core -UI components to ensure a uniform user experience among applications.

          • -
          • Haptics API on touch and hybrid mobile devices for producing complex -vibration feedback, which cannot be achieved with Tactile Framework (games, -simulations, demos, and so on).

          • -
          • Vibra API for producing haptic effects such as ringing tone vibration -in those mobile devices where Haptics API is not available or functional.

          • -

          -
          Using -tactile feedback in applications

          The API to use for tactile feedback -is the Tactile feedback -client API.

          The Symbian platform includes a tactile feedback -interface to add, modify and remove feedback areas in the registry. There -is also an option to trigger direct feedback and bypass the registry. MTouchFeedback::Instance() is -used for acquiring a pointer to a touch feedback instance. When touch feedback -is activated, the mobile device users get a slight vibration when the control -with the feedback interface is touched.

          Tactile feedback can -be set and disabled in a client application or a mobile device in some scenarios, -for example, during phone calls.

          Client applications cannot determine -the actual physical feedback that is generated. It depends on device configuration -and current settings. In current devices, the user changeable settings include -vibration and audio feedback intensity level.

          For more information, -see Feedback.

          -
          \ No newline at end of file + + + + +Tactile feedback + + + + +

          There are two cases where vibration or audio of the device is used +as an output method:

          +
            +
          • As a tacticon to inform users through physical feedback, +that an important event is occurring in the device. For example, when +a new message arrives or a warning note is displayed.

          • +
          • As tactile feedback to indicate to the user that an +interaction event has been made. For example, users receive tactile +feedback when they press a button on the touch screen.

          • +
          +

          As with sounds, tactile feedback must be used carefully so as not +to desensitize the user to the vibration; the attention grabbing quality +remains and functions so long as the feedback is not too frequent.

          +

          Tactile feedback is enabled for all the Symbian platform UI components. +Tactile feedback can be disabled for the common UI components in an +application. However, this is acceptable only if tactile feedback +causes interference with other device functions.

          +

          The user can choose the level of tactile feedback and turn tacticons +ON and OFF.

          +

          The following table lists the tactile feedback effects:

          +

          +Tactile feedback effects + + + +

          Effects

          +

          Description

          +
          + + + +

          Sensitive button

          +

          Provides single pulse effect on repeated key presses with +buttons. It is also possible with other similar components.

          +
          + +

          Basic button

          +

          Provides stronger single pulse effect to buttons. It is +also possible with other similar components.

          +
          + +

          Sensitive list

          +

          Provides single pulse effect to lists and grids. Effect +is used with move (drag and flick) when new item appears on the screen.

          +
          + +

          Basic list

          +

          Provides stronger single pulse effect to lists and grids. +Effect is used with touch down and release when tap makes an action.

          In hierarchical list, collapsing/expanding item provides basic +list effect with touch down and release.

          +
          + +

          Bounce effect

          +

          Provides pulse effect when list returns to its normal state +after boundary effect.

          +
          + +

          Sensitive slider

          +

          Provides pulse effect with scrollbar and slider thumbs. +Effect is provided with touch down and release in thumb area.

          +
          + +

          Smooth slider

          +

          Provides continuous smooth feedback when dragging scrollbar +or slider thumb. This can also be increasing or decreasing depending +of the slider type.

          +
          + +

          Hold slider

          +

          Provides sensitive pulse effect when touch down and hold +on the slider or scrollbar area. Slider thumb starts moving step by +step towards the touch point. Every step gives one sensitive pulse. +If slider thumb moves directly to the touch point, then basic slider +effect is provided.

          +
          + +

          Pop-up

          +

          Provides sensitive pulse effect when pop-up is opened or +closed. If the theme animations are ON, then pop-up effect is used +with opening event after increasing long touch effect. In this scenario, +there is no pop-up effect . All pop-ups do not have theme animation.

          +
          + +

          Pop-up close

          +

          Provides decreasing smooth feedback a pop-up and when theme +animations are ON.

          +
          + +

          Increasing long touch

          +

          Provides increasing smooth feedback. This can be used with +either long tap animation or pop-up opening theme effects. If the +theme effects are ON and long tap opens a pop-up, then feedback is +provided only with long tap. This is followed by pop-up.

          +
          + +

          Basic tab

          +

          Provides strong pulse effect with touch down event in tab +area.

          +
          + +

          Smooth flick

          +

          Provides smooth feedback with drag when horizontal movement +is possible.

          +
          + +

          Sensitive flick

          +

          Provides sensitive pulse effect with touch release when +horizontal movement is possible.

          +
          + +

          Sensitive edit

          +

          Provides sensitive pulse effect in editors with touch down +and release.

          +
          + +

          Text edit

          +

          Provides pulse effect when painting the text. Effect is +provided with every character while painting the text.

          +
          + +

          Blank edit

          +

          Provides pulse effect when painting blank character. By +default, it is none.

          +
          + +

          Line edit

          +

          Provides pulse effect when painting a line.

          +
          + +

          Empty line

          +

          Provides pulse effect when painting an empty line. By default, +it is none.

          +
          + +

          Check box

          +

          Provides pulse effect when marking/unmarking a check box.

          +
          + +

          Multiple touch recognition

          +

          Provides double pulse (sensitive + sensitive) effect when +multiple touch is recognized (generally, when second finger is touched +down).

          +
          + +

          Smooth pinch

          +

          Provides smooth continuous feedback while moving fingers +in multiple touch pinch situation.

          +
          + +

          Smooth rotate

          +

          Provides smooth continuous feedback while moving fingers +in multiple touch rotate situation.

          +
          + + +

          +
          Haptics +concept

          The different senses associated to the skin are +called cutaneous senses. These senses are temperature, pressure (touch +itself), pain, tickle, itch and vibration senses. We can characterize +touch as passive or active. Passive touch means the sense of touch +itself, whereas active touch means the touch action.

          To communicate +through the sense of touch, we have to stimulate some of the cutaneous +senses or the movement sense. The stimulation of the cutaneous senses +or one of them by a product is called tactile stimulation. Respectively, +the stimulation of the movement sense by a product is called haptic +stimulation or just haptics. Haptics is also used as general term +for all issues related to sense of touch, both human and machine.

          Haptic feedback, often referred to as "Haptics", is the use of +the sense of touch in a user interface design to provide information +to an end user. In mobile phones, this generally means the use of +vibrations from the device's vibration alarm to denote that a touch +screen button has been pressed. In this particular example, the phone +would vibrate slightly in response to the user's activation of an +on-screen control, making up for the lack of a normal tactile response +that the user would experience when pressing a physical button.

          +
          Characteristics +of haptics related APIs

          You can use the following APIs +to create haptic effects:

            +
          • Tactile Feedback Client API

              +
            • Available from S60 5th Edition onwards.

            • +
            • It can be used on all S60 5th Edition or later mobile devices. +However, the feedback is played only on touch enabled layouts.

            • +
            • Provides simple functions for triggering various predefined +tactile feedback (vibration or audio) effects.

            • +
            • Enables a consistent user experience in all applications of +the mobile device (an application gives a logical feedback type as +an input and the actual physical effect depends on the mobile device +configuration and end user settings).

            • +
            • When the area feedback is used, latency is low for the feedback +triggering (a tactile feedback can already be triggered at the window +server level prior to the corresponding pointer event being delivered +to the visible application).

            • +
            • Direct feedback can be easily integrated into CCoeControl::HandlePointerEventL().

            • +
            • An application can select the logical tactile feedback from +certain types. The produced effect may be different on various mobile +devices.

            • +
          • +
          • Haptics API

              +
            • Available from S60 5th Edition, FP2 onwards.

            • +
            • It can be used in touch and hybrid mobile devices.

            • +
            • Provides an interface for accessing Haptics player that can +control different actuator types.

            • +
            • Enables producing of complex vibrator effects, such as an explosion +or machine gun effect in a game, bass boost for a music player, advanced +ringing tone vibration, and so on.

            • +
            • Enables simultaneous playing of different kinds of basis effects +and modifying them when played.

            • +
            • Allows the design of complex effects (using a separate PC application) +that can be loaded on Haptics player for playing.

            • +
            • It may require a special license key for third-party applications +(to be set at runtime) to enable the Haptics player functionality.

            • +
          • +
          • Vibra API

              +
            • Available from S60 3.0 onwards.

            • +
            • It can be used for running device vibrator with given intensity +for a given period of time.

            • +
            • It can be used by a privileged client application to play pulse +effects, which have a very short duration (as the ones used for tactile +feedback).

            • +
          • +
          +
          When +to use Tactile Feedback Client API, Haptics API, and Vibra API

            +
          • Tactile Feedback Client API for providing tactile feedback +in custom controls (grids, lists, and so on), which will comply with +the style of Core UI components to ensure a uniform user experience +among applications.

          • +
          • Haptics API on touch and hybrid mobile devices for producing +complex vibration feedback, which cannot be achieved with Tactile +Framework (games, simulations, demos, and so on).

          • +
          • Vibra API for producing haptic effects such as ringing tone +vibration in those mobile devices where Haptics API is not available +or functional.

          • +

          +
          Using +tactile feedback in applications

          The API to use for tactile +feedback is the Tactile feedback +client API.

          The Symbian platform includes a tactile feedback +interface to add, modify and remove feedback areas in the registry. +There is also an option to trigger direct feedback and bypass the +registry. MTouchFeedback::Instance() is used for +acquiring a pointer to a touch feedback instance. When touch feedback +is activated, the mobile device users get a slight vibration when +the control with the feedback interface is touched.

          Tactile +feedback can be set and disabled in a client application or a mobile +device in some scenarios, for example, during phone calls.

          Client applications cannot determine the actual physical feedback +that is generated. It depends on device configuration and current +settings. In current devices, the user changeable settings include +vibration and audio feedback intensity level.

          For more information, +see Feedback.

          +
          +
          + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/SDK/Source/GUID-6F1ED7D0-5F41-4587-89AA-8DDE7AEC916F.dita --- a/Symbian3/SDK/Source/GUID-6F1ED7D0-5F41-4587-89AA-8DDE7AEC916F.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/SDK/Source/GUID-6F1ED7D0-5F41-4587-89AA-8DDE7AEC916F.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,373 +1,402 @@ - - - - - -What's new in Symbian^3Symbian^3 introduces a lot of new features that enhance -communication, connectivity, multimedia, graphics, security and the -overall usability of Symbian devices. These features benefit operators, -application developers and device creators by making it easier to -create feature-rich devices and applications. -

          If you are moving from a older version of Symbian platform to Symbian^3, -see Porting -applications to Symbian^3.

          - - - - -Technology Domain -New Features - - - - -Data Communications -
            -
          • FreeWay or Three Plane Comms Architecture: The Symbian -platform now supports a new IP networking architecture. The new architecture -significantly improves data flow performance and makes it easier for -third-party developers to integrate new technologies, for example -firewalls and hotspot authenticators. It also implements automatic -roaming between different access points, for example WLAN and GPRS. -For more information, see Goals of the Comms -Architecture.

          • -
          • One-Click Connectivity (OCC): The Symbian platform now -provides a new way of managing data connections on the Symbian platform. -OCC builds on the existing Application Level Roaming (ALR) solution. -This feature makes the user's interaction with "connecting" and "select -access point" dialogs significantly simple and easier. For more information, -see Extended -Connection Preferences.

          • -
          -
          - -Device Connectivity -
            - - - -
          • MTP Device Services Extension Specification: The Symbian -MTP implementation now supports the MTP device services extension -to the Media Transfer Protocol (MTP). For more information, -see MTP Device Services Extension Specification.

          • -
          • AVRCP (Audio/Video Remote Control Profile) v1.4 Support: A Symbian device user can now see music track names and browse playlists -directly from the screen of a AVRCP v1.4 enabled Bluetooth headset -or remote control.

          • -
          • Centralized AT-command Handling: The Symbian platform -now enables all AT commands to be handled using the same mechanism -regardless of the connection type. For more information, refer to -the AT Extension Plug-in API.

          • -
          -
          - -Device Management -
            -
          • Support for Open Mobile Alliance (OMA) Management Objects -(MO): The Symbian platform now supports OMA MO like Software Component -Management Object (SCOMO) v1.0, Device Capability Management Object -(DCMO) v1.0 and Connectivity Management Object (ConnMO). It also supports -Nokia Standard Streaming MO. Some enhancements have been made to Browser -MO and Email MO.

          • -
          • Other Device Management Enhancements: The Symbian platform -now provides an improved device Lock with security and an enhanced -firmware update installation experience.

          • -
          -
          - -Location -
            -
          • Landmark-based URL Parser: The Symbian platform now -supports a parser that converts between landmark objects and URLs. -The parser supports a URL format that is compliant with Ovi Maps. -For more information, see CPosLandmarkParser.

          • -
          • New Management Object (MO) for A-GPS: The Symbian platform -now provides an enhancement to Secure User Plane Location (SUPL) now -allows the service provider to provide two access points for a SUPL -server in the MO. This improves the system stability because it acts -as a fallback mechanism in case one of the access points is unavailable.

          • -
          • Support for Application Processor Engine (APE) Centric Location -Architecture: Symbian devices can now use the new architecture -based on the APE that offers standardized session IDs on network privacy -and classes that use the SUPL. The architecture converges technology -from OS, middleware and application software layers.

          • -
          • Support for Location Based Services (LBS) SUPL Positioning -Module (PSY): The Symbian platform now enables the LBS SUPL PSY -to allow GPS-enabled devices to handle network-based SUPL location -requests. This includes Cell ID based positioning and assistance data -exchange as part of SUPL v2.0. .

          • -
          • Support for GPSCost5.0D and GPSCost4.0D GPS chipsets: The Symbian platform now uses the APE-centric architecture to support -GPSCost5.0D and GPSCost4.0D chipsets. A new A-GPS Nokia Positioning -Engine (NPE) integration module replaces the OS LBS subsystem reference -A-GPS version.

          • -
          • Support for LBS SUPL Radio Resource LCS Protocol (RRLP): The Symbian platform now uses the APE-centric architecture to support -NPE and RRLP on GPS-enabled device.

          • -
          • SUPL 2.0 Trigger Support: The Symbian platform now provides -SUPL 2.0 trigger support that allows the requester to receive location -updates periodically, which is both network and device initiated.

          • -
          • Location-based Triggering Enhancements: The Symbian -platform now includes key enhancements that enable integration with -an Context framework to develop plug-ins and increase support for -total and active triggers. An enhanced, dedicated common gateway interface -enables the client to provide multiple CGIs to create a trigger, which -is fired on successful matching with at least one CGI.

          • -
          • Enhanced Location Acquisition API to support LocationKnownPositionArea.

          • -
          • Here and Now: The Symbian platform now includes Here -and now that offers easy-to-use Web services related to the user's -current location. Here and now allows the user to check the local -weather and get other topical information while on the move.

          • -
          -
          - -Multimedia -
            -
          • Mobile TV DVB-H Receiver HAI: Mobile TV Receiver is -a small internal system but does so much more than traditional TV. -It is broadcasted in a multi-grounded environment with high speed -by using low battery power and low memory usage. .

          • -
          • OpenMAX IL: OpenMAX IL is a low-level interface used -in mobile devices that allows the Multimedia Device Framework (MDF) -to load, control, connect and unload audio, video and imaging components. .

          • -
          • Thin Adaptation of A3F DevSound: The A3F DevSound is -one of the key component in the Sound Device collection that provides -access to the hardware accelerator in audio technology. For more information, -see A3F DevSound -Component.

          • -
          • Image Processor library: The Image Processor is an independent -and high-level API and framework which is developed for mobile imaging. -The Image Processor has some pluggable advanced image editing libraries -to perform the Panoramic Stitching function and the Speed View function. -For more information, see Image Processor Library.

          • -
          • Camera API Extensions: The Camera API is extended to -support the features such as background processing, continuous digital -zooming, time nudge image capturing and automatic aperture setting. -For more information, see Camera Library.

          • -
          • Camera Support for Video Encoding: The Camera supports -mobile device to capture video frames which are encoded in the H264 -format. For more information, see Using the Encoded -H264 Video Frames to Capture Video.

          • -
          • 3GP File Format Library: The 3GP Library component is -a Multimedia plug-in which supports for reading and writing 3GP, 3G2, -and MP4 files. The 3GP Library is also extended to support larger -3GP or MP4 files. .

          • -
          • Video Playback from Non-user Interface Thread: Media -Client Video Display is a standalone library used by the Video Client -library to support video playback. For more information, see Media Client Video -Display Library.

          • -
          • Video Subtitle CRP: Displays artwork on a video window -using the Video Subtitle CRP component. The Subtitle Graphic library -displays subtitles artwork on the screen through its interaction with -Client Process, Controller Process and WServ Process. For more information, -see Video Subtitle -CRP Component.

          • -
          • Dolby Digital Audio Support: The Symbian platform now -supports codecs that enable support for Dolby Digital Audio on Symbian -devices.

          • -
          • True Pause in Audio Playback: In the audio playback -request the true pause feature is implemented to stop the audio data -at the physical sound device without stopping the buffer traffic. -For more information, see Pausing and Resuming -Audio Play.

          • -
          • Global Surface Updates: The Video Render component is -extended to support the global surface updates. For more information, -see Global -Surface Updates.

          • -
          • Metadata Utility Library: The Metadata Utility library -belongs to the Metadata Utility Framework (MUF) component that provides -fast metadata access to audio, video and image media files. For more -information, see the Metadata Utility -Library section.

          • -
          • UI Patterns or Thumbnails Enhancement: This is a Multimedia -specific pattern enhancement, which includes many UI (User Interface) -features, listed below:

              -
            • Multiple customized Home Screens with 6 different widget enabled -screens.

            • -
            • Pinch zoom, kinetic scrolling and single-click features.

            • -
            • Good screen view with a new UI theme, and renewed icons.

            • -
            • Hardware acceleration with fast and responsive UI that creates -new transition effects.

            • -
            • Multitasking with Teleport visual task swapper.

            • -
            • Intelligent slide functionality for Hybrid touch and QWERTY -slider devices. Video Graphics Array (VGA) Touch supports for VGA -QWERTY mono blocks.

            • -
            • VGA Touch helps to control Music player.

            • -
          • -
          • Mobile TV: Mobile TV uses DVB-H receiver to consume -broadcast digital mobile television. The Symbian platform provides -fast and easy access to all videos and TV media content. One key press -opens videos and TV application suite, and user scrolls and selects -the desired video functionality. This media experience is built with -major components such as Videos and TV, video player and Mobile TV. -Videos and TV support high quality video up to 720 per resolution -at 12 Mbps and 30 frames per second.

          • -
          • Image Viewer Application: The Image Viewer application -is used when the client opens an image file for viewing. File Manager, -Messaging, Camcorder and Browser S60 components use the Image Viewer -application. It supports Extended ICL JPEG API, which enables a faster -and less memory-consuming way to rotate and zoom images.

          • -
          • FM Radio: The FM Radio application is used to listen -FM radio broadcast over the air. FM radio broadcast is a free service.

          • -
          • Video Sharing: Using the video sharing service, both -call users can start sharing their device live camera view or pre-recorded -video clip during a normal circuit switched (CS) voice call. The video -sharing feature allows the user to upgrade and downgrade their call -with one-way video at times of need. The video sharing application -uses the Multimedia Comms Engine API.

          • -
          -
          - -Multimedia Applications -
            -
          • High-Definition Multimedia Interface (HDMI): The Symbian -platform now supports HDMI technology. HDMI is supported as an external -accessory for audio and video playback for a great television playback -experience. It provides improved data performance and is ideal for -streaming high definition audio and video. The 720p resolution is -supported in still image and video viewing. 5+1 channel audio is also -supported.

          • -
          • Home Music Widgets: The Symbian platform now provides -music information through Home Screen Music Widgets. The Home Music -Widgets controls from the Home Screen menu system enables to play -and pause the playing track. The Music Widget supports the Radio Player -and includes the Music Suite Matrix Menu. This menu is configured -through XML and by default supports to launch the functionality listed -below:

              -
            • The last played song

            • -
            • The music collection view

            • -
            • A music shop, or to open the FM radio

            • -
          • -
          • Fusion Player Application: The Symbian platform now -introduces the Fusion Player, which replaces the existing Media Player -and Video Center applications. It enables access to both online video -services and locally stored videos. If DVB-H device is available, -live TV viewing is also possible. The main features supported by the -Fusion player application are as follows:

              -
            • To browse stored videos and to see metadata features of the -video, such as title, thumbnail DRM info, size or play-time.

            • -
            • To check videos that are pre-installed with the device.

            • -
            • To play stored video file in the device.

            • -
          • -
          -
          - -OS Base Services -
            -
          • Writable Data Paging (WDP): The Symbian platform now -supports WDP. This enables efficient use of memory and allows multiple -applications to run at the same time without physically adding more -RAM to the hardware. This leads to a more responsive system when switching -between a number of running applications. .

          • -
          • Symmetric multiprocessor (SMP): The Symbian platform -now supports SMP for multi-core processors, such as the ARM Cortex -A9. This allows device integrators to prototype and prove ARM-based -SMP platforms.

          • -
          • 64-bit file server: The Symbian platform now supports -files larger than 2 GB.

          • -
          -
          - -Productivity -
            -
          • Nokia Messaging for Social Networks: Nokia Messaging -Social Networking service is a Nokia-hosted consumer service that -provides easy and affordable mobile access to popular social networking -communities.

          • -
          • Enhanced Calendar UI Architecture: Calendar UI architecture -has changed to improve flexibility of calendar for regional, religious, -custom-tailors and xSP calendar service needs. Multiple storages are -also supported. For more information, see Calendar Guide.

          • -
          • CalDAV Protocol: Calendar application now supports the -CalDAV Protocol, which is an open calendar synchronization standard -contributed by SUN Microsystems. This enables a user to access scheduling -information on remote servers.

          • -
          • Enhanced Contacts Application: The Contacts application -in this release includes the following changes:

              -
            • Integration with social media.

            • -
            • Support for Remote Contacts Lookup, for example, from post-installed -Mail for Exchange account.

            • -
            • Virtual Phonebook API (supports getting access to the user’s -own contact card).

            • -
            • Own contact card.

            • -
          • -
          -
          - -Runtimes -
            -
          • The Symbian platform now supports the Open Source based Java -MIDP 2.1.

          • -
          • The Symbian platform now supports Browser Application v7.2 -(with Web Run Time 7.2) that includes the following features:

              -
            • Browser Control

            • -
            • Browser core features

            • -
            • Browser Customization

            • -
            • Browser plug-ins

            • -
            • Browser with touch screen

            • -
            • Content Download

            • -
            • URI Schemes

            • -
            • Display Resolution Optimizations

            • -
            • Optical Finger Navigation (OFN)

            • -
            • FlashLite 3.1

            • -
            • Search Client Integration

            • -
            • Expanding Language and Character Set Support

            • -
            • Improved Security Prompting

            • -
            • Updated Platform Service APIs

            • -
            • Visual Task Swapper Support

            • -
            • Performance Optimizations

            • -
            • Multi-touch/pinch zooming

            • -
          • -
          -
          - -Security -The Symbian platform now provides an enhanced Security subsystem -that enables device creators to integrate hardware acceleration modules, -which improves the performance of cryptographic algorithms. This is -particularly valuable in intensive real-time use-cases, such as streaming -audio or video over a secure link, where bulk data needs to be encrypted -and decrypted. - - -User Interface -
            -
          • ScreenPlay, also known as the New Graphics Architecture -(NGA): This new graphics architecture enables device creators -to take advantage of improved software performance, hardware acceleration -and third party graphics engines. It makes it possible to combine -UI components, graphics and video to create highly innovative UIs. -For more information, see The ScreenPlay Graphics -Architecture.

          • - - -
          • Multi-Touch Support: The ScreenPlay version of the Window -Server has been extended to support multiple advanced pointers, with -support for proximity and pressure. The emulator now also supports -multiple advanced pointers. For more information, see Advanced Pointers.

          • - -
          • Enhanced Touch UI: The touch UI includes the following -improvements:

              -
            • Multi-page Home Screen enables the user to navigate between -widgets with a simple flick gesture

            • -
            • Capacitive multi-touch events are supported.

            • -
            • Tactile Feedback utilizes advanced haptics effects.

            • -
          • -

          For more information about the new features in Graphics, see What's New in Graphics -in Symbian^3.

          -
          - - -
          - -New -C++ APIs in Symbian^3 -Porting -applications to Symbian^3 -Introduction -to Symbian^3 - -
          \ No newline at end of file + + + + +What's new in Symbian^3 +Symbian^3 introduces a lot of new features that enhance +communication, connectivity, multimedia, graphics, security and the +overall usability of Symbian devices. These features benefit operators, +application developers and device creators by making it easier to +create feature-rich devices and applications. + + + + +

          If you are moving from a older version of Symbian platform to Symbian^3, +see Porting +applications to Symbian^3.

          + + + + +Technology Domain +New Features + + + + +Data Communications +
            +
          • FreeWay or Three Plane Comms Architecture: The Symbian +platform now supports a new IP networking architecture. The new architecture +significantly improves data flow performance and makes it easier for +third-party developers to integrate new technologies, for example +firewalls and hotspot authenticators. It also implements automatic +roaming between different access points, for example WLAN and GPRS. +For more information, see Goals of the +Comms Architecture.

          • +
          • One-Click Connectivity (OCC): The Symbian platform now +provides a new way of managing data connections on the Symbian platform. +OCC builds on the existing Application Level Roaming (ALR) solution. +This feature makes the user's interaction with "connecting" and "select +access point" dialogs significantly simple and easier. For more information, +see Extended +Connection Preferences.

          • +
          +
          + +Device Connectivity +
            +
          • MTP Device Services Extension Specification: The Symbian +MTP implementation now supports the MTP device services extension +to the Media Transfer Protocol (MTP). For more information, see MTP Device Services Extension Specification.

          • +
          • AVRCP (Audio/Video Remote Control Profile) v1.4 Support: A Symbian device user can now see music track names and browse playlists +directly from the screen of a AVRCP v1.4 enabled Bluetooth headset +or remote control.

          • +
          • Centralized AT-command Handling: The Symbian platform +now enables all AT commands to be handled using the same mechanism +regardless of the connection type. For more information, refer to +the AT Extension Plug-in API.

          • +
          +
          + +Device Management +
            +
          • Support for Open Mobile Alliance (OMA) Management Objects +(MO): The Symbian platform now supports OMA MO like Software Component +Management Object (SCOMO) v1.0, Device Capability Management Object +(DCMO) v1.0 and Connectivity Management Object (ConnMO). It also supports +Nokia Standard Streaming MO. Some enhancements have been made to Browser +MO and Email MO.

          • +
          • Other Device Management Enhancements: The Symbian platform +now provides an improved device Lock with security and an enhanced +firmware update installation experience.

          • +
          +
          + +Location +
            +
          • Landmark-based URL Parser: The Symbian platform now +supports a parser that converts between landmark objects and URLs. +The parser supports a URL format that is compliant with Ovi Maps. +For more information, see CPosLandmarkParser.

          • +
          • New Management Object (MO) for A-GPS: The Symbian platform +now provides an enhancement to Secure User Plane Location (SUPL) now +allows the service provider to provide two access points for a SUPL +server in the MO. This improves the system stability because it acts +as a fallback mechanism in case one of the access points is unavailable.

          • +
          • Support for Application Processor Engine (APE) Centric Location +Architecture: Symbian devices can now use the new architecture +based on the APE that offers standardized session IDs on network privacy +and classes that use the SUPL. The architecture converges technology +from OS, middleware and application software layers.

          • +
          • Support for Location Based Services (LBS) SUPL Positioning +Module (PSY): The Symbian platform now enables the LBS SUPL PSY +to allow GPS-enabled devices to handle network-based SUPL location +requests. This includes Cell ID based positioning and assistance data +exchange as part of SUPL v2.0. .

          • +
          • Support for GPSCost5.0D and GPSCost4.0D GPS chipsets: The Symbian platform now uses the APE-centric architecture to support +GPSCost5.0D and GPSCost4.0D chipsets. A new A-GPS Nokia Positioning +Engine (NPE) integration module replaces the OS LBS subsystem reference +A-GPS version.

          • +
          • Support for LBS SUPL Radio Resource LCS Protocol (RRLP): The Symbian platform now uses the APE-centric architecture to support +NPE and RRLP on GPS-enabled device.

          • +
          • SUPL 2.0 Trigger Support: The Symbian platform now provides +SUPL 2.0 trigger support that allows the requester to receive location +updates periodically, which is both network and device initiated.

          • +
          • Location-based Triggering Enhancements: The Symbian +platform now includes key enhancements that enable integration with +an Context framework to develop plug-ins and increase support for +total and active triggers. An enhanced, dedicated common gateway interface +enables the client to provide multiple CGIs to create a trigger, which +is fired on successful matching with at least one CGI.

          • +
          • Enhanced Location Acquisition API to support LocationKnownPositionArea.

          • +
          • Here and Now: The Symbian platform now includes Here +and now that offers easy-to-use Web services related to the user's +current location. Here and now allows the user to check the local +weather and get other topical information while on the move.

          • +
          +
          + +Multimedia +
            +
          • Mobile TV DVB-H Receiver HAI: Mobile TV Receiver is +a small internal system but does so much more than traditional TV. +It is broadcasted in a multi-grounded environment with high speed +by using low battery power and low memory usage. .

          • +
          • OpenMAX IL: OpenMAX IL is a low-level interface used +in mobile devices that allows the Multimedia Device Framework (MDF) +to load, control, connect and unload audio, video and imaging components. +.

          • +
          • Thin Adaptation of A3F DevSound: The A3F DevSound is +one of the key component in the Sound Device collection that provides +access to the hardware accelerator in audio technology. For more information, +see A3F +DevSound Component.

          • +
          • Image Processor library: The Image Processor is an independent +and high-level API and framework which is developed for mobile imaging. +The Image Processor has some pluggable advanced image editing libraries +to perform the Panoramic Stitching function and the Speed View function. +For more information, see Image Processor +Library.

          • +
          • Camera API Extensions: The Camera API is extended to +support the features such as background processing, continuous digital +zooming, time nudge image capturing and automatic aperture setting. +For more information, see Camera Library.

          • +
          • Camera Support for Video Encoding: The Camera supports +mobile device to capture video frames which are encoded in the H264 +format. For more information, see Using the Encoded +H264 Video Frames to Capture Video.

          • +
          • 3GP File Format Library: The 3GP Library component is +a Multimedia plug-in which supports for reading and writing 3GP, 3G2, +and MP4 files. The 3GP Library is also extended to support larger +3GP or MP4 files. .

          • +
          • Video Playback from Non-user Interface Thread: Media +Client Video Display is a standalone library used by the Video Client +library to support video playback. For more information, see Media Client +Video Display Library.

          • +
          • Video Subtitle CRP: Displays artwork on a video window +using the Video Subtitle CRP component. The Subtitle Graphic library +displays subtitles artwork on the screen through its interaction with +Client Process, Controller Process and WServ Process. For more information, +see Video +Subtitle CRP Component.

          • +
          • Dolby Digital Audio Support: The Symbian platform now +supports codecs that enable support for Dolby Digital Audio on Symbian +devices.

          • +
          • True Pause in Audio Playback: In the audio playback +request the true pause feature is implemented to stop the audio data +at the physical sound device without stopping the buffer traffic. +For more information, see Pausing and +Resuming Audio Play.

          • +
          • Global Surface Updates: The Video Render component is +extended to support the global surface updates. For more information, +see Global +Surface Updates.

          • +
          • Metadata Utility Library: The Metadata Utility library +belongs to the Metadata Utility Framework (MUF) component that provides +fast metadata access to audio, video and image media files. For more +information, see the Metadata Utility +Library section.

          • +
          • UI Patterns or Thumbnails Enhancement: This is a Multimedia +specific pattern enhancement, which includes many UI (User Interface) +features, listed below:

              +
            • Multiple customized Home Screens with 6 different widget enabled +screens.

            • +
            • Pinch zoom, kinetic scrolling and single-click features.

            • +
            • Good screen view with a new UI theme, and renewed icons.

            • +
            • Hardware acceleration with fast and responsive UI that creates +new transition effects.

            • +
            • Multitasking with Teleport visual task swapper.

            • +
            • Intelligent slide functionality for Hybrid touch and QWERTY +slider devices. Video Graphics Array (VGA) Touch supports for VGA +QWERTY mono blocks.

            • +
            • VGA Touch helps to control Music player.

            • +
          • +
          • Mobile TV: Mobile TV uses DVB-H receiver to consume +broadcast digital mobile television. The Symbian platform provides +fast and easy access to all videos and TV media content. One key press +opens videos and TV application suite, and user scrolls and selects +the desired video functionality. This media experience is built with +major components such as Videos and TV, video player and Mobile TV. +Videos and TV support high quality video up to 720 per resolution +at 12 Mbps and 30 frames per second.

          • +
          • Image Viewer Application: The Image Viewer application +is used when the client opens an image file for viewing. File Manager, +Messaging, Camcorder and Browser S60 components use the Image Viewer +application. It supports Extended ICL JPEG API, which enables a faster +and less memory-consuming way to rotate and zoom images.

          • +
          • FM Radio: The FM Radio application is used to listen +FM radio broadcast over the air. FM radio broadcast is a free service.

          • +
          • Video Sharing: Using the video sharing service, both +call users can start sharing their device live camera view or pre-recorded +video clip during a normal circuit switched (CS) voice call. The video +sharing feature allows the user to upgrade and downgrade their call +with one-way video at times of need. The video sharing application +uses the Multimedia Comms Engine API.

          • +
          +
          + +Multimedia Applications +
            +
          • High-Definition Multimedia Interface (HDMI): The Symbian +platform now supports HDMI technology. HDMI is supported as an external +accessory for audio and video playback for a great television playback +experience. It provides improved data performance and is ideal for +streaming high definition audio and video. The 720p resolution is +supported in still image and video viewing. 5+1 channel audio is also +supported.

          • +
          • Home Music Widgets: The Symbian platform now provides +music information through Home Screen Music Widgets. The Home Music +Widgets controls from the Home Screen menu system enables to play +and pause the playing track. The Music Widget supports the Radio Player +and includes the Music Suite Matrix Menu. This menu is configured +through XML and by default supports to launch the functionality listed +below:

              +
            • The last played song

            • +
            • The music collection view

            • +
            • A music shop, or to open the FM radio

            • +
          • +
          • Fusion Player Application: The Symbian platform now +introduces the Fusion Player, which replaces the existing Media Player +and Video Center applications. It enables access to both online video +services and locally stored videos. If DVB-H device is available, +live TV viewing is also possible. The main features supported by the +Fusion player application are as follows:

              +
            • To browse stored videos and to see metadata features of the +video, such as title, thumbnail DRM info, size or play-time.

            • +
            • To check videos that are pre-installed with the device.

            • +
            • To play stored video file in the device.

            • +
          • +
          +
          + +OS Base Services +
            +
          • Writable Data Paging (WDP): The Symbian platform now +supports WDP. This enables efficient use of memory and allows multiple +applications to run at the same time without physically adding more +RAM to the hardware. This leads to a more responsive system when switching +between a number of running applications. .

          • +
          • Symmetric multiprocessor (SMP): The Symbian platform +now supports SMP for multi-core processors, such as the ARM Cortex +A9. This allows device integrators to prototype and prove ARM-based +SMP platforms.

          • +
          • 64-bit file server: The Symbian platform now supports +files larger than 2 GB.

          • +
          +
          + +Productivity +
            +
          • Nokia Messaging for Social Networks: Nokia Messaging +Social Networking service is a Nokia-hosted consumer service that +provides easy and affordable mobile access to popular social networking +communities.

          • +
          • Enhanced Calendar UI Architecture: Calendar UI architecture +has changed to improve flexibility of calendar for regional, religious, +custom-tailors and xSP calendar service needs. Multiple storages are +also supported. For more information, see Calendar Guide.

          • +
          • CalDAV Protocol: Calendar application now supports the +CalDAV Protocol, which is an open calendar synchronization standard +contributed by SUN Microsystems. This enables a user to access scheduling +information on remote servers.

          • +
          • Enhanced Contacts Application: The Contacts application +in this release includes the following changes:

              +
            • Integration with social media.

            • +
            • Support for Remote Contacts Lookup, for example, from post-installed +Mail for Exchange account.

            • +
            • Virtual Phonebook API (supports getting access to the user’s +own contact card).

            • +
            • Own contact card.

            • +
          • +
          +
          + +Runtimes +
            +
          • The Symbian platform now supports the Open Source based Java +MIDP 2.1.

          • +
          • The Symbian platform now supports Browser Application v7.2 +(with Web Run Time 7.2) that includes the following features:

              +
            • Browser Control

            • +
            • Browser core features

            • +
            • Browser Customization

            • +
            • Browser plug-ins

            • +
            • Browser with touch screen

            • +
            • Content Download

            • +
            • URI Schemes

            • +
            • Display Resolution Optimizations

            • +
            • Optical Finger Navigation (OFN)

            • +
            • FlashLite 3.1

            • +
            • Search Client Integration

            • +
            • Expanding Language and Character Set Support

            • +
            • Improved Security Prompting

            • +
            • Updated Platform Service APIs

            • +
            • Visual Task Swapper Support

            • +
            • Performance Optimizations

            • +
            • Multiple touch/pinch zooming

            • +
          • +
          +
          + +Security +The Symbian platform now provides an enhanced Security subsystem +that enables device creators to integrate hardware acceleration modules, +which improves the performance of cryptographic algorithms. This is +particularly valuable in intensive real-time use-cases, such as streaming +audio or video over a secure link, where bulk data needs to be encrypted +and decrypted. + + +User Interface +
            +
          • ScreenPlay, also known as the New Graphics Architecture +(NGA): This new graphics architecture enables device creators +to take advantage of improved software performance, hardware acceleration +and third party graphics engines. It makes it possible to combine +UI components, graphics and video to create highly innovative UIs. +For more information, see The ScreenPlay +Graphics Architecture.

          • +
          • Multiple Touch Support: The ScreenPlay version of the +Window Server has been extended to support multiple advanced pointers, +with support for proximity and pressure. The emulator now also supports +multiple advanced pointers. For more information, see Advanced Pointers.

          • +
          • Enhanced Touch UI: The touch UI includes the following +improvements:

              +
            • Multi-page Home Screen enables the user to navigate between +widgets with a simple flick gesture

            • +
            • Capacitive multiple touch events are supported.

            • +
            • Tactile Feedback utilizes advanced haptics effects.

            • +
          • +

          For more information about the new features in Graphics, see What's New in +Graphics in Symbian^3.

          +
          + + +
          +
          + + +New C++ APIs in Symbian^3 +Porting applications to Symbian^3 +Introduction to Symbian^3 + + +
          + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/SDK/Source/GUID-9126A296-0301-4077-A183-3D703F77C548.dita --- a/Symbian3/SDK/Source/GUID-9126A296-0301-4077-A183-3D703F77C548.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/SDK/Source/GUID-9126A296-0301-4077-A183-3D703F77C548.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,90 +1,113 @@ - - - - - -Multi-Touch -Support in the Emulator OverviewThis topic provides an overview of multi-touch support in the emulator. -Two mice are used to provide two independent pointer positions. The emulator -responds to the mice’s individual button-clicks, moves, and mouse wheel scrolls -as if two human fingers are moving, touching or hovering over the screen. -

          The emulator can be extended to support more than two mice or other pointer -devices.

          -

          Variant: ScreenPlay. Target -audience: Application developers.

          -

          The following figure shows two Windows pointers on the emulator screen, -each representing a mouse device. The ordinal integer (starting from 0) beside -each pointer is the unique device identifier. The position of each mouse on -the screen is represented by the X and Y coordinates. The pressure (a positive -value) and proximity (a negative value) information captured by the mouse -wheel is represented by the Z coordinate. Notice that the status bar shows -the identifier and the dynamic X, Y and Z values of each pointer.

          - -Two pointers are displayed in the emulator - - -

          The delivery of pointer events from the emulator driver to the Window Server -is the same in the multi-touch environment as in the single pointer environment. -This means the raw events for a mouse move, button click and mouse wheel movement -are delivered to the Window Server as usual. Each mouse has a unique device -identifier, which makes it possible to ascertain which mouse the events relate -to. The raw events for each individual mouse include the following:

          -
            -
          • TRawEvent::EPointerMove indicates a mouse move or -a mouse wheel movement event.

          • -
          • TRawEvent::EButton1Down indicates that the left mouse -button is pressed down.

          • -
          • TRawEvent::EButton1Up indicates that the left mouse -button is released.

          • -
          • TRawEvent::EPointerOutOfRange indicates that the proximity -of a mouse is out of range. This means that the Z coordinate value of the -mouse has reached HALData::EPointer3DMaxProximity.

          • -
          -
          Pressure -and proximity emulation

          The Z coordinate value is used to represent -the pressure and proximity to the screen. In the emulator, the Z value is -captured and tuned by the mouse wheel movement.

            -
          • Z < 0 indicates the proximity of the device from the screen.

          • -
          • Z > 0 indicates pressure.

          • -

          See Advanced -Pointer Overview for more information about pressure and proximity.

          The -mouse wheel combines the features of a wheel and a mouse button. The wheel -has discrete, evenly spaced notches. Rotating the wheel backwards or forwards -has the effect of changing the pressure or proximity.

            -
          • When the mouse wheel is rotated, a device-specific message is sent -to the emulator window that has focus as each notch is encountered.

          • -
          • The Z coordinate is initiated as 0. Then when the wheel is moved forward, -the Z value enters the pressure range and increases by one pressure step. -When the wheel is moved backward, the Z value enters the proximity range and -decreases by one proximity step.

            The pressure or proximity step can -be customized in the epoc.ini file. See Enabling -Multi-Touch in the Emulator Tutorial for more information.

          • -
          • When the Z value is in the pressure range (Z > 0), moving the wheel -forward by one notch increases Z by one pressure step. Moving the wheel backward -by one notch decreases Z by one pressure step, until Z returns to 0.

          • -
          • When the Z value is in the proximity range (Z < 0), moving the wheel -backward by one notch decreases Z by one proximity step. Moving the wheel -forward by one notch increases Z by one proximity step, until Z returns to -0.

          • -
          • There are limits to the values of the Z coordinate. This -means that the Symbian emulator does not allow Z to exceed the upper boundary HALData::EPointer3DMaxPressure (a -positive value) and lower boundary HALData::EPointer3DMaxProximity (a -negative value). If Z is at the lower boundary, when the mouse wheel is moved -backward next time, Z does not change. A new Out of Range pointer -event is generated and sent to the Window Server. Similarly when Z is at the -upper boundary, Z does not change when the mouse wheel is moved forward.

          • -
          • When the mouse button down or up event (TRawEvent::EButton1Down or TRawEvent::EButton1Up) -is generated, Z is reset to 0.

          • -
          -
          -Advanced -Pointers -Enabling -Multi-Touch in the Emulator Tutorial -
          \ No newline at end of file + + + + +Support for Multiple Pointers in the Emulator Overview +This topic provides an overview of support for multiple +pointers in the emulator. Two mice are used to provide two independent +pointer positions. The emulator responds to the mice’s individual +button-clicks, moves, and mouse wheel scrolls as if two human fingers +are moving, touching or hovering over the screen. + + + + +

          The emulator can be extended to support more than two mice or other +pointer devices.

          +

          Variant: ScreenPlay. Target audience: Application developers.

          +

          The following figure shows two Windows pointers on the emulator +screen, each representing a mouse device. The ordinal integer (starting +from 0) beside each pointer is the unique device identifier. The position +of each mouse on the screen is represented by the X and Y coordinates. +The pressure (a positive value) and proximity (a negative value) information +captured by the mouse wheel is represented by the Z coordinate. Notice +that the status bar shows the identifier and the dynamic X, Y and +Z values of each pointer.

          + +Two pointers are displayed in the emulator + +

          The delivery of pointer events from the emulator driver to the +Window Server is the same when there are multiple pointers as in the +single pointer environment. This means the raw events for a mouse +move, button click and mouse wheel movement are delivered to the Window +Server as usual. Each mouse has a unique device identifier, which +makes it possible to ascertain which mouse the events relate to. The +raw events for each individual mouse include the following:

          +
            +
          • TRawEvent::EPointerMove indicates a mouse +move or a mouse wheel movement event.

          • +
          • TRawEvent::EButton1Down indicates that the +left mouse button is pressed down.

          • +
          • TRawEvent::EButton1Up indicates that the left +mouse button is released.

          • +
          • TRawEvent::EPointerOutOfRange indicates that +the proximity of a mouse is out of range. This means that the Z coordinate +value of the mouse has reached HALData::EPointer3DMaxProximity.

          • +
          +
          Pressure and proximity emulation

          The Z coordinate +value is used to represent the pressure and proximity to the screen. +In the emulator, the Z value is captured and tuned by the mouse wheel +movement.

            +
          • Z < 0 indicates the proximity of the device from the screen.

          • +
          • Z > 0 indicates pressure.

          • +

          See Advanced Pointer Overview for more information about pressure +and proximity.

          The mouse wheel combines the features of a wheel +and a mouse button. The wheel has discrete, evenly spaced notches. +Rotating the wheel backwards or forwards has the effect of changing +the pressure or proximity.

            +
          • When the mouse wheel is rotated, a device-specific message +is sent to the emulator window that has focus as each notch is encountered.

          • +
          • The Z coordinate is initiated as 0. Then when the wheel is +moved forward, the Z value enters the pressure range and increases +by one pressure step. When the wheel is moved backward, the Z value +enters the proximity range and decreases by one proximity step.

            The pressure or proximity step can be customized in the epoc.ini file. See Enabling Multiple +Pointers in the Emulator Tutorial for more information.

          • +
          • When the Z value is in the pressure range (Z > 0), moving the +wheel forward by one notch increases Z by one pressure step. Moving +the wheel backward by one notch decreases Z by one pressure step, +until Z returns to 0.

          • +
          • When the Z value is in the proximity range (Z < 0), moving +the wheel backward by one notch decreases Z by one proximity step. +Moving the wheel forward by one notch increases Z by one proximity +step, until Z returns to 0.

          • +
          • There are limits to the values of the Z coordinate. This means +that the Symbian emulator does not allow Z to exceed the upper boundary HALData::EPointer3DMaxPressure (a positive +value) and lower boundary HALData::EPointer3DMaxProximity (a negative +value). If Z is at the lower boundary, when the mouse wheel is moved +backward next time, Z does not change. A new Out of Range pointer event is generated and sent to the Window Server. Similarly +when Z is at the upper boundary, Z does not change when the mouse +wheel is moved forward.

          • +
          • When the mouse button down or up event (TRawEvent::EButton1Down or TRawEvent::EButton1Up) is generated, Z is reset +to 0.

          • +
          +
          + +Advanced Pointers +Enabling Multiple Pointers in the Emulator Tutorial + + +
          + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/SDK/Source/GUID-930F1E88-2A03-4BD1-AA2A-3A0128A844BD.dita --- a/Symbian3/SDK/Source/GUID-930F1E88-2A03-4BD1-AA2A-3A0128A844BD.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/SDK/Source/GUID-930F1E88-2A03-4BD1-AA2A-3A0128A844BD.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,58 +1,76 @@ - - - - - -Enabling -Multi-Touch in the Emulator TutorialThis topic describes how to configure the Symbian emulator to enable -a multi-touch environment. -

          Variant: ScreenPlay. Target -audience: Application developers.

          -

          This topic builds on Multi-Touch -Support in the Emulator Overview.

          -
          Configuring -the emulator

          Make sure that two or more mice are plugged in and -detected on the Windows PC on which the emulator will run. The number of -detected mice can be from two up to the maximum number defined in the HAL HALData::EPointerMaxPointers attribute.

            -
          1. Add the following lines -to the \epoc32\data\epoc.ini file. These lines enable -ScreenPlay and multi-touch.

            SYMBIAN_BASE_USE_GCE ON -EnableMultiTouch ON
          2. -
          3. Specify the MultiTouchProximityStep and MultiTouchPressureStep values in the \epoc32\data\epoc.ini file to define -the proximity and pressure steps.

            MultiTouchProximityStep 10 -MultiTouchPressureStep 200 -

            If the above two options are not defined in the epoc.ini file, -the default proximity and pressure steps are taken from the following HAL -attributes.

            HALData::EPointer3DProximityStep -HALData::EPointer3DPressureStep
          4. -

          Result: Launch the emulator to verify that the mice are detected -and displayed inside the application window area. When you move a mouse or -scroll the mouse wheel, its X, Y and Z values are reflected in the status -bar.

          -
          Enabling -and disabling multi-touch

          Multi-touch is only required by UI applications. -Therefore, multi-touch is enabled inside the orange rectangular area shown -on the following diagram. Inside the area two Windows pointers are displayed. -The one numbered zero is the system pointer and the other is used only for -multi-touch purposes. The first mouse to report events to the emulator is -automatically taken as the primary mouse, which owns the Windows system pointer.

          -Multi-touch area - -

          System pointer. Once the system pointer moves outside multi-touch -area, multi-touch is temporarily disabled and standard emulator pointer behavior -is resumed. This means that only one Windows system pointer is displayed and -it is controlled by both mice.

          Non-system pointer. If the -non-system pointer moves out of the multi-touch area, the pointer just disappears -from the screen. Disabling multi-touch is then not necessary because the system -pointer behaves normally inside the multi-touch area. Moving the non-system -pointer back into the area makes it reappear on the screen.

          -
          -Multi-Touch -Support in the Emulator Overview -
          \ No newline at end of file + + + + +Enabling Multiple Pointers in the Emulator Tutorial +This topic describes how to configure the Symbian emulator +to enable a multiple pointer environment. + + + + +

          Variant: ScreenPlay. Target audience: Application developers.

          +

          This topic builds on Support for +Multiple Pointers in the Emulator Overview.

          +
          Configuring the emulator

          Make sure that two or more mice +are plugged in and detected on the Windows PC on which the emulator +will run. The number of detected mice can be from two up to the maximum +number defined in the HAL HALData::EPointerMaxPointers attribute.

            +
          1. Add the following +lines to the \epoc32\data\epoc.ini file. These +lines enable ScreenPlay and multiple pointers.

            SYMBIAN_BASE_USE_GCE ON +EnableMultiTouch ON
          2. +
          3. Specify the MultiTouchProximityStep and MultiTouchPressureStep values in the \epoc32\data\epoc.ini file to +define the proximity and pressure steps.

            MultiTouchProximityStep 10 +MultiTouchPressureStep 200 +

            If the above two options are not defined in the epoc.ini file, the default proximity and pressure steps +are taken from the following HAL attributes.

            HALData::EPointer3DProximityStep +HALData::EPointer3DPressureStep
          4. +

          Result: Launch the emulator to verify that the mice +are detected and displayed inside the application window area. When +you move a mouse or scroll the mouse wheel, its X, Y and Z values +are reflected in the status bar.

          +
          Enabling and disabling multiple pointers

          Multiple pointers are only required by UI applications. Therefore, +multiple pointers are enabled inside the orange rectangular area shown +on the following diagram. Inside the area two Windows pointers are +displayed. The one numbered zero is the system pointer and the other +is used only for emulating touch with two fingers. The first mouse +to report events to the emulator is automatically taken as the primary +mouse, which owns the Windows system pointer.

          +Multiple pointer area +

          System pointer. Once the +system pointer moves outside the multiple pointer area, multiple pointers +are temporarily disabled and standard emulator pointer behavior is +resumed. This means that only one Windows system pointer is displayed +and it is controlled by both mice.

          Non-system pointer. If the non-system pointer moves out of the multiple pointer area, +the pointer just disappears from the screen. Disabling multiple pointers +is then not necessary because the system pointer behaves normally +inside the multiple pointer area. Moving the non-system pointer back +into the area makes it reappear on the screen.

          +
          + +Support for Multiple Pointers in the Emulator Overview + + +
          + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/SDK/Source/GUID-9C269F45-F160-5A4B-ABF8-896D2A538E3B.dita --- a/Symbian3/SDK/Source/GUID-9C269F45-F160-5A4B-ABF8-896D2A538E3B.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/SDK/Source/GUID-9C269F45-F160-5A4B-ABF8-896D2A538E3B.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,19 +1,241 @@ - - - - - -Advanced Pointer Overview This is an overview of the Window Server extensions that support the use of advanced pointers. These extensions enable mobile devices to respond to events from multiple pointers, including their proximity and pressure. These extensions are available only in ScreenPlay.

          Variant: ScreenPlay. Target audience: Application developers.

          Architecture

          In response to multi-touch pointer movements, an input driver generates a pointer event for each touch. The Window Server changes and delivers the pointer events to the client application, as shown in the following diagram.

          - Pointer events -

          Pointer-related events move from the driver to the application. The TRawEvent, TWsEvent and TPointerEvent classes encapsulate the event information.

          Key concepts/terms

          The following terms are introduced here and are used throughout the advanced pointer documentation:

          Pointer

          A device that points at the screen, for example, a mouse, pen, finger, or touchpad.

          Multi-pointer support

          Handling more than one pointer at the same time.

          Proximity

          Proximity in this context means the distance of the pointer from the mobile device. Sensors detect the value of the proximity of the pointer from the mobile device.

          Pressure

          Pressure in this context is a value that indicates the force applied to the mobile device by the pointer. Sensors detect the value of the pressure of the pointer on the mobile device.

          Logical model of pointing devices

          A logical model is used to handle all of the different pointing devices correctly. In this logical model, the pointer is performing an action when any of the following scenarios occur:

          • An EButton1Down event is sent to the client.

          • EDrag events are sent to the client (optional).

          • An EButton1Up event is sent to the client.

          Pointing devices can be in one of the following states:

          State Description

          Out of range

          Not detected by the device's sensors.

          Up

          Detected by sensors, coordinates available, not performing an action.

          Down

          Detected by sensors, coordinates available, performing an action (as defined above).

          The mapping between these states and physical actions performed by the user vary for different pointing device types (mouse, finger) and different phone models. Here are two example interpretations of physical pointing device states:

          • Mouse. An example interpretation by a driver of the physical state of a mouse is as follows: It is always in the up state except when the left button is pressed, when it is in the down state. It is never out of range.

          • Fingers with proximity support. The following is an example interpretation of finger physical states when the device has proximity support (that is, it can measure the finger's proximity from the screen):

            • Out of range when proximity > 10cm

            • Up when 1cm < proximity <= 10cm

            • Down when proximity <= 1cm

            In this way the finger can perform actions (for example, press buttons, drag items) without touching the screen.

          Multiple pointers

          The system handles multiple pointers at the same time by identifying each one with a number and sending pointer events separately for each of them. A field (iPointerNumber) in the pointer event classes (TRawEvent and the TAdvancedPointerEvent class which extends TPointerEvent) identifies the pointer for which the event occurred. The order and frequency of pointer events depends on the driver of the pointing device.

          On each phone there is a pool of available pointer numbers, ranging from 0 to HALData::EPointerNumberOfPointers - 1. Every time the driver detects a new pointer coming into the range of the device, the driver assigns a number from the pool. After the pointer goes out of the range of the device, the number no longer identifies that particular pointer and the driver sends TRawEvent::EPointer3DOutOfRange with this pointer number. The number is then released back to the pool and may be reused to identify another pointer coming into the device's range.

          Pressure and proximity

          The pressure of the pointer on the screen is represented as a positive integer. The proximity of the pointer to the screen is represented as a negative integer. It is up to the UI Platform to define units of pressure and proximity, which may be non-linear. In the TRawEvent class, pressure and proximity are expressed in terms of the Z coordinate of the pointer. The definition of the Z coordinate is based on the assumption that the pointer is either hovering over the screen (proximity < 0, pressure = 0) or touching the screen (proximity = 0, pressure >= 0):

          • If proximity < 0 and pressure = 0 then the Z coordinate = proximity.

          • If proximity = 0 and pressure >= 0 then the Z coordinate = pressure.

          - Relationships between the pointer proximity, pressure and z - coordinate -
          API summary API Description

          HALData

          Includes z coordinate, pressure precision and number of pointers. Also contains threshold values for proximity and pressure.

          TRawEvent

          Includes the pointer number and a structure for proximity and pressure data.

          RWindowBase

          Enables advanced pointer events for the window.

          TWsEvent

          Supports TAdvancedPointerEvent (derived from TPointerEvent).

          TPointerEvent

          Includes event types for pressing and closeness.

          TAdvancedPointerEvent

          Inherits from TPointerEvent.

          Provides capabilities for pressure, proximity and multi-touch support.

          RWsSession

          Provides get and set methods to manipulate threshold values for proximity and pressure.

          Typical uses
          • Enabling many pointers for a window

            Enables multiple pointers to act on one window.

          • Enabling concurrent control of many objects

            Controls many objects on one or more windows with many pointers.

          • Getting z coordinates from TPointerEvent

            Reads the pressure and proximity values for a pointer.

          • Pinch zooming

            Enables the user to zoom in and out of data by using two fingers to pinch an area of the screen. Pinch zooming is normally used in web-page, map, picture, chart and control applications.

          • Responding to high pressure events

            As the pointer state changes, the pressure value can be checked. When it passes over a threshold value, the Window Server responds appropriately to the client.

          Pointer States and Event - Communication Advanced Pointer - Tutorial
          \ No newline at end of file + + + + +Advanced Pointer Overview +This is an overview of the Window Server extensions that +support the use of advanced pointers. These extensions enable mobile +devices to respond to events from multiple pointers, including their +proximity and pressure. These extensions are available only in ScreenPlay. + + + + +

          Variant: ScreenPlay. Target audience: Application developers.

          +
          Architecture

          In response to multiple pointer movements, an input driver generates +a pointer event for each touch. The Window Server changes and delivers +the pointer events to the client application, as shown in the following +diagram.

          + Pointer events +

          Pointer-related events move from +the driver to the application. The TRawEvent, TWsEvent and TPointerEvent classes encapsulate the event information.

          +
          Key concepts/terms

          The following terms +are introduced here and are used throughout the advanced pointer documentation:

          + +
          Pointer
          +

          A device that points at the screen, for example, a mouse, pen, +finger, or touchpad.

          + +
          Multiple pointer support
          +

          Handling more than one pointer at the same time.

          +
          + +
          Proximity
          +

          Proximity in this context means the distance of the pointer +from the mobile device. Sensors detect the value of the proximity +of the pointer from the mobile device.

          + +
          Pressure
          +

          Pressure in this context is a value that indicates the force +applied to the mobile device by the pointer. Sensors detect the value +of the pressure of the pointer on the mobile device.

          +
          +
          +
          Logical model of pointing devices

          A logical +model is used to handle all of the different pointing devices correctly. +In this logical model, the pointer is performing an action when +any of the following scenarios occur:

            +
          • An EButton1Down event is sent to the client.

          • +
          • EDrag events are sent to the client (optional).

          • +
          • An EButton1Up event is sent to the client.

          • +

          Pointing devices can be in one of the following states:

          + + + +State +Description + + + + +

          Out of range

          +

          Not detected by the device's sensors.

          +
          + +

          Up

          +

          Detected by sensors, coordinates available, not performing +an action.

          +
          + +

          Down

          +

          Detected by sensors, coordinates available, performing an +action (as defined above).

          +
          + + +

          The mapping between these states and physical actions +performed by the user vary for different pointing device types (mouse, +finger) and different phone models. Here are two example interpretations +of physical pointing device states:

            +
          • Mouse. An example interpretation by a driver of the physical state of +a mouse is as follows: It is always in the up state except +when the left button is pressed, when it is in the down state. +It is never out of range.

          • +
          • Fingers +with proximity support. The following is an example interpretation +of finger physical states when the device has proximity support (that +is, it can measure the finger's proximity from the screen):

              +
            • Out of range when proximity > 10cm

            • +
            • Up when +1cm < proximity <= 10cm

            • +
            • Down when proximity <= 1cm

            • +

            In this way the finger can perform actions (for example, +press buttons, drag items) without touching the screen.

          • +
          +
          Multiple pointers

          The system handles multiple +pointers at the same time by identifying each one with a number and +sending pointer events separately for each of them. A field (iPointerNumber) in the pointer event classes (TRawEvent and the TAdvancedPointerEvent class which extends TPointerEvent) identifies the pointer for which the event occurred. The +order and frequency of pointer events depends on the driver of the +pointing device.

          On each phone there is a pool of available +pointer numbers, ranging from 0 to HALData::EPointerNumberOfPointers - 1. Every time the driver detects a new pointer coming into the +range of the device, the driver assigns a number from the pool. After +the pointer goes out of the range of the device, the number no longer +identifies that particular pointer and the driver sends TRawEvent::EPointer3DOutOfRange with this +pointer number. The number is then released back to the pool and may +be reused to identify another pointer coming into the device's range.

          +
          Pressure and proximity

          The pressure of +the pointer on the screen is represented as a positive integer. The +proximity of the pointer to the screen is represented as a negative +integer. It is up to the UI Platform to define units of pressure and +proximity, which may be non-linear. In the TRawEvent class, pressure and proximity are expressed in terms of the +Z coordinate of the pointer. The definition of the Z coordinate is +based on the assumption that the pointer is either hovering over the +screen (proximity < 0, pressure = 0) or touching the screen (proximity += 0, pressure >= 0):

            +
          • If proximity +< 0 and pressure = 0 then the Z coordinate = proximity.

          • +
          • If proximity += 0 and pressure >= 0 then the Z coordinate = pressure.

          • +
          + Relationships between the pointer proximity, +pressure and z coordinate +
          +
          API summary + + + +API +Description + + + + +

          HALData

          +

          Includes z coordinate, pressure precision and number of +pointers. Also contains threshold values for proximity and pressure.

          +
          + +

          TRawEvent

          +

          Includes the pointer number and a structure for proximity +and pressure data.

          +
          + +

          RWindowBase

          +

          Enables advanced pointer events for the window.

          +
          + +

          TWsEvent

          +

          Supports TAdvancedPointerEvent (derived +from TPointerEvent).

          +
          + +

          TPointerEvent

          +

          Includes event types for pressing and closeness.

          +
          + +

          TAdvancedPointerEvent

          +

          Inherits from TPointerEvent.

          Provides +capabilities for pressure, proximity and multiple pointers.

          +
          + +

          RWsSession

          +

          Provides get and set methods to manipulate threshold values +for proximity and pressure.

          +
          + + +
          +
          Typical uses
            +
          • Enabling +many pointers for a window

            Enables multiple pointers +to act on one window.

          • +
          • Enabling +concurrent control of many objects

            Controls many objects +on one or more windows with many pointers.

          • +
          • Getting +z coordinates from TPointerEvent

            Reads the pressure and +proximity values for a pointer.

          • +
          • Pinch zooming

            Enables the user to zoom in and out of data by using two +fingers to pinch an area of the screen. Pinch zooming is normally +used in web-page, map, picture, chart and control applications.

          • +
          • Responding +to high pressure events

            As the pointer state changes, +the pressure value can be checked. When it passes over a threshold +value, the Window Server responds appropriately to the client.

          • +
          +
          + +Pointer States and Event Communication + +Advanced Pointer Tutorial + +
          + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/SDK/Source/GUID-AE6F03EB-1430-4526-B4D0-57BC6C6029D4.dita --- a/Symbian3/SDK/Source/GUID-AE6F03EB-1430-4526-B4D0-57BC6C6029D4.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/SDK/Source/GUID-AE6F03EB-1430-4526-B4D0-57BC6C6029D4.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,53 +1,62 @@ - - - - - -Touch -UI -

          When designing a Symbian application, the UI must be designed so that all -tasks can be performed with touch. Therefore, the design must not rely on -hardware keys (except for turning the power ON and OFF).

          -

          The touch UI in the Symbian platform involves various specific touch components, -component and UI behavior changes, layout changes and additions to the user experience. The -main differences or additions in touch UI include the following:

          -
            -
          • Resistive touch screen (HW).

            For more information, see Designing applications for -touch UI

          • -
          • Capacitive touch screen (HW).

            For more information, see Designing applications for -touch UI

          • -
          • Single tap. For more information, see Single -tap.

          • -
          • Multi-touch.

            For more information, see Multi-touch.

          • - -
          • Toolbar component in touch UI

            For -more information, see Toolbar.

          • -
          • Touch input component (virtual keyboard, hand-writing recognition and -virtual ITU-T)

            For more information, -see Text -input.

          • -
          • Stylus pop-up menu component

            For -more information, see Stylus -pop-up menu.

          • -
          • On-screen dialer application

          • -
          • Additional touch functionality to some components (for example, Preview -pop-up)

            For more information, -see Preview -pop-up.

          • -
          • Touch-enabled components

            For -more information, see Touch support for UI components.

          • -
          -

          There are two generic layouts for touch UI -portrait orientation and landscape -orientation, see the following figure. The Status -pane in Touch UI has three variants: extended, flat and small.

          - -Default Symbian Touch UI layouts for portrait and landscape - - -
          \ No newline at end of file + + + + +Touch UI + + + + +

          When designing a Symbian application, the UI must be designed so +that all tasks can be performed with touch. Therefore, the design +must not rely on hardware keys (except for turning the power ON and +OFF).

          +

          The touch UI in the Symbian platform involves various specific +touch components, component and UI behavior changes, layout changes +and additions to the user experience. The main differences or additions in touch UI include the following:

          +
            +
          • Resistive touch screen (HW).

            For more information, see Designing applications +for touch UI

          • +
          • Capacitive touch screen (HW).

            For more information, +see Designing +applications for touch UI

          • +
          • Single tap. For more information, see Single tap.

          • +
          • Multiple touch.

            For more information, see Multiple touch.

          • +
          • Toolbar component in touch UI

            For more information, see Toolbar.

          • +
          • Touch input component (virtual keyboard, hand-writing recognition +and virtual ITU-T)

            For more information, see Text input.

          • +
          • Stylus pop-up menu component

            For more information, see Stylus pop-up +menu.

          • +
          • On-screen dialer application

          • +
          • Additional touch functionality to some components (for example, +Preview pop-up)

            For more information, see Preview pop-up.

          • +
          • Touch-enabled components

            For more information, see Touch support +for UI components.

          • +
          +

          There are two generic layouts for touch UI -portrait orientation +and landscape orientation, see the following figure. The Status pane in Touch UI has three variants: extended, flat and small.

          + +Default Symbian Touch UI layouts for portrait and landscape + +
          +
          + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/SDK/Source/GUID-C60DC070-572B-5960-B394-550426FDB909.dita --- a/Symbian3/SDK/Source/GUID-C60DC070-572B-5960-B394-550426FDB909.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/SDK/Source/GUID-C60DC070-572B-5960-B394-550426FDB909.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,199 +1,262 @@ - - - - - - Advanced -Pointer TutorialThis tutorial provides step-by-step instructions and sample code -to help you write applications using advanced pointers. -

          Variant: ScreenPlay. Target -audience: Application developers.

          -
          Required background

          This topic builds on the material -in the following topics:

            -
          • Advanced -Pointer Overview

          • -
          • Advanced -Pointer States and Event Communication

          • -
          -
          Using advanced pointers

          This topic covers the following:

            -
          • Enabling multi-touch for a window

          • -
          • Getting Z coordinates from TPointerEvent

          • -
          • Pinch zooming

          • -
          -
          Enabling multi-touch -in a window
            -
          1. RWindow provides -a handle to a standard window. Call RWindow to create an -instance of a window.

            -RWindow window(ws); - -User::LeaveIfError(window.Construct(wg, reinterpret_cast<TUint32>(&wg) + 1)); -
          2. -
          3. Call RWindow::EnableAdvancedPointers() to -enable advanced pointers. Then call RWindowBase::Activate() to -display the window and enable the window to receive events. RWindow inherits -from RWindowBase, so you can call the Activate() function -on RWindow.

            -window.EnableAdvancedPointers(); -window.Activate(); -

            When an application needs to receive advanced pointer events -in a window, it must call RWindowBase::EnableAdvancedPointers() for -the window before it is activated.

            If advanced pointers are -not enabled for a window, it receives only standard TPointerEvent information -from a single pointer with no pressure and proximity data. The single pointer -environment rules describe the way in which pointer events coming from many -pointers in the multi-pointer model are transformed into events of one pointer. -They are necessary to ensure that old single-pointer applications work in -a multi-touch environment intuitively and as expected by the user.

            However, -the new TPointerEvent types, EEnterCloseProximity, EExitCloseProximity, EEnterHighPressure and EExitHighPressure, are delivered to all windows, -even to those that do not enable advanced pointers.

          4. -
          -
          Getting Z coordinates -from TPointerEvent
            -
          1. Call TPointerEvent::AdvancedPointerEvent() on -a TPointerEvent to return a pointer to a TAdvancedPointerEvent.

            -TZType aZType; -TPointerEvent& aPointerEvent; -TInt* aZ; -TInt* aPoint3D; - -TAdvancedPointerEvent *advancedP = aPointerEvent.AdvancedPointerEvent(); -

            TPointerEvent is a struct that contains -details of a pointer event. TZType is a struct provided by -the programmer containing members to hold proximity, pressure, and "proximity -and pressure" data.

          2. -
          3. Now we need to test -whether the pointer event contains advanced pointer data. If it is not an -advanced pointer, the code leaves.

            If it is an advanced pointer, we -call functions to detect proximity, pressure, "proximity and pressure" data -and coordinates.

            -if(!advancedP) - { - // The TPointerEvent isn't an instance of TAdvancedPointerEvent - User::Leave(KErrArgument); - } - -switch(aZType) - { - case EZTypeProximity: - aZ = advancedP->Proximity(); - aPoint3D = advancedP->Proximity3D(); - break; - case EZTypePressure: - aZ = advancedP->Pressure(); - aPoint3D = advancedP->Pressure3D(); - break; - case EZTypeProximityAndPressure: - aZ = advancedP->ProximityAndPressure(); - aPoint3D = advancedP->ProximityAndPressure3D(); - break; - default: - User::Leave(KErrArgument); - break; - } -
              -
            • TAdvancedPointerEvent::Proximity() returns -the proximity.

            • -
            • TAdvancedPointerEvent::Pressure() returns -the pressure.

            • -
            • TAdvancedPointerEvent::ProximityAndPressure() returns -the proximity and pressure combined.

            • -
            • TAdvancedPointerEvent:: -Position3D() returns the proximity and the X, Y and Z coordinates.

            • -
            • TAdvancedPointerEvent::Pressure3D() returns -the pressure and the X and Y coordinates.

            • -

            Proximity is always negative and pressure is always positive. -Internally they are combined together as a Z coordinate. When Z > 0, the proximity -is 0 and the Z value represents the pressure. When Z < 0, the pressure -is 0 and the Z value represents the proximity. Some APIs use only a Z coordinate -(such as the threshold getters and setters and TAdvancedPointerEvent::ProximityAndPressure()). -In these, the Z coordinate is interpreted in terms of pressure and proximity.

          4. -
          - Relationships between the pointer proximity, pressure and Z - coordinate - -
          -
          Pinch zooming

          This -example shows an easy way to pinch zoom an image when the screen receives -pointer events from two pointers. There are two functions in this code that -must be implemented by the programmer: BitmapCoordinates() and MoveBitmap(). -They are not included in the example because they involve complex calculations -that are not related to advanced pointers.

          The high-level steps to -perform pinch zooming are:

            -
          1. Define the coordinates, -equivalent to the given on-screen coordinates. In the code example, this is -done using the function BitmapCoordinates().

          2. -
          3. Define the ID of the -pointer by using TAdvancedPointerEvent::PointerNumber(). -If the device can handle two pointers (two fingers) at the same time, their -numbers are 0 and 1. The pointer number enables you to distinguish a given -pointer from other pointers.

          4. -
          5. For each pointer assign -its coordinates to a local variable. We assume there are only two pointers -handled by the system here.

          6. -
          7. Use the MoveBitmap() function -to achieve the zoom effect.

            -/** -Receives pointer events from two pointers to perform Pinch Zoom of the image. -Function will finish when EButton1Up is received for any of the pointers. -@param aPointer1 Coordinates of pointer number 1 when zoom is started -@param aPointer2 Coordinates of pointer number 2 when zoom is started -*/ - -void PinchZoom(TPoint aPointer1, TPoint aPointer2) - { - TPoint actualP1 = aPointer1; - TPoint actualP2 = aPointer2; - - // translate on-screen pointer coordinates to coordinates of displayed bitmap - TPoint bitmapCatching1 = BitmapCoordinates(aPointer1); - TPoint bitmapCatching2 = BitmapCoordinates(aPointer2); - - TBool repaint = EFalse; - - while (ETrue) - { - TAdvancedPointerEvent event = GetNextPointerEvent(); - - if (event.iType == TPointerEvent::EDrag) - { - if (event.PointerNumber() == 1) - { - actualP1 = event.iPosition; - repaint = ETrue; - } - else if (event.PointerNumber() == 2) - { - actualP2 = event.iPosition; - repaint = ETrue; - } - } - else if (event.iType == TPointerEvent::EButton1Up) - { - break; - } - - if (repaint) - { - // move bitmap on the screen in the way that - // bitmapCatching1 point of the bitmap will be displayed at actualP1 screen coordinate, - // bitmapCatching2 point of the bitmap will be displayed at actualP2 screen coordinate. - MoveBitmap(bitmapCatching1, actualP1, bitmapCatching2, actualP2); - repaint = EFalse; - } - } - } -
          8. -
          -
          -Advanced -Pointer Overview -Advanced -Pointer States and Event Communication -
          \ No newline at end of file + + + + + Advanced Pointer Tutorial +This tutorial provides step-by-step instructions and sample +code to help you write applications using advanced pointers. + + + + +

          Variant: ScreenPlay. Target audience: Application developers.

          +
          Required background

          This topic builds +on the material in the following topics:

            +
          • Advanced Pointer +Overview

          • +
          • Advanced Pointer +States and Event Communication

          • +
          +
          Using advanced pointers

          This topic covers +the following:

            +
          • Enabling multiple pointers for a window

          • +
          • Getting Z coordinates from TPointerEvent

          • +
          • Pinch zooming

          • +
          +
          Enabling +multiple pointers in a window
            +
          1. RWindow provides a handle to a standard window. Call RWindow to create an instance of a window.

            +RWindow window(ws); + +User::LeaveIfError(window.Construct(wg, reinterpret_cast<TUint32>(&wg) + 1)); +
          2. +
          3. Call RWindow::EnableAdvancedPointers() to enable +advanced pointers. Then call RWindowBase::Activate() to display the +window and enable the window to receive events. RWindow inherits from RWindowBase, so you can call the Activate() function +on RWindow.

            +window.EnableAdvancedPointers(); +window.Activate(); +

            When an application needs to receive advanced pointer +events in a window, it must call RWindowBase::EnableAdvancedPointers() for the window before it is activated.

            If advanced +pointers are not enabled for a window, it receives only standard TPointerEvent information from a single pointer with no pressure and proximity +data. The single pointer environment rules describe the way in which +pointer events coming from many pointers in the multiple pointer model +are transformed into events of one pointer. They are necessary to +ensure that old single-pointer applications work in a multiple pointer +environment intuitively and as expected by the user.

            However, the new TPointerEvent types, EEnterCloseProximity, EExitCloseProximity, EEnterHighPressure and EExitHighPressure, are delivered to all +windows, even to those that do not enable advanced pointers.

          4. +
          +
          Getting +Z coordinates from TPointerEvent
            +
          1. Call TPointerEvent::AdvancedPointerEvent() on +a TPointerEvent to return a pointer to a TAdvancedPointerEvent.

            +TZType aZType; +TPointerEvent& aPointerEvent; +TInt* aZ; +TInt* aPoint3D; + +TAdvancedPointerEvent *advancedP = aPointerEvent.AdvancedPointerEvent(); +

            TPointerEvent is a struct that contains +details of a pointer event. TZType is a struct provided +by the programmer containing members to hold proximity, pressure, +and "proximity and pressure" data.

          2. +
          3. Now we need +to test whether the pointer event contains advanced pointer data. +If it is not an advanced pointer, the code leaves.

            If it is +an advanced pointer, we call functions to detect proximity, pressure, +"proximity and pressure" data and coordinates.

            +if(!advancedP) + { + // The TPointerEvent isn't an instance of TAdvancedPointerEvent + User::Leave(KErrArgument); + } + +switch(aZType) + { + case EZTypeProximity: + aZ = advancedP->Proximity(); + aPoint3D = advancedP->Proximity3D(); + break; + case EZTypePressure: + aZ = advancedP->Pressure(); + aPoint3D = advancedP->Pressure3D(); + break; + case EZTypeProximityAndPressure: + aZ = advancedP->ProximityAndPressure(); + aPoint3D = advancedP->ProximityAndPressure3D(); + break; + default: + User::Leave(KErrArgument); + break; + } +
              +
            • TAdvancedPointerEvent::Proximity() returns +the proximity.

            • +
            • TAdvancedPointerEvent::Pressure() returns +the pressure.

            • +
            • TAdvancedPointerEvent::ProximityAndPressure() returns the proximity and pressure combined.

            • +
            • TAdvancedPointerEvent:: Position3D() returns +the proximity and the X, Y and Z coordinates.

            • +
            • TAdvancedPointerEvent::Pressure3D() returns +the pressure and the X and Y coordinates.

            • +

            Proximity is always negative and pressure is always positive. Internally they are combined together as a Z coordinate. +When Z > 0, the proximity is 0 and the Z value represents the pressure. +When Z < 0, the pressure is 0 and the Z value represents the proximity. +Some APIs use only a Z coordinate (such as the threshold getters and +setters and TAdvancedPointerEvent::ProximityAndPressure()). In these, the Z coordinate is interpreted in terms of pressure +and proximity.

          4. +
          + Relationships between the pointer proximity, pressure and +Z coordinate +
          +
          Pinch +zooming

          This example shows an easy way to pinch zoom an +image when the screen receives pointer events from two pointers. There +are two functions in this code that must be implemented by the programmer: BitmapCoordinates() and MoveBitmap(). They +are not included in the example because they involve complex calculations +that are not related to advanced pointers.

          The high-level +steps to perform pinch zooming are:

            +
          1. Define the coordinates, +equivalent to the given on-screen coordinates. In the code example, +this is done using the function BitmapCoordinates().

          2. +
          3. Define the ID +of the pointer by using TAdvancedPointerEvent::PointerNumber(). +If the device can handle two pointers (two fingers) at the same time, +their numbers are 0 and 1. The pointer number enables you to distinguish +a given pointer from other pointers.

          4. +
          5. For each pointer +assign its coordinates to a local variable. We assume there are only +two pointers handled by the system here.

          6. +
          7. Use the MoveBitmap() function to achieve the zoom effect.

            +/** +Receives pointer events from two pointers to perform Pinch Zoom of the image. +Function will finish when EButton1Up is received for any of the pointers. +@param aPointer1 Coordinates of pointer number 1 when zoom is started +@param aPointer2 Coordinates of pointer number 2 when zoom is started +*/ + +void PinchZoom(TPoint aPointer1, TPoint aPointer2) + { + TPoint actualP1 = aPointer1; + TPoint actualP2 = aPointer2; + + // translate on-screen pointer coordinates to coordinates of displayed bitmap + TPoint bitmapCatching1 = BitmapCoordinates(aPointer1); + TPoint bitmapCatching2 = BitmapCoordinates(aPointer2); + + TBool repaint = EFalse; + + while (ETrue) + { + TAdvancedPointerEvent event = GetNextPointerEvent(); + + if (event.iType == TPointerEvent::EDrag) + { + if (event.PointerNumber() == 1) + { + actualP1 = event.iPosition; + repaint = ETrue; + } + else if (event.PointerNumber() == 2) + { + actualP2 = event.iPosition; + repaint = ETrue; + } + } + else if (event.iType == TPointerEvent::EButton1Up) + { + break; + } + + if (repaint) + { + // move bitmap on the screen in the way that + // bitmapCatching1 point of the bitmap will be displayed at actualP1 screen coordinate, + // bitmapCatching2 point of the bitmap will be displayed at actualP2 screen coordinate. + MoveBitmap(bitmapCatching1, actualP1, bitmapCatching2, actualP2); + repaint = EFalse; + } + } + } +
          8. +
          +
          + +Advanced Pointer Overview +Advanced Pointer States and Event Communication + + +
          + diff -r d4524d6a4472 -r 5072524fcc79 Symbian3/SDK/Source/GUID-F25C17AC-BA88-4965-BAE8-AEF0E2EA66EC.dita --- a/Symbian3/SDK/Source/GUID-F25C17AC-BA88-4965-BAE8-AEF0E2EA66EC.dita Wed Jun 16 10:24:13 2010 +0100 +++ b/Symbian3/SDK/Source/GUID-F25C17AC-BA88-4965-BAE8-AEF0E2EA66EC.dita Fri Jul 02 12:51:36 2010 +0100 @@ -1,39 +1,43 @@ - - - - - -Zooming -actionsMobile device users must be able to zoom in and out consistently -within applications on a mobile device. However the zooming actions may differ -from one device model to another. -

          The product features and form factor of a mobile device determine which -zooming actions application developers should make available on it:

          + + + + +Zooming actions +Mobile device users must be able to zoom in and out consistently within applications on a mobile device. However +the zooming actions may differ from one device model to another. + + + + +

          The product features and form factor of a mobile device determine +which zooming actions application developers should make available +on it:

            -
          • If the device has an ITU-T keypad, the asterisk (*) key zooms in and -the hash mark (#) key zooms out. This functionality is not available in editors -or other states where the keys play another role. In these cases, the zoom -functions, if applicable, must be available in the Options menu.

          • -
          • If the device has a QWERTY or half-QWERTY keyboard, use the two topmost -keys at the top left of the keyboard for zooming in and out. For example, -on a Latin keyboard, use the Q key to zoom in and the A key to zoom out. Some -products might have zooming symbols printed on the keyboard to help users -find the zooming features. Again, the functions are not available in editors.

          • -
          • On touch devices, users can use touch stripes to zoom. Finger movement -along the stripe controls zooming. Applications may support different number -of zoom levels. It should be possible to zoom across the full range with one -swipe.

          • -
          • On touch devices with multi-touch support, users can use pinch zoom. -See Multi-touch section -for more details on pinch in and pinch out.

          • -
          • On touch devices, some applications may support double-tapping zoom. -A double tap can toggle between zoomed and normal view, but this depends on -the application.

          • +
          • If the device has an ITU-T keypad, the asterisk (*) key zooms +in and the hash mark (#) key zooms out. This functionality is not +available in editors or other states where the keys play another role. +In these cases, the zoom functions, if applicable, must be available +in the Options menu.

          • +
          • If the device has a QWERTY or half-QWERTY keyboard, use the +two topmost keys at the top left of the keyboard for zooming in and +out. For example, on a Latin keyboard, use the Q key to zoom in and +the A key to zoom out. Some products might have zooming symbols printed +on the keyboard to help users find the zooming features. Again, the +functions are not available in editors.

          • +
          • On touch devices, users can use touch stripes to zoom. Finger +movement along the stripe controls zooming. Applications may support +different number of zoom levels. It should be possible to zoom across +the full range with one swipe.

          • +
          • On touch devices with multiple touch support, users can use +pinch zoom. See Multiple touch section for more details on pinch in and pinch out.

          • +
          • On touch devices, some applications may support double-tapping +zoom. A double tap can toggle between zoomed and normal view, but +this depends on the application.

          -
          \ No newline at end of file +
          +
          +