blob: 261e64fac9b8250cf5746c49e3bf779bd8dd2b73 [file] [log] [blame]
Mathias Agopiane1c61d32012-03-23 14:19:36 -07001/*
2 * Copyright (C) 2009 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070017/**
18 * @addtogroup Bitmap
19 * @{
20 */
21
22/**
23 * @file bitmap.h
24 */
25
Mathias Agopiane1c61d32012-03-23 14:19:36 -070026#ifndef ANDROID_BITMAP_H
27#define ANDROID_BITMAP_H
28
29#include <stdint.h>
30#include <jni.h>
31
32#ifdef __cplusplus
33extern "C" {
34#endif
35
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070036/** AndroidBitmap functions result code. */
37enum {
38 /** Operation was successful. */
39 ANDROID_BITMAP_RESULT_SUCCESS = 0,
40 /** Bad parameter. */
41 ANDROID_BITMAP_RESULT_BAD_PARAMETER = -1,
42 /** JNI exception occured. */
43 ANDROID_BITMAP_RESULT_JNI_EXCEPTION = -2,
44 /** Allocation failed. */
45 ANDROID_BITMAP_RESULT_ALLOCATION_FAILED = -3,
46};
Mathias Agopiane1c61d32012-03-23 14:19:36 -070047
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070048/** Backward compatibility: this macro used to be misspelled. */
Andrew Hsieh370980c2012-12-17 08:01:36 +080049#define ANDROID_BITMAP_RESUT_SUCCESS ANDROID_BITMAP_RESULT_SUCCESS
50
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070051/** Bitmap pixel format. */
Mathias Agopiane1c61d32012-03-23 14:19:36 -070052enum AndroidBitmapFormat {
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070053 /** No format. */
Mathias Agopiane1c61d32012-03-23 14:19:36 -070054 ANDROID_BITMAP_FORMAT_NONE = 0,
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070055 /** Red: 8 bits, Green: 8 bits, Blue: 8 bits, Alpha: 8 bits. **/
Mathias Agopiane1c61d32012-03-23 14:19:36 -070056 ANDROID_BITMAP_FORMAT_RGBA_8888 = 1,
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070057 /** Red: 5 bits, Green: 6 bits, Blue: 5 bits. **/
Mathias Agopiane1c61d32012-03-23 14:19:36 -070058 ANDROID_BITMAP_FORMAT_RGB_565 = 4,
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070059 /** Red: 4 bits, Green: 4 bits, Blue: 4 bits, Alpha: 4 bits. **/
Mathias Agopiane1c61d32012-03-23 14:19:36 -070060 ANDROID_BITMAP_FORMAT_RGBA_4444 = 7,
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070061 /** Deprecated. */
Mathias Agopiane1c61d32012-03-23 14:19:36 -070062 ANDROID_BITMAP_FORMAT_A_8 = 8,
63};
64
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070065/** Bitmap info, see AndroidBitmap_getInfo(). */
Mathias Agopiane1c61d32012-03-23 14:19:36 -070066typedef struct {
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070067 /** The bitmap width in pixels. */
Mathias Agopiane1c61d32012-03-23 14:19:36 -070068 uint32_t width;
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070069 /** The bitmap height in pixels. */
Mathias Agopiane1c61d32012-03-23 14:19:36 -070070 uint32_t height;
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070071 /** The number of byte per row. */
Mathias Agopiane1c61d32012-03-23 14:19:36 -070072 uint32_t stride;
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070073 /** The bitmap pixel format. See {@link AndroidBitmapFormat} */
Mathias Agopiane1c61d32012-03-23 14:19:36 -070074 int32_t format;
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070075 /** Unused. */
Mathias Agopiane1c61d32012-03-23 14:19:36 -070076 uint32_t flags; // 0 for now
77} AndroidBitmapInfo;
78
79/**
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -070080 * Given a java bitmap object, fill out the AndroidBitmapInfo struct for it.
81 * If the call fails, the info parameter will be ignored.
Mathias Agopiane1c61d32012-03-23 14:19:36 -070082 */
83int AndroidBitmap_getInfo(JNIEnv* env, jobject jbitmap,
84 AndroidBitmapInfo* info);
85
86/**
87 * Given a java bitmap object, attempt to lock the pixel address.
88 * Locking will ensure that the memory for the pixels will not move
89 * until the unlockPixels call, and ensure that, if the pixels had been
90 * previously purged, they will have been restored.
91 *
92 * If this call succeeds, it must be balanced by a call to
93 * AndroidBitmap_unlockPixels, after which time the address of the pixels should
94 * no longer be used.
95 *
96 * If this succeeds, *addrPtr will be set to the pixel address. If the call
97 * fails, addrPtr will be ignored.
98 */
99int AndroidBitmap_lockPixels(JNIEnv* env, jobject jbitmap, void** addrPtr);
100
101/**
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -0700102 * Call this to balance a successful call to AndroidBitmap_lockPixels.
Mathias Agopiane1c61d32012-03-23 14:19:36 -0700103 */
104int AndroidBitmap_unlockPixels(JNIEnv* env, jobject jbitmap);
105
106#ifdef __cplusplus
107}
108#endif
109
110#endif
Johan Euphrosinebf6d5e02015-03-27 17:15:43 -0700111
112/** @} */