a68c517c62
* commit '80c1a386d3f614919708b37986919ecaf74ee738': refactor image resource loading code in minui
124 lines
4 KiB
C
124 lines
4 KiB
C
/*
|
|
* Copyright (C) 2007 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 _MINUI_H_
|
|
#define _MINUI_H_
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
typedef struct {
|
|
int width;
|
|
int height;
|
|
int row_bytes;
|
|
int pixel_bytes;
|
|
unsigned char* data;
|
|
} GRSurface;
|
|
|
|
typedef GRSurface* gr_surface;
|
|
|
|
int gr_init(void);
|
|
void gr_exit(void);
|
|
|
|
int gr_fb_width(void);
|
|
int gr_fb_height(void);
|
|
|
|
void gr_flip(void);
|
|
void gr_fb_blank(bool blank);
|
|
|
|
void gr_clear(); // clear entire surface to current color
|
|
void gr_color(unsigned char r, unsigned char g, unsigned char b, unsigned char a);
|
|
void gr_fill(int x1, int y1, int x2, int y2);
|
|
void gr_text(int x, int y, const char *s, int bold);
|
|
void gr_texticon(int x, int y, gr_surface icon);
|
|
int gr_measure(const char *s);
|
|
void gr_font_size(int *x, int *y);
|
|
|
|
void gr_blit(gr_surface source, int sx, int sy, int w, int h, int dx, int dy);
|
|
unsigned int gr_get_width(gr_surface surface);
|
|
unsigned int gr_get_height(gr_surface surface);
|
|
|
|
// input event structure, include <linux/input.h> for the definition.
|
|
// see http://www.mjmwired.net/kernel/Documentation/input/ for info.
|
|
struct input_event;
|
|
|
|
typedef int (*ev_callback)(int fd, uint32_t epevents, void *data);
|
|
typedef int (*ev_set_key_callback)(int code, int value, void *data);
|
|
|
|
int ev_init(ev_callback input_cb, void *data);
|
|
void ev_exit(void);
|
|
int ev_add_fd(int fd, ev_callback cb, void *data);
|
|
int ev_sync_key_state(ev_set_key_callback set_key_cb, void *data);
|
|
|
|
/* timeout has the same semantics as for poll
|
|
* 0 : don't block
|
|
* < 0 : block forever
|
|
* > 0 : block for 'timeout' milliseconds
|
|
*/
|
|
int ev_wait(int timeout);
|
|
|
|
int ev_get_input(int fd, uint32_t epevents, struct input_event *ev);
|
|
void ev_dispatch(void);
|
|
int ev_get_epollfd(void);
|
|
|
|
// Resources
|
|
|
|
// res_create_*_surface() functions return 0 if no error, else
|
|
// negative.
|
|
//
|
|
// A "display" surface is one that is intended to be drawn to the
|
|
// screen with gr_blit(). An "alpha" surface is a grayscale image
|
|
// interpreted as an alpha mask used to render text in the current
|
|
// color (with gr_text() or gr_texticon()).
|
|
//
|
|
// All these functions load PNG images from "/res/images/${name}.png".
|
|
|
|
// Load a single display surface from a PNG image.
|
|
int res_create_display_surface(const char* name, gr_surface* pSurface);
|
|
|
|
// Load an array of display surfaces from a single PNG image. The PNG
|
|
// should have a 'Frames' text chunk whose value is the number of
|
|
// frames this image represents. The pixel data itself is interlaced
|
|
// by row.
|
|
int res_create_multi_display_surface(const char* name,
|
|
int* frames, gr_surface** pSurface);
|
|
|
|
// Load a single alpha surface from a grayscale PNG image.
|
|
int res_create_alpha_surface(const char* name, gr_surface* pSurface);
|
|
|
|
// Load part of a grayscale PNG image that is the first match for the
|
|
// given locale. The image is expected to be a composite of multiple
|
|
// translations of the same text, with special added rows that encode
|
|
// the subimages' size and intended locale in the pixel data. See
|
|
// development/tools/recovery_l10n for an app that will generate these
|
|
// specialized images from Android resources.
|
|
int res_create_localized_alpha_surface(const char* name, const char* locale,
|
|
gr_surface* pSurface);
|
|
|
|
// Free a surface allocated by any of the res_create_*_surface()
|
|
// functions.
|
|
void res_free_surface(gr_surface surface);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif
|