710bc535f4
As well as all the derived classes. Instances must be created with Create(). A default copy ctor would mess up the ownership of the mapped or allocated buffer in these classes, so that has been explicitly removed. Test: mmma -j bootable/recovery Test: Run recovery_unit_test on marlin. Test: `Run graphics test` on blueline. Change-Id: I69ce001a9ec9e3ac851edb6ec4d3fa11f4aaea08
196 lines
6.1 KiB
C++
196 lines
6.1 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.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <stdint.h>
|
|
#include <sys/types.h>
|
|
|
|
#include <functional>
|
|
#include <memory>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include <android-base/macros.h>
|
|
|
|
//
|
|
// Graphics.
|
|
//
|
|
|
|
class GRSurface {
|
|
public:
|
|
virtual ~GRSurface();
|
|
|
|
// Creates and returns a GRSurface instance that's sufficient for storing an image of the given
|
|
// size. The starting address of the surface data is aligned to SURFACE_DATA_ALIGNMENT. Returns
|
|
// the created GRSurface instance (in std::unique_ptr), or nullptr on error.
|
|
static std::unique_ptr<GRSurface> Create(int width, int height, int row_bytes, int pixel_bytes,
|
|
size_t data_size);
|
|
|
|
virtual uint8_t* data() {
|
|
return data_;
|
|
}
|
|
|
|
const uint8_t* data() const {
|
|
return const_cast<const uint8_t*>(const_cast<GRSurface*>(this)->data());
|
|
}
|
|
|
|
int width;
|
|
int height;
|
|
int row_bytes;
|
|
int pixel_bytes;
|
|
|
|
protected:
|
|
GRSurface(int width, int height, int row_bytes, int pixel_bytes)
|
|
: width(width), height(height), row_bytes(row_bytes), pixel_bytes(pixel_bytes) {}
|
|
|
|
private:
|
|
uint8_t* data_{ nullptr };
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(GRSurface);
|
|
};
|
|
|
|
struct GRFont {
|
|
GRSurface* texture;
|
|
int char_width;
|
|
int char_height;
|
|
};
|
|
|
|
enum class GRRotation : int {
|
|
NONE = 0,
|
|
RIGHT = 1,
|
|
DOWN = 2,
|
|
LEFT = 3,
|
|
};
|
|
|
|
enum class PixelFormat : int {
|
|
UNKNOWN = 0,
|
|
ABGR = 1,
|
|
RGBX = 2,
|
|
BGRA = 3,
|
|
};
|
|
|
|
// Initializes the graphics backend and loads font file. Returns 0 on success, or -1 on error. Note
|
|
// that the font initialization failure would be non-fatal, as caller may not need to draw any text
|
|
// at all. Caller can check the font initialization result via gr_sys_font() as needed.
|
|
int gr_init();
|
|
|
|
// Frees the allocated resources. The function is idempotent, and safe to be called if gr_init()
|
|
// didn't finish successfully.
|
|
void gr_exit();
|
|
|
|
int gr_fb_width();
|
|
int gr_fb_height();
|
|
|
|
void gr_flip();
|
|
void gr_fb_blank(bool blank);
|
|
|
|
// Clears entire surface to current color.
|
|
void gr_clear();
|
|
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_texticon(int x, int y, const GRSurface* icon);
|
|
|
|
const GRFont* gr_sys_font();
|
|
int gr_init_font(const char* name, GRFont** dest);
|
|
void gr_text(const GRFont* font, int x, int y, const char* s, bool bold);
|
|
// Returns -1 if font is nullptr.
|
|
int gr_measure(const GRFont* font, const char* s);
|
|
// Returns -1 if font is nullptr.
|
|
int gr_font_size(const GRFont* font, int* x, int* y);
|
|
|
|
void gr_blit(const GRSurface* source, int sx, int sy, int w, int h, int dx, int dy);
|
|
unsigned int gr_get_width(const GRSurface* surface);
|
|
unsigned int gr_get_height(const GRSurface* surface);
|
|
|
|
// Sets rotation, flips gr_fb_width/height if 90 degree rotation difference
|
|
void gr_rotate(GRRotation rotation);
|
|
|
|
// Returns the current PixelFormat being used.
|
|
PixelFormat gr_pixel_format();
|
|
|
|
//
|
|
// Input events.
|
|
//
|
|
|
|
struct input_event;
|
|
|
|
using ev_callback = std::function<int(int fd, uint32_t epevents)>;
|
|
using ev_set_key_callback = std::function<int(int code, int value)>;
|
|
|
|
int ev_init(ev_callback input_cb, bool allow_touch_inputs = false);
|
|
void ev_exit();
|
|
int ev_add_fd(int fd, ev_callback cb);
|
|
void ev_iterate_available_keys(const std::function<void(int)>& f);
|
|
void ev_iterate_touch_inputs(const std::function<void(int)>& action);
|
|
int ev_sync_key_state(const ev_set_key_callback& set_key_cb);
|
|
|
|
// 'timeout' has the same semantics as poll(2).
|
|
// 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, input_event* ev);
|
|
void ev_dispatch();
|
|
int ev_get_epollfd();
|
|
|
|
//
|
|
// Resources
|
|
//
|
|
|
|
bool matches_locale(const std::string& prefix, const std::string& locale);
|
|
|
|
// 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, GRSurface** 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, int* fps,
|
|
GRSurface*** pSurface);
|
|
|
|
// Load a single alpha surface from a grayscale PNG image.
|
|
int res_create_alpha_surface(const char* name, GRSurface** 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
|
|
// bootable/recovery/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,
|
|
GRSurface** pSurface);
|
|
|
|
// Return a list of locale strings embedded in |png_name|. Return a empty list in case of failure.
|
|
std::vector<std::string> get_locales_in_png(const std::string& png_name);
|
|
|
|
// Free a surface allocated by any of the res_create_*_surface()
|
|
// functions.
|
|
void res_free_surface(GRSurface* surface);
|