RetroArch/menu/menu_driver.h

388 lines
8.9 KiB
C
Raw Normal View History

/* RetroArch - A frontend for libretro.
* Copyright (C) 2010-2014 - Hans-Kristian Arntzen
2015-01-07 17:46:50 +01:00
* Copyright (C) 2011-2015 - Daniel De Matteis
*
* RetroArch is free software: you can redistribute it and/or modify it under the terms
* of the GNU General Public License as published by the Free Software Found-
* ation, either version 3 of the License, or (at your option) any later version.
*
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
* PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with RetroArch.
* If not, see <http://www.gnu.org/licenses/>.
*/
2015-01-12 21:22:50 +01:00
#ifndef __MENU_DRIVER_H__
#define __MENU_DRIVER_H__
#include <stddef.h>
#include <stdint.h>
#include <boolean.h>
#include <retro_miscellaneous.h>
2015-02-24 00:01:45 +01:00
#include <queues/message_queue.h>
#include "menu_animation.h"
2015-05-13 16:18:43 +02:00
#include "menu_displaylist.h"
#include "menu_list.h"
#include "menu_navigation.h"
2015-06-03 11:24:53 +02:00
#include "menu_setting.h"
2015-06-09 03:07:19 +02:00
#include "../libretro.h"
#include "../playlist.h"
2015-06-08 15:00:04 +02:00
#ifdef HAVE_LIBRETRODB
#include "../database_info.h"
#endif
#ifdef __cplusplus
extern "C" {
#endif
#define MENU_MAX_BUTTONS 219
#define MENU_MAX_AXES 32
#define MENU_MAX_HATS 4
2015-01-05 01:58:00 +01:00
#ifndef MAX_USERS
#define MAX_USERS 16
#endif
typedef enum
{
MENU_IMAGE_NONE = 0,
MENU_IMAGE_WALLPAPER,
MENU_IMAGE_BOXART,
} menu_image_type_t;
struct menu_bind_state_port
{
bool buttons[MENU_MAX_BUTTONS];
int16_t axes[MENU_MAX_AXES];
uint16_t hats[MENU_MAX_HATS];
};
struct menu_bind_axis_state
{
2014-09-02 16:13:42 +02:00
/* Default axis state. */
int16_t rested_axes[MENU_MAX_AXES];
2014-09-02 16:13:42 +02:00
/* Locked axis state. If we configured an axis,
* avoid having the same axis state trigger something again right away. */
int16_t locked_axes[MENU_MAX_AXES];
};
struct menu_bind_state
{
struct retro_keybind *target;
2014-09-02 16:13:42 +02:00
/* For keyboard binding. */
int64_t timeout_end;
unsigned begin;
unsigned last;
2014-12-05 13:48:54 +01:00
unsigned user;
2015-01-05 01:58:00 +01:00
struct menu_bind_state_port state[MAX_USERS];
struct menu_bind_axis_state axis_state[MAX_USERS];
bool skip;
};
typedef struct menu_framebuf
{
uint16_t *data;
unsigned width;
unsigned height;
size_t pitch;
} menu_framebuf_t;
typedef struct
{
2014-10-10 15:52:12 +02:00
void *userdata;
2015-03-06 16:00:46 +01:00
/* Delta timing */
float dt;
retro_time_t cur_time;
retro_time_t old_time;
2014-09-28 10:19:44 +00:00
/* Used for key repeat */
2015-02-11 21:48:20 +01:00
struct
{
2015-03-06 16:00:46 +01:00
float timer;
float count;
2015-02-11 21:48:20 +01:00
} delay;
2014-10-26 22:31:53 +01:00
size_t begin;
2015-04-04 21:26:11 +02:00
unsigned header_height;
2015-04-20 21:22:55 +07:00
float scroll_y;
menu_list_t *menu_list;
2015-02-14 00:47:42 +01:00
menu_navigation_t navigation;
2015-02-11 21:43:16 +01:00
struct
{
size_t selection_ptr;
} categories;
bool need_refresh;
2015-02-27 08:52:44 +01:00
bool nonblocking_refresh;
bool msg_force;
bool push_start_screen;
bool defer_core;
char deferred_path[PATH_MAX_LENGTH];
/* This buffer can be used to display generic OK messages to the user.
* Fill it and call
2015-03-21 22:55:50 +01:00
* menu_list_push(driver->menu->menu_stack, "", "message", 0, 0);
*/
char message_contents[PATH_MAX_LENGTH];
2015-02-24 00:01:45 +01:00
msg_queue_t *msg_queue;
char default_glslp[PATH_MAX_LENGTH];
char default_cgp[PATH_MAX_LENGTH];
menu_framebuf_t frame_buf;
2015-04-24 23:06:04 +02:00
struct
{
void *buf;
int size;
const uint8_t *framebuf;
bool alloc_framebuf;
} font;
2014-07-28 19:37:25 +02:00
bool load_no_content;
2015-01-19 21:24:08 +01:00
struct video_shader *shader;
struct menu_bind_state binds;
2014-10-25 22:42:19 +02:00
struct
{
2014-10-26 00:37:33 +02:00
int16_t dx;
int16_t dy;
2014-10-25 22:42:19 +02:00
int16_t x;
int16_t y;
2015-03-30 02:09:25 +01:00
int16_t screen_x;
int16_t screen_y;
2014-10-26 00:37:33 +02:00
bool left;
bool right;
bool oldleft;
bool oldright;
bool wheelup;
bool wheeldown;
bool hwheelup;
bool hwheeldown;
2015-03-10 15:22:46 +01:00
bool scrollup;
bool scrolldown;
2014-10-27 00:55:14 +01:00
unsigned ptr;
2014-10-25 22:42:19 +02:00
} mouse;
struct
{
2015-04-04 21:26:11 +02:00
int16_t x;
int16_t y;
int16_t dx;
int16_t dy;
int16_t old_x;
int16_t old_y;
2015-04-04 21:26:11 +02:00
int16_t start_x;
int16_t start_y;
bool pressed[2];
bool oldpressed[2];
bool dragging;
bool back;
bool oldback;
unsigned ptr;
} pointer;
struct
{
const char **buffer;
const char *label;
2014-08-25 14:53:03 +02:00
const char *label_setting;
bool display;
unsigned type;
unsigned idx;
} keyboard;
struct
{
bool is_updated;
} label;
struct
{
bool dirty;
} framebuf;
struct
{
bool active;
} action;
struct
{
unsigned joypad;
uint64_t mouse;
} input;
rarch_setting_t *list_settings;
2015-02-11 00:40:18 +01:00
animation_t *animation;
bool animation_is_active;
2015-05-26 04:27:21 +02:00
content_playlist_t *playlist;
char db_playlist_file[PATH_MAX_LENGTH];
} menu_handle_t;
typedef struct menu_ctx_driver
{
void (*set_texture)(void);
void (*render_messagebox)(const char *msg);
void (*render)(void);
void (*frame)(void);
void* (*init)(void);
void (*free)(void*);
void (*context_reset)(void);
void (*context_destroy)(void);
void (*populate_entries)(const char *path, const char *label,
2015-02-11 20:40:48 +01:00
unsigned k);
void (*toggle)(bool);
void (*navigation_clear)(bool);
void (*navigation_decrement)(void);
void (*navigation_increment)(void);
void (*navigation_set)(bool);
void (*navigation_set_last)(void);
void (*navigation_descend_alphabet)(size_t *);
void (*navigation_ascend_alphabet)(size_t *);
void (*list_insert)(file_list_t *list, const char *, const char *, size_t);
void (*list_free)(file_list_t *list, size_t, size_t);
void (*list_clear)(file_list_t *list);
void (*list_cache)(menu_list_type_t, unsigned);
size_t(*list_get_size)(void *data, menu_list_type_t type);
void *(*list_get_entry)(void *data, menu_list_type_t type, unsigned i);
2015-02-11 20:40:48 +01:00
void (*list_set_selection)(file_list_t *list);
int (*bind_init)(menu_file_list_cbs_t *cbs,
2015-06-08 16:01:57 +02:00
const char *path, const char *label, unsigned type, size_t idx,
const char *elem0, const char *elem1,
uint32_t label_hash, uint32_t menu_label_hash);
bool (*load_image)(void *data, menu_image_type_t type);
const char *ident;
bool (*perform_action)(void* data, unsigned action);
} menu_ctx_driver_t;
2015-01-12 21:22:50 +01:00
extern menu_ctx_driver_t menu_ctx_rmenu;
extern menu_ctx_driver_t menu_ctx_rmenu_xui;
extern menu_ctx_driver_t menu_ctx_rgui;
extern menu_ctx_driver_t menu_ctx_glui;
extern menu_ctx_driver_t menu_ctx_xmb;
2015-03-09 14:39:39 +01:00
extern menu_ctx_driver_t menu_ctx_null;
2015-01-12 21:22:50 +01:00
/**
* menu_driver_find_handle:
* @index : index of driver to get handle to.
*
* Returns: handle to menu driver at index. Can be NULL
* if nothing found.
**/
const void *menu_driver_find_handle(int index);
/**
* menu_driver_find_ident:
* @index : index of driver to get handle to.
*
* Returns: Human-readable identifier of menu driver at index. Can be NULL
* if nothing found.
**/
const char *menu_driver_find_ident(int index);
/**
* config_get_menu_driver_options:
*
* Get an enumerated list of all menu driver names,
* separated by '|'.
*
* Returns: string listing of all menu driver names,
* separated by '|'.
**/
const char* config_get_menu_driver_options(void);
void find_menu_driver(void);
void init_menu(void);
menu_handle_t *menu_driver_get_ptr(void);
2015-03-22 05:21:14 +01:00
void menu_driver_navigation_increment(void);
void menu_driver_navigation_decrement(void);
void menu_driver_navigation_clear(bool pending_push);
void menu_driver_navigation_set(bool scroll);
void menu_driver_navigation_set_last(void);
void menu_driver_set_texture(void);
2015-03-22 05:27:19 +01:00
void menu_driver_frame(void);
2015-03-22 05:21:14 +01:00
void menu_driver_context_reset(void);
void menu_driver_free(menu_handle_t *menu);
2015-03-22 05:35:46 +01:00
void menu_driver_render(void);
2015-03-22 06:02:02 +01:00
void menu_driver_toggle(bool latch);
2015-03-22 06:37:26 +01:00
void menu_driver_render_messagebox(const char *msg);
void menu_driver_populate_entries(const char *path, const char *label,
unsigned k);
bool menu_driver_load_image(void *data, menu_image_type_t type);
2015-03-22 06:48:03 +01:00
2015-03-22 07:07:07 +01:00
void menu_driver_navigation_descend_alphabet(size_t *);
void menu_driver_navigation_ascend_alphabet(size_t *);
void menu_driver_list_cache(menu_list_type_t type, unsigned action);
void menu_driver_list_free(file_list_t *list, size_t i, size_t list_size);
void menu_driver_list_insert(file_list_t *list, const char *path,
const char *label, unsigned type, size_t list_size);
void menu_driver_list_clear(file_list_t *list);
2015-06-07 15:43:03 +02:00
size_t menu_driver_list_get_size(menu_list_type_t type);
void menu_driver_list_set_selection(file_list_t *list);
void *menu_driver_list_get_entry(menu_list_type_t type, unsigned i);
const menu_ctx_driver_t *menu_ctx_driver_get_ptr(void);
void menu_driver_context_destroy(void);
bool menu_driver_alive(void);
void menu_driver_set_alive(void);
void menu_driver_unset_alive(void);
int menu_driver_bind_init(menu_file_list_cbs_t *cbs,
const char *path, const char *label, unsigned type, size_t idx,
const char *elem0, const char *elem1,
uint32_t label_hash, uint32_t menu_label_hash);
2015-06-08 14:53:50 +02:00
/* HACK */
extern unsigned int rdb_entry_start_game_selection_ptr;
#ifdef __cplusplus
}
#endif
#endif