blob: f3eaad3d0a9fc46763e66f97c7620eafc9f3bb0c [file] [log] [blame]
/*
* Copyright (C) 2011 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef _ANDROID_VIEW_POINTER_ICON_H
#define _ANDROID_VIEW_POINTER_ICON_H
#include <android/graphics/bitmap.h>
#include <input/Input.h>
#include <utils/Errors.h>
#include <vector>
#include "jni.h"
namespace android {
/*
* Describes a pointer icon.
*/
struct PointerIcon {
inline PointerIcon() { reset(); }
PointerIconStyle style;
graphics::Bitmap bitmap;
float hotSpotX;
float hotSpotY;
std::vector<graphics::Bitmap> bitmapFrames;
int32_t durationPerFrame;
inline bool isNullIcon() { return style == PointerIconStyle::TYPE_NULL; }
inline void reset() {
style = PointerIconStyle::TYPE_NULL;
bitmap.reset();
hotSpotX = 0;
hotSpotY = 0;
bitmapFrames.clear();
durationPerFrame = 0;
}
};
/* Gets a system pointer icon with the specified style. */
extern jobject android_view_PointerIcon_getSystemIcon(JNIEnv* env, jobject contextObj,
PointerIconStyle style);
/* Loads the bitmap associated with a pointer icon.
* If pointerIconObj is NULL, returns OK and a pointer icon with POINTER_ICON_STYLE_NULL. */
extern status_t android_view_PointerIcon_load(JNIEnv* env, jobject pointerIconObj,
jobject contextObj, PointerIcon* outPointerIcon);
/* Obtain the data of pointerIconObj and put to outPointerIcon. */
extern status_t android_view_PointerIcon_getLoadedIcon(JNIEnv* env, jobject pointerIconObj,
PointerIcon* outPointerIcon);
/* Loads the bitmap associated with a pointer icon by style.
* If pointerIconObj is NULL, returns OK and a pointer icon with POINTER_ICON_STYLE_NULL. */
extern status_t android_view_PointerIcon_loadSystemIcon(JNIEnv* env, jobject contextObj,
PointerIconStyle style,
PointerIcon* outPointerIcon);
} // namespace android
#endif // _ANDROID_OS_POINTER_ICON_H