/* 
 | 
 * 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 <inttypes.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; 
 | 
  
 | 
typedef enum GRRotation_e { 
 | 
  ROTATION_NONE = 0, 
 | 
  ROTATION_RIGHT = 1, 
 | 
  ROTATION_DOWN = 2, 
 | 
  ROTATION_LEFT = 3, 
 | 
}GRRotation; 
 | 
  
 | 
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); 
 | 
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); 
 | 
// Set rotation, flips gr_fb_width/height if 90 degree rotation difference 
 | 
void gr_rotate(GRRotation rotation); 
 | 
  
 | 
  
 | 
// 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 
 |