Added textmenu
This commit is contained in:
@ -71,14 +71,15 @@
|
|||||||
|
|
||||||
// User Interface Objects
|
// User Interface Objects
|
||||||
#include "ui/grid.h"
|
#include "ui/grid.h"
|
||||||
|
#include "ui/label.h"
|
||||||
#include "ui/menuv2.h"
|
#include "ui/menuv2.h"
|
||||||
|
#include "ui/rectangle.h"
|
||||||
|
#include "ui/textmenu.h"
|
||||||
|
|
||||||
#include "ui/frame.h"
|
#include "ui/frame.h"
|
||||||
#include "ui/image.h"
|
#include "ui/image.h"
|
||||||
#include "ui/label.h"
|
|
||||||
#include "ui/menu.h"
|
#include "ui/menu.h"
|
||||||
#include "ui/menulist.h"
|
#include "ui/menulist.h"
|
||||||
#include "ui/rectangle.h"
|
|
||||||
|
|
||||||
// Utility Objects
|
// Utility Objects
|
||||||
#include "util/array.h"
|
#include "util/array.h"
|
||||||
|
@ -26,6 +26,7 @@ typedef struct {
|
|||||||
primitive_t primitive;
|
primitive_t primitive;
|
||||||
texture_t texture;
|
texture_t texture;
|
||||||
shader_t shader;
|
shader_t shader;
|
||||||
|
font_t font;
|
||||||
|
|
||||||
gridbruh_t items[GRID_BRUH_COUNT];
|
gridbruh_t items[GRID_BRUH_COUNT];
|
||||||
} sandboxscene_t;
|
} sandboxscene_t;
|
@ -29,7 +29,7 @@ typedef struct {
|
|||||||
|
|
||||||
/** Callback to receive when a grid child is to be resized */
|
/** Callback to receive when a grid child is to be resized */
|
||||||
typedef void gridchildresizecallback_t(
|
typedef void gridchildresizecallback_t(
|
||||||
void *user, int32_t i,
|
void *user, uint8_t i,
|
||||||
float screenWidth, float screenHeight,
|
float screenWidth, float screenHeight,
|
||||||
float x, float y,
|
float x, float y,
|
||||||
float width, float height
|
float width, float height
|
||||||
@ -47,7 +47,6 @@ typedef struct {
|
|||||||
typedef struct {
|
typedef struct {
|
||||||
gridchildbreakpoint_t breakpoints[GRID_BREAKPOINT_COUNT];
|
gridchildbreakpoint_t breakpoints[GRID_BREAKPOINT_COUNT];
|
||||||
uint8_t breakpointCount;
|
uint8_t breakpointCount;
|
||||||
gridchildresizecallback_t *onResize;
|
|
||||||
} gridchild_t;
|
} gridchild_t;
|
||||||
|
|
||||||
/** Definitio of a grid */
|
/** Definitio of a grid */
|
||||||
@ -65,9 +64,10 @@ typedef struct {
|
|||||||
/** Internal size reference, used for caching resize events */
|
/** Internal size reference, used for caching resize events */
|
||||||
float width;
|
float width;
|
||||||
float height;
|
float height;
|
||||||
float x;
|
|
||||||
float y;
|
|
||||||
|
|
||||||
/** Pointer to any custom user data */
|
/** Pointer to any custom user data */
|
||||||
void *user;
|
void *user;
|
||||||
|
|
||||||
|
/** Callback to listen for when children are resized */
|
||||||
|
gridchildresizecallback_t *onResize;
|
||||||
} grid_t;
|
} grid_t;
|
31
include/dawn/ui/textmenu.h
Normal file
31
include/dawn/ui/textmenu.h
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
// Copyright (c) 2021 Dominic Masters
|
||||||
|
//
|
||||||
|
// This software is released under the MIT License.
|
||||||
|
// https://opensource.org/licenses/MIT
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#include "../libs.h"
|
||||||
|
#include "menuv2.h"
|
||||||
|
#include "grid.h"
|
||||||
|
#include "label.h"
|
||||||
|
#include "rectangle.h"
|
||||||
|
|
||||||
|
typedef void textmenucallback_t(void *user, uint8_t i, char *text);
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
float x, y;
|
||||||
|
float width, height;
|
||||||
|
} textmenulabelinfo_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
menuv2_t menu;
|
||||||
|
char *texts[GRID_CHILD_COUNT];
|
||||||
|
|
||||||
|
font_t *font;
|
||||||
|
label_t labels[GRID_CHILD_COUNT];
|
||||||
|
rectangle_t rectangle;
|
||||||
|
textmenulabelinfo_t labelInfo[GRID_CHILD_COUNT];
|
||||||
|
|
||||||
|
textmenucallback_t *onSelect;
|
||||||
|
void *user;
|
||||||
|
} textmenu_t;
|
@ -7,51 +7,30 @@
|
|||||||
|
|
||||||
#include "sandboxscene.h"
|
#include "sandboxscene.h"
|
||||||
|
|
||||||
menuv2_t menu;
|
textmenu_t menu;
|
||||||
|
|
||||||
|
|
||||||
void gridTest(
|
|
||||||
void *user, int32_t i,
|
|
||||||
float screenWidth, float screenHeight,
|
|
||||||
float x, float y,
|
|
||||||
float width, float height
|
|
||||||
) {
|
|
||||||
sandboxscene_t *game = (sandboxscene_t *)user;
|
|
||||||
game->items[i].x = x;
|
|
||||||
game->items[i].y = y;
|
|
||||||
game->items[i].width = width;
|
|
||||||
game->items[i].height = height;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool sandboxSceneInit(sandboxscene_t *game) {
|
bool sandboxSceneInit(sandboxscene_t *game) {
|
||||||
menu2Init(&menu);
|
assetFontLoad(&game->font, "fonts/opensans/OpenSans-Regular.ttf");
|
||||||
gridAddBreakpoint(&menu.grid, -1, 3, 1, 0, 0);
|
|
||||||
gridchild_t *child = gridAddChild(&menu.grid);
|
|
||||||
gridChildAddBreakpoint(child, 0,0, 1,1);
|
|
||||||
|
|
||||||
child = gridAddChild(&menu.grid);
|
|
||||||
gridChildAddBreakpoint(child, 0,1, 1,1);
|
|
||||||
|
|
||||||
child = gridAddChild(&menu.grid);
|
|
||||||
gridChildAddBreakpoint(child, 0,2, 1,1);
|
|
||||||
|
|
||||||
|
|
||||||
assetTextureLoad(&game->texture, "test_texture.png");
|
assetTextureLoad(&game->texture, "test_texture.png");
|
||||||
assetShaderLoad(&game->shader,
|
assetShaderLoad(&game->shader,
|
||||||
"shaders/textured.vert", "shaders/textured.frag"
|
"shaders/textured.vert", "shaders/textured.frag"
|
||||||
);
|
);
|
||||||
quadInit(&game->primitive, 0,
|
|
||||||
0,0,0,0,
|
textMenuInit(&menu, &game->font);
|
||||||
1,1,1,1
|
gridAddBreakpoint(&menu.menu.grid, -1, 3, 1, 0, 0);
|
||||||
);
|
gridchild_t *child = textMenuListAdd(&menu, "First");
|
||||||
|
gridChildAddBreakpoint(child, 0,0, 1,1);
|
||||||
|
|
||||||
|
child = textMenuListAdd(&menu, "Second");
|
||||||
|
gridChildAddBreakpoint(child, 0,1, 1,1);
|
||||||
|
|
||||||
|
child = textMenuListAdd(&menu, "Third");
|
||||||
|
gridChildAddBreakpoint(child, 0,2, 1,1);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void sandboxSceneUpdate(sandboxscene_t *game, engine_t *engine) {
|
void sandboxSceneUpdate(sandboxscene_t *game, engine_t *engine) {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
cameraLookAt(&game->camera,
|
cameraLookAt(&game->camera,
|
||||||
0, 0, 10,
|
0, 0, 10,
|
||||||
0, 0, 0
|
0, 0, 0
|
||||||
@ -67,29 +46,13 @@ void sandboxSceneUpdate(sandboxscene_t *game, engine_t *engine) {
|
|||||||
shaderUseCamera(&game->shader, &game->camera);
|
shaderUseCamera(&game->shader, &game->camera);
|
||||||
shaderUseTexture(&game->shader, &game->texture);
|
shaderUseTexture(&game->shader, &game->texture);
|
||||||
|
|
||||||
menu2Update(&menu, engine);
|
gridSetSize(&menu.menu.grid,
|
||||||
gridSetSize(&menu.grid,
|
|
||||||
engine->render.width, engine->render.height,
|
|
||||||
engine->render.width, engine->render.height,
|
engine->render.width, engine->render.height,
|
||||||
|
engine->render.width, FONT_LINE_HEIGHT * fontGetScale(16.0f) * 3,
|
||||||
0, 0
|
0, 0
|
||||||
);
|
);
|
||||||
|
menu2Update(&menu.menu, engine);
|
||||||
// gridSetSize(&grid,
|
textMenuListRender(&menu, &game->shader, 0, 0);
|
||||||
// engine->render.width, engine->render.height,
|
|
||||||
// engine->render.width, engine->render.height,
|
|
||||||
// 0, 0
|
|
||||||
// );
|
|
||||||
|
|
||||||
|
|
||||||
for(uint8_t i = 0; i < GRID_BRUH_COUNT; i++) {
|
|
||||||
gridbruh_t *b = game->items + i;
|
|
||||||
shaderUsePositionAndScale(&game->shader,
|
|
||||||
b->x, b->y, 0,
|
|
||||||
0, 0, 0,
|
|
||||||
b->width, b->height, 1
|
|
||||||
);
|
|
||||||
primitiveDraw(&game->primitive, 0, -1);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void sandboxSceneDispose(sandboxscene_t *game) {
|
void sandboxSceneDispose(sandboxscene_t *game) {
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
#include "../../ui/grid.h"
|
#include "../../ui/grid.h"
|
||||||
#include "../../ui/menuv2.h"
|
#include "../../ui/menuv2.h"
|
||||||
|
#include "../../ui/textmenu.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initialize the sandbox scene test game.
|
* Initialize the sandbox scene test game.
|
||||||
|
@ -13,8 +13,7 @@ void gridInit(grid_t *grid) {
|
|||||||
grid->childCount = 0x00;
|
grid->childCount = 0x00;
|
||||||
grid->width = 0;
|
grid->width = 0;
|
||||||
grid->height = 0;
|
grid->height = 0;
|
||||||
grid->x = 0;
|
grid->onResize = NULL;
|
||||||
grid->y = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t gridAddBreakpoint(
|
uint8_t gridAddBreakpoint(
|
||||||
@ -36,7 +35,6 @@ uint8_t gridAddBreakpoint(
|
|||||||
gridchild_t * gridAddChild(grid_t *grid) {
|
gridchild_t * gridAddChild(grid_t *grid) {
|
||||||
gridchild_t *child = grid->children + grid->childCount++;
|
gridchild_t *child = grid->children + grid->childCount++;
|
||||||
child->breakpointCount = 0;
|
child->breakpointCount = 0;
|
||||||
child->onResize = NULL;
|
|
||||||
return child;
|
return child;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -73,18 +71,13 @@ void gridSetSize(grid_t *grid,
|
|||||||
float sizeCol, sizeRow, gx, gy, gw, gh;
|
float sizeCol, sizeRow, gx, gy, gw, gh;
|
||||||
|
|
||||||
// Need to resize?
|
// Need to resize?
|
||||||
if((
|
if(grid->width == width && grid->height == height) {
|
||||||
grid->width == width && grid->height == height &&
|
|
||||||
grid->x == x && grid->y == y
|
|
||||||
)) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update properties
|
// Update properties
|
||||||
grid->width = width;
|
grid->width = width;
|
||||||
grid->height = height;
|
grid->height = height;
|
||||||
grid->x = x;
|
|
||||||
grid->y = y;
|
|
||||||
|
|
||||||
// Determine breakpoint
|
// Determine breakpoint
|
||||||
breakpoint = 0xFF;
|
breakpoint = 0xFF;
|
||||||
@ -100,11 +93,12 @@ void gridSetSize(grid_t *grid,
|
|||||||
sizeCol = (width - (gridbp->gutterX * (gridbp->columns-1))) / gridbp->columns;
|
sizeCol = (width - (gridbp->gutterX * (gridbp->columns-1))) / gridbp->columns;
|
||||||
sizeRow = (height - (gridbp->gutterY * (gridbp->rows - 1))) / gridbp->rows;
|
sizeRow = (height - (gridbp->gutterY * (gridbp->rows - 1))) / gridbp->rows;
|
||||||
|
|
||||||
|
if(grid->onResize == NULL) return;
|
||||||
|
|
||||||
// Resize children
|
// Resize children
|
||||||
for(i = 0; i < grid->childCount; i++) {
|
for(i = 0; i < grid->childCount; i++) {
|
||||||
// Get the item and the definition.
|
// Get the item and the definition.
|
||||||
child = grid->children + i;
|
child = grid->children + i;
|
||||||
if(child->onResize == NULL) continue;
|
|
||||||
|
|
||||||
childbp = gridChildGetBreakpoint(child, breakpoint);
|
childbp = gridChildGetBreakpoint(child, breakpoint);
|
||||||
|
|
||||||
@ -123,7 +117,7 @@ void gridSetSize(grid_t *grid,
|
|||||||
);
|
);
|
||||||
|
|
||||||
// Fire the resize event.
|
// Fire the resize event.
|
||||||
child->onResize(
|
grid->onResize(
|
||||||
grid->user, i,
|
grid->user, i,
|
||||||
screenWidth, screenHeight,
|
screenWidth, screenHeight,
|
||||||
x + gx, y + gy,
|
x + gx, y + gy,
|
||||||
|
@ -86,6 +86,5 @@ void menu2Update(menuv2_t *menu, engine_t *engine) {
|
|||||||
// Was a target found?
|
// Was a target found?
|
||||||
if(j == GRID_CHILD_COUNT) return;
|
if(j == GRID_CHILD_COUNT) return;
|
||||||
menu->selected = j;
|
menu->selected = j;
|
||||||
printf("Selected %u :: %u x %u \n", j, itembp->x, itembp->y);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
76
src/ui/textmenu.c
Normal file
76
src/ui/textmenu.c
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2021 Dominic Masters
|
||||||
|
*
|
||||||
|
* This software is released under the MIT License.
|
||||||
|
* https://opensource.org/licenses/MIT
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "textmenu.h"
|
||||||
|
|
||||||
|
void _textMenuOnSelect(menuv2_t *menu, uint8_t i) {
|
||||||
|
textmenu_t *textMenu = (textmenu_t *)menu->user;
|
||||||
|
|
||||||
|
if(textMenu->onSelect != NULL) {
|
||||||
|
textMenu->onSelect(textMenu->user, i, textMenu->texts[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void _textMenuOnResize(
|
||||||
|
void *user, uint8_t i,
|
||||||
|
float screenWidth, float screenHeight,
|
||||||
|
float x, float y,
|
||||||
|
float width, float height
|
||||||
|
) {
|
||||||
|
textmenu_t *textMenu = (textmenu_t *)((menuv2_t *)user);
|
||||||
|
label_t *label = textMenu->labels + i;
|
||||||
|
textmenulabelinfo_t *info = textMenu->labelInfo + i;
|
||||||
|
info->x = x;
|
||||||
|
info->y = y;
|
||||||
|
info->width = width;
|
||||||
|
info->height = height;
|
||||||
|
labelSetText(label, textMenu->font, textMenu->texts[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
void textMenuInit(textmenu_t *menu, font_t *font) {
|
||||||
|
menu2Init(&menu->menu);
|
||||||
|
rectangleInit(&menu->rectangle);
|
||||||
|
rectangleSetColor(&menu->rectangle, MENULIST_SELECTION_COLOR);
|
||||||
|
|
||||||
|
menu->menu.user = menu;
|
||||||
|
menu->menu.onSelect = &_textMenuOnSelect;
|
||||||
|
menu->font = font;
|
||||||
|
menu->onSelect = NULL;
|
||||||
|
menu->menu.grid.onResize = &_textMenuOnResize;
|
||||||
|
}
|
||||||
|
|
||||||
|
gridchild_t * textMenuListAdd(textmenu_t *menu, char *item) {
|
||||||
|
menu->texts[menu->menu.grid.childCount] = item;
|
||||||
|
labelInit(menu->labels + menu->menu.grid.childCount);
|
||||||
|
(menu->labels + menu->menu.grid.childCount)->font = menu->font;
|
||||||
|
return gridAddChild(&menu->menu.grid);
|
||||||
|
}
|
||||||
|
|
||||||
|
void textMenuListRender(textmenu_t *menu, shader_t *shader, float x, float y) {
|
||||||
|
uint8_t i;
|
||||||
|
label_t *label;
|
||||||
|
textmenulabelinfo_t *info;
|
||||||
|
|
||||||
|
info = menu->labelInfo + menu->menu.selected;
|
||||||
|
menu->rectangle.width = info->width;
|
||||||
|
menu->rectangle.height = info->height;
|
||||||
|
rectangleRender(&menu->rectangle, shader, info->x, info->y);
|
||||||
|
|
||||||
|
for(i = 0; i < menu->menu.grid.childCount; i++) {
|
||||||
|
label = menu->labels + i;
|
||||||
|
info = menu->labelInfo + i;
|
||||||
|
labelRender(label, shader, x + info->x, y + info->y);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void textMenuDispse(textmenu_t *menu) {
|
||||||
|
uint8_t i;
|
||||||
|
rectangleDispose(&menu->rectangle);
|
||||||
|
for(i = 0; i < menu->menu.grid.childCount; i++) {
|
||||||
|
labelDispose(menu->labels + i);
|
||||||
|
}
|
||||||
|
}
|
58
src/ui/textmenu.h
Normal file
58
src/ui/textmenu.h
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2021 Dominic Masters
|
||||||
|
*
|
||||||
|
* This software is released under the MIT License.
|
||||||
|
* https://opensource.org/licenses/MIT
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#include <dawn/dawn.h>
|
||||||
|
#include "menuv2.h"
|
||||||
|
#include "grid.h"
|
||||||
|
#include "label.h"
|
||||||
|
#include "rectangle.h"
|
||||||
|
|
||||||
|
/** Callback to be notified from the menu when the menu items are selected. */
|
||||||
|
void _textMenuOnSelect(menuv2_t *menu, uint8_t i);
|
||||||
|
|
||||||
|
/** Callback to lisen for resize events from the grid subsystem */
|
||||||
|
void _textMenuOnResize(
|
||||||
|
void *user, uint8_t i,
|
||||||
|
float screenWidth, float screenHeight,
|
||||||
|
float x, float y,
|
||||||
|
float width, float height
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize a text menu item.
|
||||||
|
*
|
||||||
|
* @param menu Menu to initialize.
|
||||||
|
* @param font Font to use during initialization.
|
||||||
|
*/
|
||||||
|
void textMenuInit(textmenu_t *menu, font_t *font);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add text to a menu list.
|
||||||
|
*
|
||||||
|
* @param menu Menu to add to.
|
||||||
|
* @param item Text to add (must be a constant value).
|
||||||
|
* @return The grid subsystem item.
|
||||||
|
*/
|
||||||
|
gridchild_t * textMenuListAdd(textmenu_t *menu, char *item);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Render a text menu list.
|
||||||
|
*
|
||||||
|
* @param menu Menu to render.
|
||||||
|
* @param shader Shader to use.
|
||||||
|
* @param x X position of the menu.
|
||||||
|
* @param y Y position of the menu.
|
||||||
|
*/
|
||||||
|
void textMenuListRender(textmenu_t *menu, shader_t *shader, float x, float y);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Dispose/Cleanup a text menu.
|
||||||
|
*
|
||||||
|
* @param menu Text menu to dispose.
|
||||||
|
*/
|
||||||
|
void textMenuDispse(textmenu_t *menu);
|
Reference in New Issue
Block a user