harmony 鸿蒙Mouse Pointer Development

  • 2023-02-03
  • 浏览 (2046)

Mouse Pointer Development

When to Use

Mouse pointer management provides the functions such as displaying or hiding the mouse pointer as well as querying and setting the pointer style. For example, you can determine whether to display or hide the mouse pointer when a user watches a video in full screen, and can switch the mouse pointer to a color picker when a user attempts color pickup.

Modules to Import

import pointer from '@ohos.multimodalInput.pointer';

Available APIs

The following table lists the common APIs for mouse pointer management. For details about the APIs, see ohos.multimodalInput.pointer.

Instance API Description
pointer function isPointerVisible(callback: AsyncCallback<boolean>): void; Checks the visible status of the mouse pointer.
pointer function setPointerVisible(visible: boolean, callback: AsyncCallback<void>): void; Sets the visible status of the mouse pointer. This setting takes effect for the mouse pointer globally.
pointer function setPointerStyle(windowId: number, pointerStyle: PointerStyle, callback: AsyncCallback<void>): void; Sets the mouse pointer style. This setting takes effect for the mouse pointer style of a specified window.
pointer function getPointerStyle(windowId: number, callback: AsyncCallback<PointerStyle>): void; Obtains the mouse pointer style.

Hiding the Mouse Pointer

When watching a video in full-screen mode, a user can hide the mouse pointer for an improved user experience.

How to Develop

  1. Switch to the full-screen playback mode.
  2. Hide the mouse pointer.
  3. Exit the full-screen playback mode.
  4. Display the mouse pointer.
import pointer from '@ohos.multimodalInput.pointer';

// 1. Switch to the full-screen playback mode.
// 2. Hide the mouse pointer.
try {
  pointer.setPointerVisible(false, (error: Error) => {
    if (error) {
      console.log(`Set pointer visible failed, error: ${JSON.stringify(error, [`code`, `message`])}`);
      return;
    }
    console.log(`Set pointer visible success.`);
  });
} catch (error) {
  console.log(`The mouse pointer hide attributes is failed. ${JSON.stringify(error, [`code`, `message`])}`);
}

// 3. Exit the full-screen playback mode.
// 4. Display the mouse pointer.
try {
  pointer.setPointerVisible(true, (error: Error) => {
    if (error) {
      console.log(`Set pointer visible failed, error: ${JSON.stringify(error, [`code`, `message`])}`);
      return;
    }
    console.log(`Set pointer visible success.`);
  });
} catch (error) {
  console.log(`Set pointer visible failed, ${JSON.stringify(error, [`code`, `message`])}`);
}

Setting the Mouse Pointer Style

When designing a color picker, you can have the mouse pointer switched to the color picker style during color pickup and then switched to the default style on completion of color pickup. This setting takes effect for the pointer style of a specified window in the current application. A total of 43 pointer styles can be set. For details, see Pointer Style.

How to Develop

  1. Enable the color pickup function.
  2. Obtain the window ID.
  3. Set the mouse pointer to the color picker style.
  4. End color pickup.
  5. Set the mouse pointer to the default style.
import { BusinessError }  from '@ohos.base';
import pointer from '@ohos.multimodalInput.pointer';
import window from '@ohos.window';

// 1. Enable the color pickup function.
// 2. Obtain the window ID.
window.getLastWindow(getContext(), (error: BusinessError, windowClass: window.Window) => {
  if (error.code) {
    console.error('Failed to obtain the top window. Cause: ' + JSON.stringify(error));
    return;
  }
  let windowId = windowClass.getWindowProperties().id;
  if (windowId < 0) {
    console.log(`Invalid windowId`);
    return;
  }
  try {
    // 3. Set the mouse pointer to the color picker style.
    pointer.setPointerStyle(windowId, pointer.PointerStyle.COLOR_SUCKER).then(() => {
      console.log(`Successfully set mouse pointer style`);
    });
  } catch (error) {
    console.log(`Failed to set the pointer style, error=${JSON.stringify(error)}, msg=${JSON.stringify(`message`)}`);
  }
});
// 4. End color pickup.
window.getLastWindow(getContext(), (error: BusinessError, windowClass: window.Window) => {
  if (error.code) {
    console.error('Failed to obtain the top window. Cause: ' + JSON.stringify(error));
    return;
  }
  let windowId = windowClass.getWindowProperties().id;
  if (windowId < 0) {
    console.log(`Invalid windowId`);
    return;
  }
  try {
    // 5. Set the mouse pointer to the default style.
    pointer.setPointerStyle(windowId, pointer.PointerStyle.DEFAULT).then(() => {
      console.log(`Successfully set mouse pointer style`);
    });
  } catch (error) {
    console.log(`Failed to set the pointer style, error=${JSON.stringify(error)}, msg=${JSON.stringify(`message`)}`);
  }
});

你可能感兴趣的鸿蒙文章

harmony 鸿蒙Device Management

harmony 鸿蒙Peripheral Management Development

harmony 鸿蒙Input Device Development

harmony 鸿蒙Location Service Development

harmony 鸿蒙Sample Server Development

harmony 鸿蒙Sample Server Overview

harmony 鸿蒙Sensor Development

harmony 鸿蒙Sensor Overview

harmony 鸿蒙Stationary Development

harmony 鸿蒙USB Service Development

0  赞