Some S60 devices support screen rotation. On these devices, applications can be displayed in portrait or landscape orientation.
Screen rotation can be supported in the following ways:
You can add a menu option to your widget that enables the user to rotate the UI.
Some devices support rotation in response to a user action such as opening a cover or moving a slider. However, Web Runtime (WRT) does not support receiving the JavaScript event that indicates the screen orientation has changed. For an example of a solution for this issue, see the AccuWidget Example on Forum Nokia.
Some devices enable software developers to use widget
object methods to programmatically rotate the screen.
Combine the JavaScript on resize DOM event handler with the height and width properties from the window and screen objects to calculate the effective area or viewport available for a widget. See the Viewport widget for an example of how to determine the effective viewport size.
In the landscape orientation, the softkeys can either be placed on either side of the display or at the bottom of the display. In the bottom softkey style, the layout is stretched horizontally to fit the screen, leaving the softkeys below the screen as in portrait orientation. Touch devices do not support the bottom softkey style. Design widgets to work in both portrait orientation and landscape orientation with side softkeys.
Figure: Page layout in portrait and landscape
Note: The WRT environment adjusts the softkey labels.
Add a rotation option to the options menu.
For more information, see Using softkeys.
Create the code for the menu option. Check that the device supports screen rotation and use widget
object methods to change the screen orientation.
if (widget.isrotationsupported) // Change the screen orientation var h = window.screen.height; var w = window.screen.width; if (h < w) widget.setDisplayLanscape();