Update Scroll Panel Example

This commit is contained in:
Demizdor 2019-02-12 18:38:47 +02:00
parent af7a2d1993
commit db3753dd94

View File

@ -12,6 +12,9 @@
* COMPILATION (Windows - MinGW):
* gcc -o $(NAME_PART).exe $(FILE_NAME) -I../../src -lraylib -lopengl32 -lgdi32 -std=c99
*
* COMPILATION (Linux - gcc):
* gcc -o $(NAME_PART) $(FILE_NAME) -I../../src -lraylib -std=c99
*
* LICENSE: zlib/libpng
*
* Copyright (c) 2019 Vlad Adrian (@Demizdor) and Ramon Santamaria (@raysan5)
@ -23,6 +26,10 @@
#define RAYGUI_IMPLEMENTATION
#include "../src/raygui.h"
bool contentArea = true;
Rectangle panelContentRec = {0, 0, 340, 340 };
void ChangeStyleUI(void);
//------------------------------------------------------------------------------------
// Program main entry point
//------------------------------------------------------------------------------------
@ -30,14 +37,13 @@ int main()
{
// Initialization
//---------------------------------------------------------------------------------------
const int screenWidth = 400;
const int screenWidth = 800;
const int screenHeight = 450;
InitWindow(screenWidth, screenHeight, "raygui - GuiScrollPanel()");
Rectangle panelRec = { 20,40,200,150 };
Rectangle panelContentRec = { 0,0,340,340 };
Vector2 panelScroll = { 99, -20 };
Rectangle panelRec = {20, 40, 200, 150 };
Vector2 panelScroll = {99, -20};
SetTargetFPS(60);
//---------------------------------------------------------------------------------------
@ -52,21 +58,23 @@ int main()
// Draw
//----------------------------------------------------------------------------------
BeginDrawing();
BeginDrawing();
ClearBackground(RAYWHITE);
ClearBackground(RAYWHITE);
DrawText(TextFormat("[%f, %f]", panelScroll.x, panelScroll.y), 4, 4, 20, RED);
Rectangle view = GuiScrollPanel(panelRec, panelContentRec, &panelScroll);
BeginScissorMode(view.x, view.y, view.width, view.height);
GuiGrid((Rectangle){panelRec.x+panelScroll.x, panelRec.y+panelScroll.y, panelContentRec.width, panelContentRec.height}, 16, 3);
GuiGrid((Rectangle){panelRec.x + panelScroll.x, panelRec.y + panelScroll.y, panelContentRec.width, panelContentRec.height}, 16, 3);
EndScissorMode();
DrawRectangle(panelRec.x+panelScroll.x, panelRec.y+panelScroll.y, panelContentRec.width, panelContentRec.height, Fade(RED, 0.1));
EndDrawing();
if(contentArea)
DrawRectangle(panelRec.x + panelScroll.x, panelRec.y + panelScroll.y, panelContentRec.width, panelContentRec.height, Fade(RED, 0.1));
ChangeStyleUI();
EndDrawing();
//----------------------------------------------------------------------------------
}
@ -76,4 +84,62 @@ int main()
//--------------------------------------------------------------------------------------
return 0;
}
void ChangeStyleUI()
{
GuiGroupBox((Rectangle){550,170,220,205}, "SCROLLBAR STYLE");
int style = GuiGetStyle(SCROLLBAR, SCROLLBAR_BORDER);
GuiLabel((Rectangle){555,195,110,10}, "SCROLLBAR_BORDER");
GuiSpinner((Rectangle){670,190,90,20}, &style, 0, 6, false);
GuiSetStyle(SCROLLBAR, SCROLLBAR_BORDER, style);
style = GuiGetStyle(SCROLLBAR, SCROLLBAR_ARROWS_SIZE);
GuiLabel((Rectangle){555,220,110,10}, "ARROWS_SIZE");
GuiSpinner((Rectangle){670,215,90,20}, &style, 4, 14, false);
GuiSetStyle(SCROLLBAR, SCROLLBAR_ARROWS_SIZE, style);
style = GuiGetStyle(SCROLLBAR, SCROLLBAR_PADDING);
GuiLabel((Rectangle){555,245,110,10}, "SCROLLBAR_PADDING");
GuiSpinner((Rectangle){670,240,90,20}, &style, 0, 14, false);
GuiSetStyle(SCROLLBAR, SCROLLBAR_PADDING, style);
style = GuiCheckBox((Rectangle){565,280,20,20}, "SHOW_SPINNER_BUTTONS", GuiGetStyle(SCROLLBAR, SCROLLBAR_SHOW_SPINNER_BUTTONS));
GuiSetStyle(SCROLLBAR, SCROLLBAR_SHOW_SPINNER_BUTTONS, style);
style = GuiGetStyle(SCROLLBAR, SCROLLBAR_SLIDER_PADDING);
GuiLabel((Rectangle){555,325,110,10}, "SLIDER_PADDING");
GuiSpinner((Rectangle){670,320,90,20}, &style, 0, 14, false);
GuiSetStyle(SCROLLBAR, SCROLLBAR_SLIDER_PADDING, style);
style = GuiGetStyle(SCROLLBAR, SCROLLBAR_SLIDER_SIZE);
GuiLabel((Rectangle){555,350,110,10}, "SLIDER_SIZE");
GuiSpinner((Rectangle){670,345,90,20}, &style, 2, 100, false);
GuiSetStyle(SCROLLBAR, SCROLLBAR_SLIDER_SIZE, style);
//----------------------------------------------------------
GuiGroupBox((Rectangle){550,20,220,135}, "SCROLLPANEL STYLE");
style = GuiGetStyle(LISTVIEW, SCROLLBAR_WIDTH);
GuiLabel((Rectangle){555,35,110,10}, "SCROLLBAR_WIDTH");
GuiSpinner((Rectangle){670,30,90,20}, &style, 6, 30, false);
GuiSetStyle(LISTVIEW, SCROLLBAR_WIDTH, style);
style = GuiGetStyle(DEFAULT, BORDER_WIDTH);
GuiLabel((Rectangle){555,60,110,10}, "BORDER_WIDTH");
GuiSpinner((Rectangle){670,55,90,20}, &style, 0, 20, false);
GuiSetStyle(DEFAULT, BORDER_WIDTH, style);
contentArea = GuiCheckBox((Rectangle){565,80,20,20}, "SHOW CONTENT AREA", contentArea);
const char* text = GuiGetStyle(LISTVIEW, SCROLLBAR_SIDE) == SCROLLBAR_LEFT_SIDE ? "SCROLLBAR: LEFT" : "SCROLLBAR: RIGHT";
style = GuiToggle((Rectangle){560,110,200,35}, text, GuiGetStyle(LISTVIEW, SCROLLBAR_SIDE));
GuiSetStyle(LISTVIEW, SCROLLBAR_SIDE, style);
//----------------------------------------------------------
panelContentRec.width = GuiSliderBar((Rectangle){590,385,145,15}, "WIDTH", panelContentRec.width, 1, 600, true);
panelContentRec.height = GuiSliderBar((Rectangle){590,410,145,15}, "HEIGHT", panelContentRec.height, 1, 400, true);
}