Quantcast
Jump to content


Recommended Posts

Posted

Rotary event handling, enabled via the bezel, is supported on the Tizen platform. A bezel is a term used to describe the outside frame of a device, and in the case of a Galaxy Watch, the bezel is the outer ring of the device, which can be rotated. Rotary events are triggered from the Galaxy Watch rotary component when the bezel is rotated clockwise or counterclockwise. The event for each rotation is measured in incremental units called “detents.”

rotary_event.png

Bezel interactions can be used in a variety of ways, such as controlling the application page, controlling the snap list, changing the progress bar value, scrolling the page, changing the volume, and setting configurations such as date-time on the date-time picker.

This blog discusses how to handle rotary events in Tizen web and native applications. In the following example, you’ll learn how to let a user interact with bezel by using the rotary event to receive or reject a call. The user rotates the bezel clockwise to receive the call and counterclockwise to reject it.

galaxy-watch_lifestyle_hands-free_s.png

Note: Because Galaxy Active devices do not have bezels, rotary features will not work on them.


Prerequisites

Tizen Web
In the Tizen web application, add the following line in the config.xml file:

<feature name="tizen.org/feature/input.rotating_bezel"/>

Tizen Native
In the Tizen native application, include the <system_info.h>header file to use the functions and data types of the system information API.

#include<system_info.h>

You also must add the following line to the manifest file:

<feature name="http://tizen.org/feature/input.rotating_bezel">true</feature>

Check capability

Tizen Web

In the Tizen web application, use the following line to check if the device supports rotary events or if it uses bezel:

var isSupport = tizen.systeminfo.getCapability('http://tizen.org/feature/input.rotating_bezel'); 
console.log(' Bezel = ' + isSupport);

The getCapability() function of the Tizen web API returns with information about whether or not the device supports bezel.

Tizen Native
In the Tizen native application, use the following code to check bezel capability:

bool rotaryValue;
int rotaryReturn;
    rotaryReturn = system_info_get_platform_bool("http://tizen.org/feature/input.rotating_bezel", & rotaryValue);
    if (rotaryReturn!= SYSTEM_INFO_ERROR_NONE) {
       dlog_print(DLOG_INFO, LOG_TAG, "Rotary error");
        return;
    }
dlog_print(DLOG_INFO, LOG_TAG, "Bezel: %s", value ? "Supported" : "Not supported");

Implementation

Tizen Web
Register the rotarydetent event. After registering an event, ev.detail.direction provides the direction value. If the value is CW, the bezel is rotated clockwise. If the value of direction is CCW, the bezel is rotated counterclockwise.

document.addEventListener('rotarydetent', function(ev) {
        /* Get the direction value from the event */
        var direction = ev.detail.direction;
        var textbox = document.querySelector('.contents');
        box = document.querySelector('#textbox'); 
        
        if (direction == 'CW') {
            /* Add behavior for clockwise rotation */
            console.log('clockwise');
            box.innerHTML ="clockwise";
        } else if (direction == 'CCW') {
            /* Add behavior for counter-clockwise rotation */
            console.log('counter-clockwise');
            box.innerHTML ="counter-clockwise";
        }
  });

Tizen Native
Register the rotary event in the app using the following line:

eext_rotary_event_handler_add(_rotary_handler_cb, ad);

The handle function is defined using following code:

Eina_Bool
_rotary_handler_cb(appdata_s *data, Eext_Rotary_Event_Info *ev)
{
    if (ev->direction == EEXT_ROTARY_DIRECTION_CLOCKWISE) {
        dlog_print(DLOG_DEBUG, LOG_TAG,
                   "Rotary device rotated in clockwise direction");

    } else {
        dlog_print(DLOG_DEBUG, LOG_TAG,
                   "Rotary device rotated in counter-clockwise direction");
    }
    return EINA_FALSE;
}

If the rotation direction is equal to EEXT_ROTARY_DIRECTION_CLOCKWISE, the bezel is rotated clockwise. Otherwise, the bezel is rotated counterclockwise.


Demo

Two sample apps are attached:
Rotary Native
Rotary Web

Web
When you run the web sample app and turn the bezel clockwise, the following text appears on the watch face:

CW_web.png

When you turn the bezel counter counterclockwise, “counterclockwise” appears on the watch face:

CCW_web.png

Native
When you run the native sample app and turn the bezel clockwise, the following text appears on the watch face:

CW_native.png

When you turn the bezel counterclockwise, the following text appears:

CCW_native.png


For more information

The bezel is the physical controller of some Samsung wearable devices. Understanding the physical characteristics of the bezel will help you design better interactions.

References:

View the full blog at its source



  • Replies 0
  • Created
  • Last Reply

Top Posters In This Topic

Popular Days

Top Posters In This Topic

Popular Days

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Loading...
  • Similar Topics

    • By Samsung Newsroom
      View the full blog at its source
    • By BGR
      Samsung’s Galaxy S23 launch event is coming on February 1st, but we don’t have to wait to see the Ultra flagship in a hands-on video. If the huge number of Galaxy S23 leaks wasn’t enough to help you decide whether or not to purchase one of the three S23 variants, we now have purported videos out in the wild of the most expensive option.
      Apparently, stores are already getting their Galaxy S23 supply in ahead of the February 1st launch event. Preorders will follow right after the press conference, and we expect the three Galaxy S23 handsets to hit stores a couple of weeks later.
      The Galaxy S23 Ultra hands-on videos below reportedly come from Nicaragua, where some stores shared Galaxy S23 content online well ahead of the phone’s launch:
      One of the clips shows the Galaxy S23 Ultra’s full design. The new Note successor matches previous leaks, not that we expected surprises. We have a large display with curved bezels and flat top and bottom sides. On the back, there’s a massive camera with no fewer than four distinct lenses, including the brand-new 200-megapixel shooter.
      This isn’t a dummy unit, either. The Galaxy S23 Ultra in these clips appears to be a retail version. The person who posted the clips also shared a test of the Galaxy S23 Ultra’s zoom camera in action.
      Moreover, other images seem to confirm some of the Galaxy S23 Ultra camera’s specs and features. The handset features a 200-megapixel sensor, according to the camera interface. That must be the new Isocell HP2 camera that Samsung just announced. And the camera supports 8K video recording at 30fps.
      Separately, the Nicaraguan retail store that posted the hands-on videos also shared photos showing the Galaxy S23, S23 Plus, and S23 Ultra. As you can see, the images confirm some of the colors Samsung will offer Galaxy S23 buyers at launch. The Galaxy S23 Ultra will get Green, Cream, Phantom Black, and Lavender options if this leak is accurate.
      Finally, Evan Blass posted online posters for the Galaxy S23 preorder event that seemingly corroborated the leaks from Nicaragua.
      The retail store didn’t leak the local pricing details for the Galaxy S23 series. Word on the street is that Samsung will keep Galaxy S22 prices in place in the US, while international buyers will see price hikes for all three Galaxy S23 models.
      Don't Miss: Galaxy S23 Ultra release date and specs leak finally reveals everything about the new modelThe post Galaxy S23 Ultra hands-on video leaks ahead of launch event appeared first on BGR.
      View the full article
    • By BGR
      As leaks continue unabated, Samsung confirmed this week that its next Galaxy Unpacked event will take place on February 1 at 10 a.m. PST / 1 p.m. EST. Samsung will host the in-person event in San Francisco, where we will see the Galaxy S23, Galaxy S23 Plus, Galaxy S23 Ultra, and the new pair of Galaxy Buds. You can watch the Unpacked event live on YouTube or on Samsung’s website to get a first glimpse of the Galaxy S23.
      Countless leaks have already spoiled most of the new features coming to the Galaxy S23, as well as the design, which Samsung is obviously teasing on its invite. The three spotlights represent the triple rear camera array, which will be the focus of this generation.
      Unlike the previous generation, all three models should feature the embedded rear camera design that was exclusive to the Galaxy S22 Ultra. It’s a much cleaner look, and it’s clear that Samsung heard the feedback from its fans loud and clear last year.
      Samsung’s reservation page for the Galaxy S23 is already live as well. If you reserve the Galaxy S23 today, you can get up to $100 in Samsung Credit. If you check out that page, you can watch a video highlighting one of the phone’s new camera features.
      Galaxy S23 specs and features leaked
      According to recent leaks, the Galaxy S23 and S23 Plus will feature 8GB of RAM and up to 512GB of storage. The Galaxy S23 Ultra will feature up to 12GB of RAM and 1TB of storage. All three should also use faster DDR5X RAM instead of DDR5.
      As for the colorways, display analyst Ross Young claims the Galaxy S23 will come in Beige, Black, Green, and Light Pink. There will also be Gray, Light Blue, Light Green, and Red options for the Galaxy S23 Ultra.
      The post Samsung’s Galaxy S23 Unpacked event set for February 1st appeared first on BGR.
      View the full article





×
×
  • Create New...