Integrated the test into the main packge. I'll need to handle a few corner cases here...
This commit is contained in:
parent
ef04c18856
commit
e27781cce7
|
@ -1,18 +0,0 @@
|
||||||
// 4 september 2015
|
|
||||||
#define GLIB_VERSION_MIN_REQUIRED GLIB_VERSION_2_32
|
|
||||||
#define GLIB_VERSION_MAX_ALLOWED GLIB_VERSION_2_32
|
|
||||||
#define GDK_VERSION_MIN_REQUIRED GDK_VERSION_3_4
|
|
||||||
#define GDK_VERSION_MAX_ALLOWED GDK_VERSION_3_4
|
|
||||||
#include <gtk/gtk.h>
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <stddef.h>
|
|
||||||
|
|
||||||
|
|
||||||
extern GType areaWidget_get_type(void);
|
|
||||||
|
|
||||||
#include "ui.h"
|
|
||||||
#include "uipriv.h"
|
|
||||||
|
|
||||||
extern GtkWidget *newArea(uiAreaHandler *ah);
|
|
||||||
extern void areaUpdateScroll(GtkWidget *area);
|
|
||||||
|
|
|
@ -8,6 +8,7 @@ testCFILES = \
|
||||||
test/page3.c \
|
test/page3.c \
|
||||||
test/page4.c \
|
test/page4.c \
|
||||||
test/page5.c \
|
test/page5.c \
|
||||||
|
test/page6.c \
|
||||||
test/spaced.c
|
test/spaced.c
|
||||||
|
|
||||||
testHFILES = \
|
testHFILES = \
|
||||||
|
|
|
@ -42,7 +42,7 @@ int main(int argc, char *argv[])
|
||||||
int i;
|
int i;
|
||||||
const char *err;
|
const char *err;
|
||||||
uiWindow *w;
|
uiWindow *w;
|
||||||
uiBox *page2, *page3, *page4, *page5;
|
uiBox *page2, *page3, *page4, *page5, *page6;
|
||||||
int nomenus = 0;
|
int nomenus = 0;
|
||||||
int startspaced = 0;
|
int startspaced = 0;
|
||||||
|
|
||||||
|
@ -104,6 +104,9 @@ int main(int argc, char *argv[])
|
||||||
page5 = makePage5();
|
page5 = makePage5();
|
||||||
uiTabAppend(mainTab, "Page 5", uiControl(page5));
|
uiTabAppend(mainTab, "Page 5", uiControl(page5));
|
||||||
|
|
||||||
|
page6 = makePage6();
|
||||||
|
uiTabAppend(mainTab, "Page 6", uiControl(page6));
|
||||||
|
|
||||||
if (startspaced)
|
if (startspaced)
|
||||||
setSpaced(1);
|
setSpaced(1);
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,310 @@
|
||||||
|
// 8 october 2015
|
||||||
|
#include "test.h"
|
||||||
|
|
||||||
|
static uiArea *area;
|
||||||
|
static uiCombobox *which;
|
||||||
|
|
||||||
|
struct handler {
|
||||||
|
uiAreaHandler ah;
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct handler handler;
|
||||||
|
|
||||||
|
static void handlerDraw(uiAreaHandler *a, uiArea *area, uiAreaDrawParams *p)
|
||||||
|
{
|
||||||
|
uiDrawPath *path;
|
||||||
|
uiDrawBrush brush;
|
||||||
|
uiDrawStrokeParams sp;
|
||||||
|
|
||||||
|
brush.Type = uiDrawBrushTypeSolid;
|
||||||
|
brush.A = 1;
|
||||||
|
|
||||||
|
brush.R = 1;
|
||||||
|
brush.G = 0;
|
||||||
|
brush.B = 0;
|
||||||
|
path = uiDrawNewPath(uiDrawFillModeWinding);
|
||||||
|
uiDrawPathNewFigure(path, p->ClipX + 5, p->ClipY + 5);
|
||||||
|
uiDrawPathLineTo(path, (p->ClipX + p->ClipWidth) - 5, (p->ClipY + p->ClipHeight) - 5);
|
||||||
|
uiDrawPathEnd(path);
|
||||||
|
sp.Cap = uiDrawLineCapFlat;
|
||||||
|
sp.Join = uiDrawLineJoinMiter;
|
||||||
|
sp.Thickness = 1;
|
||||||
|
sp.MiterLimit = uiDrawDefaultMiterLimit;
|
||||||
|
uiDrawStroke(p->Context, path, &brush, &sp);
|
||||||
|
uiDrawFreePath(path);
|
||||||
|
|
||||||
|
brush.R = 0;
|
||||||
|
brush.G = 0;
|
||||||
|
brush.B = 0.75;
|
||||||
|
path = uiDrawNewPath(uiDrawFillModeWinding);
|
||||||
|
uiDrawPathNewFigure(path, p->ClipX, p->ClipY);
|
||||||
|
uiDrawPathLineTo(path, p->ClipX + p->ClipWidth, p->ClipY);
|
||||||
|
uiDrawPathLineTo(path, 50, 150);
|
||||||
|
uiDrawPathLineTo(path, 50, 50);
|
||||||
|
uiDrawPathCloseFigure(path);
|
||||||
|
uiDrawPathEnd(path);
|
||||||
|
sp.Cap = uiDrawLineCapFlat;
|
||||||
|
sp.Join = uiDrawLineJoinRound;
|
||||||
|
sp.Thickness = 5;
|
||||||
|
uiDrawStroke(p->Context, path, &brush, &sp);
|
||||||
|
uiDrawFreePath(path);
|
||||||
|
|
||||||
|
brush.R = 0;
|
||||||
|
brush.G = 0.75;
|
||||||
|
brush.B = 0;
|
||||||
|
brush.A = 0.5;
|
||||||
|
path = uiDrawNewPath(uiDrawFillModeWinding);
|
||||||
|
uiDrawPathAddRectangle(path, 120, 80, 50, 50);
|
||||||
|
uiDrawPathEnd(path);
|
||||||
|
uiDrawFill(p->Context, path, &brush);
|
||||||
|
uiDrawFreePath(path);
|
||||||
|
brush.A = 1;
|
||||||
|
|
||||||
|
brush.R = 0;
|
||||||
|
brush.G = 0.5;
|
||||||
|
brush.B = 0;
|
||||||
|
path = uiDrawNewPath(uiDrawFillModeWinding);
|
||||||
|
uiDrawPathNewFigure(path, 5.5, 10.5);
|
||||||
|
uiDrawPathLineTo(path, 5.5, 50.5);
|
||||||
|
uiDrawPathEnd(path);
|
||||||
|
sp.Cap = uiDrawLineCapFlat;
|
||||||
|
sp.Join = uiDrawLineJoinMiter;
|
||||||
|
sp.Thickness = 1;
|
||||||
|
sp.MiterLimit = uiDrawDefaultMiterLimit;
|
||||||
|
uiDrawStroke(p->Context, path, &brush, &sp);
|
||||||
|
uiDrawFreePath(path);
|
||||||
|
|
||||||
|
brush.R = 0.5;
|
||||||
|
brush.G = 0.75;
|
||||||
|
brush.B = 0;
|
||||||
|
path = uiDrawNewPath(uiDrawFillModeWinding);
|
||||||
|
uiDrawPathNewFigure(path, 400, 100);
|
||||||
|
uiDrawPathArcTo(path,
|
||||||
|
400, 100,
|
||||||
|
50,
|
||||||
|
30. * (M_PI / 180.),
|
||||||
|
// note the end angle here
|
||||||
|
// in GDI, the second angle to AngleArc() is relative to the start, not to 0
|
||||||
|
330. * (M_PI / 180.));
|
||||||
|
// TODO add a checkbox for this
|
||||||
|
uiDrawPathLineTo(path, 400, 100);
|
||||||
|
uiDrawPathNewFigureWithArc(path,
|
||||||
|
510, 100,
|
||||||
|
50,
|
||||||
|
30. * (M_PI / 180.),
|
||||||
|
330. * (M_PI / 180.));
|
||||||
|
uiDrawPathCloseFigure(path);
|
||||||
|
uiDrawPathEnd(path);
|
||||||
|
sp.Cap = uiDrawLineCapFlat;
|
||||||
|
sp.Join = uiDrawLineJoinMiter;
|
||||||
|
sp.Thickness = 1;
|
||||||
|
sp.MiterLimit = uiDrawDefaultMiterLimit;
|
||||||
|
uiDrawStroke(p->Context, path, &brush, &sp);
|
||||||
|
uiDrawFreePath(path);
|
||||||
|
|
||||||
|
brush.R = 0;
|
||||||
|
brush.G = 0.5;
|
||||||
|
brush.B = 0.75;
|
||||||
|
path = uiDrawNewPath(uiDrawFillModeWinding);
|
||||||
|
uiDrawPathNewFigure(path, 300, 300);
|
||||||
|
uiDrawPathBezierTo(path,
|
||||||
|
350, 320,
|
||||||
|
310, 390,
|
||||||
|
435, 372);
|
||||||
|
uiDrawPathEnd(path);
|
||||||
|
sp.Cap = uiDrawLineCapFlat;
|
||||||
|
sp.Join = uiDrawLineJoinMiter;
|
||||||
|
sp.Thickness = 1;
|
||||||
|
sp.MiterLimit = uiDrawDefaultMiterLimit;
|
||||||
|
uiDrawStroke(p->Context, path, &brush, &sp);
|
||||||
|
uiDrawFreePath(path);
|
||||||
|
|
||||||
|
// based on https://msdn.microsoft.com/en-us/library/windows/desktop/dd756682%28v=vs.85%29.aspx
|
||||||
|
path = uiDrawNewPath(uiDrawFillModeWinding);
|
||||||
|
#define XO 50
|
||||||
|
#define YO 250
|
||||||
|
uiDrawPathNewFigure(path, 0 + XO, 0 + YO);
|
||||||
|
uiDrawPathLineTo(path, 200 + XO, 0 + YO);
|
||||||
|
uiDrawPathBezierTo(path,
|
||||||
|
150 + XO, 50 + YO,
|
||||||
|
150 + XO, 150 + YO,
|
||||||
|
200 + XO, 200 + YO);
|
||||||
|
uiDrawPathLineTo(path, 0 + XO, 200 + YO);
|
||||||
|
uiDrawPathBezierTo(path,
|
||||||
|
50 + XO, 150 + YO,
|
||||||
|
50 + XO, 50 + YO,
|
||||||
|
0 + XO, 0 + YO);
|
||||||
|
uiDrawPathCloseFigure(path);
|
||||||
|
uiDrawPathEnd(path);
|
||||||
|
// first the stroke
|
||||||
|
brush.Type = uiDrawBrushTypeSolid;
|
||||||
|
brush.R = 0;
|
||||||
|
brush.G = 0;
|
||||||
|
brush.B = 0;
|
||||||
|
brush.A = 1;
|
||||||
|
sp.Cap = uiDrawLineCapFlat;
|
||||||
|
sp.Join = uiDrawLineJoinMiter;
|
||||||
|
sp.MiterLimit = uiDrawDefaultMiterLimit;
|
||||||
|
sp.Thickness = 10;
|
||||||
|
uiDrawStroke(p->Context, path, &brush, &sp);
|
||||||
|
// and now the fill
|
||||||
|
{
|
||||||
|
uiDrawBrushGradientStop stops[2];
|
||||||
|
|
||||||
|
stops[0].Pos = 0.0;
|
||||||
|
stops[0].R = 0.0;
|
||||||
|
stops[0].G = 1.0;
|
||||||
|
stops[0].B = 1.0;
|
||||||
|
stops[0].A = 0.25;
|
||||||
|
stops[1].Pos = 1.0;
|
||||||
|
stops[1].R = 0.0;
|
||||||
|
stops[1].G = 0.0;
|
||||||
|
stops[1].B = 1.0;
|
||||||
|
stops[1].A = 1.0;
|
||||||
|
brush.Type = uiDrawBrushTypeLinearGradient;
|
||||||
|
brush.X0 = 100 + XO;
|
||||||
|
brush.Y0 = 0 + YO;
|
||||||
|
brush.X1 = 100 + XO;
|
||||||
|
brush.Y1 = 200 + YO;
|
||||||
|
brush.Stops = stops;
|
||||||
|
brush.NumStops = 2;
|
||||||
|
uiDrawFill(p->Context, path, &brush);
|
||||||
|
}
|
||||||
|
#undef YO
|
||||||
|
#undef XO
|
||||||
|
uiDrawFreePath(path);
|
||||||
|
|
||||||
|
// based on https://msdn.microsoft.com/en-us/library/windows/desktop/dd756679%28v=vs.85%29.aspx
|
||||||
|
path = uiDrawNewPath(uiDrawFillModeWinding);
|
||||||
|
uiDrawPathNewFigure(path, 585, 235);
|
||||||
|
uiDrawPathArcTo(path,
|
||||||
|
510, 235,
|
||||||
|
75,
|
||||||
|
0,
|
||||||
|
// TODO why doesn't 360° work
|
||||||
|
2 * M_PI - 0.1);
|
||||||
|
uiDrawPathEnd(path);
|
||||||
|
// first the stroke
|
||||||
|
brush.Type = uiDrawBrushTypeSolid;
|
||||||
|
brush.R = 0;
|
||||||
|
brush.G = 0;
|
||||||
|
brush.B = 0;
|
||||||
|
brush.A = 1;
|
||||||
|
sp.Cap = uiDrawLineCapFlat;
|
||||||
|
sp.Join = uiDrawLineJoinMiter;
|
||||||
|
sp.MiterLimit = uiDrawDefaultMiterLimit;
|
||||||
|
sp.Thickness = 1;
|
||||||
|
uiDrawStroke(p->Context, path, &brush, &sp);
|
||||||
|
// then the fill
|
||||||
|
{
|
||||||
|
uiDrawBrushGradientStop stops[2];
|
||||||
|
|
||||||
|
stops[0].Pos = 0.0;
|
||||||
|
stops[0].R = 1.0;
|
||||||
|
stops[0].G = 1.0;
|
||||||
|
stops[0].B = 0.0;
|
||||||
|
stops[0].A = 1.0;
|
||||||
|
stops[1].Pos = 1.0;
|
||||||
|
stops[1].R = ((double) 0x22) / 255.0;
|
||||||
|
stops[1].G = ((double) 0x8B) / 255.0;
|
||||||
|
stops[1].B = ((double) 0x22) / 255.0;
|
||||||
|
stops[1].A = 1.0;
|
||||||
|
brush.Type = uiDrawBrushTypeRadialGradient;
|
||||||
|
// start point
|
||||||
|
brush.X0 = 510;
|
||||||
|
brush.Y0 = 235;
|
||||||
|
// outer circle's center
|
||||||
|
brush.X1 = 510;
|
||||||
|
brush.Y1 = 235;
|
||||||
|
brush.OuterRadius = 75;
|
||||||
|
brush.Stops = stops;
|
||||||
|
brush.NumStops = 2;
|
||||||
|
uiDrawFill(p->Context, path, &brush);
|
||||||
|
}
|
||||||
|
uiDrawFreePath(path);
|
||||||
|
}
|
||||||
|
|
||||||
|
static uintmax_t handlerHScrollMax(uiAreaHandler *a, uiArea *area)
|
||||||
|
{
|
||||||
|
// TODO
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uintmax_t handlerVScrollMax(uiAreaHandler *a, uiArea *area)
|
||||||
|
{
|
||||||
|
// TODO
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int handlerRedrawOnResize(uiAreaHandler *a, uiArea *area)
|
||||||
|
{
|
||||||
|
// TODO
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void handlerMouseEvent(uiAreaHandler *a, uiArea *area, uiAreaMouseEvent *e)
|
||||||
|
{
|
||||||
|
printf("mouse (%d,%d):(%d,%d) down:%d up:%d count:%d mods:%x held:%x\n",
|
||||||
|
(int) e->X,
|
||||||
|
(int) e->Y,
|
||||||
|
(int) e->HScrollPos,
|
||||||
|
(int) e->VScrollPos,
|
||||||
|
(int) e->Down,
|
||||||
|
(int) e->Up,
|
||||||
|
(int) e->Count,
|
||||||
|
(uint32_t) e->Modifiers,
|
||||||
|
e->Held1To64);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void handlerDragBroken(uiAreaHandler *ah, uiArea *a)
|
||||||
|
{
|
||||||
|
printf("drag broken\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
static int handlerKeyEvent(uiAreaHandler *ah, uiArea *a, uiAreaKeyEvent *e)
|
||||||
|
{
|
||||||
|
char k[4];
|
||||||
|
|
||||||
|
k[0] = '\'';
|
||||||
|
k[1] = e->Key;
|
||||||
|
k[2] = '\'';
|
||||||
|
k[3] = '\0';
|
||||||
|
if (e->Key == 0) {
|
||||||
|
k[0] = '0';
|
||||||
|
k[1] = '\0';
|
||||||
|
}
|
||||||
|
printf("key key:%s extkey:%d mod:%d mods:%d up:%d\n",
|
||||||
|
k,
|
||||||
|
(int) e->ExtKey,
|
||||||
|
(int) e->Modifier,
|
||||||
|
(int) e->Modifiers,
|
||||||
|
e->Up);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
uiBox *makePage6(void)
|
||||||
|
{
|
||||||
|
uiBox *page6;
|
||||||
|
uiBox *hbox;
|
||||||
|
|
||||||
|
handler.ah.Draw = handlerDraw;
|
||||||
|
handler.ah.HScrollMax = handlerHScrollMax;
|
||||||
|
handler.ah.VScrollMax = handlerVScrollMax;
|
||||||
|
handler.ah.RedrawOnResize = handlerRedrawOnResize;
|
||||||
|
handler.ah.MouseEvent = handlerMouseEvent;
|
||||||
|
handler.ah.DragBroken = handlerDragBroken;
|
||||||
|
handler.ah.KeyEvent = handlerKeyEvent;
|
||||||
|
|
||||||
|
page6 = newVerticalBox();
|
||||||
|
|
||||||
|
hbox = newHorizontalBox();
|
||||||
|
uiBoxAppend(page6, uiControl(hbox), 0);
|
||||||
|
|
||||||
|
which = uiNewCombobox();
|
||||||
|
uiBoxAppend(hbox, uiControl(which), 0);
|
||||||
|
|
||||||
|
area = uiNewArea((uiAreaHandler *) (&handler));
|
||||||
|
uiBoxAppend(page6, uiControl(area), 1);
|
||||||
|
|
||||||
|
return page6;
|
||||||
|
}
|
|
@ -1,9 +1,13 @@
|
||||||
// 22 april 2015
|
// 22 april 2015
|
||||||
|
// TODO
|
||||||
|
#define _GNU_SOURCE
|
||||||
|
#define _USE_MATH_DEFINES
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <math.h>
|
||||||
#include "../ui.h"
|
#include "../ui.h"
|
||||||
|
|
||||||
// main.c
|
// main.c
|
||||||
|
@ -42,3 +46,6 @@ extern uiBox *makePage4(void);
|
||||||
|
|
||||||
// page5.c
|
// page5.c
|
||||||
extern uiBox *makePage5(void);
|
extern uiBox *makePage5(void);
|
||||||
|
|
||||||
|
// page6.c
|
||||||
|
extern uiBox *makePage6(void);
|
||||||
|
|
|
@ -28,4 +28,4 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <shobjidl.h>
|
#include <shobjidl.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <usp10.h>
|
#include <d2d1.h>
|
||||||
|
|
Loading…
Reference in New Issue