menu works on windows

git-svn-id: http://svn2.nishi.boats/svn/milsko/trunk@139 b9cfdab3-6d41-4d17-bbe4-086880011989
This commit is contained in:
NishiOwO
2025-10-03 16:13:11 +00:00
parent 6db4808815
commit 06b2178ecc
5 changed files with 63 additions and 26 deletions

View File

@@ -109,7 +109,7 @@ static void draw(MwWidget handle) {
m->sub[i]->wsub = NULL;
m->sub[i]->keep = 0;
m->wait = 1;
}else if(arrlen(m->sub[i]->sub) == 0){
} else if(arrlen(m->sub[i]->sub) == 0) {
MwDispatchUserHandler(handle, MwNmenuHandler, m->sub[i]);
}
} else if(!handle->pressed && m->sub[i]->wsub != NULL) {

View File

@@ -45,16 +45,16 @@ static void draw(MwWidget handle) {
int i;
p.x = 0;
p.y = 5;
p.y = 3;
for(i = 0; i < arrlen(menu->sub); i++) {
int tw = MwTextWidth(handle, menu->sub[i]->name);
int th = MwTextHeight(handle, menu->sub[i]->name);
if(menu->sub[i]->wsub != NULL){
r.x = 0;
r.y = p.y - 3;
r.width = tw + 15 + 5 * 2;
if(menu->sub[i]->wsub != NULL) {
r.x = 0;
r.y = p.y - 3;
r.width = tw + 15 + 5 * 2;
r.height = th + 3 * 2;
MwDrawFrame(handle, &r, base, 0);
}
@@ -64,7 +64,7 @@ static void draw(MwWidget handle) {
p.y += th / 2;
MwDrawText(handle, &p, menu->sub[i]->name, 1, text);
if(arrlen(menu->sub[i]->sub) > 0){
if(arrlen(menu->sub[i]->sub) > 0) {
MwPoint pl[3];
p.x = 5 + tw + 10;
@@ -81,7 +81,7 @@ static void draw(MwWidget handle) {
MwLLPolygon(handle->lowlevel, pl, 3, text);
}
p.y += th / 2 + 5;
p.y += th / 2 + 3;
}
}
@@ -99,7 +99,7 @@ static void click(MwWidget handle) {
MwRect rc;
rc.x = 5;
rc.y = 5;
rc.y = 3;
for(i = 0; i < arrlen(menu->sub); i++) {
int tw = MwTextWidth(handle, menu->sub[i]->name);
if(tw > ww) ww = tw;
@@ -113,36 +113,45 @@ static void click(MwWidget handle) {
if(rc.x <= handle->mouse_point.x && rc.y <= handle->mouse_point.y && handle->mouse_point.x <= (int)(rc.x + rc.width) && handle->mouse_point.y <= (int)(rc.y + rc.height)) {
if(menu->sub[i]->wsub == NULL && arrlen(menu->sub[i]->sub) > 0) {
MwPoint p;
int j;
int j;
for(j = 0; j < arrlen(menu->sub); j++){
for(j = 0; j < arrlen(menu->sub); j++) {
if(menu->sub[j]->wsub != NULL) MwDestroyWidget(menu->sub[j]->wsub);
menu->sub[j]->wsub = NULL;
}
p.x = rc.x + rc.width + 5;
p.y = rc.y - 5;
p.x = rc.x + rc.width + 3;
p.y = rc.y - 3;
menu->sub[i]->wsub = MwCreateWidget(MwSubMenuClass, "submenu", handle, 0, 0, 0, 0);
MwSubMenuAppear(menu->sub[i]->wsub, menu->sub[i], &p);
i = -1;
}else if(arrlen(menu->sub[i]->sub) == 0){
} else if(menu->sub[i]->wsub != NULL && arrlen(menu->sub[i]->sub) > 0) {
MwDestroyWidget(menu->sub[i]->wsub);
menu->sub[i]->wsub = NULL;
MwLLForceRender(handle->lowlevel);
} else if(arrlen(menu->sub[i]->sub) == 0) {
MwWidget p;
while(w->parent->widget_class != MwMenuClass) w = w->parent;
MwGetBeforeStep(w, &jmp);
p = w->parent;
MwDestroyWidget(w);
MwLLForceRender(w->parent->lowlevel);
MwLLForceRender(p->lowlevel);
MwDispatchUserHandler(p, MwNmenuHandler, menu->sub[i]);
MwDispatchUserHandler(w->parent, MwNmenuHandler, menu->sub[i]);
longjmp(jmp, 1);
break;
}
}
rc.y += rc.height + 5;
rc.y += rc.height + 3;
}
}
}
@@ -159,6 +168,23 @@ MwClass MwSubMenuClass = &MwSubMenuClassRec;
void MwSubMenuAppear(MwWidget handle, MwMenu menu, MwPoint* point) {
int i, w = 0, h = 0;
#ifdef _WIN32
RECT rc;
SetWindowLongPtr(handle->lowlevel->hWnd, GWL_STYLE, (LONG_PTR)WS_POPUP);
GetWindowRect(handle->parent->lowlevel->hWnd, &rc);
SetParent(handle->lowlevel->hWnd, NULL);
rc.left += point->x;
rc.top += point->y;
SetWindowPos(handle->lowlevel->hWnd, NULL, rc.left, rc.top, 1, 1, SWP_NOREDRAW);
ShowWindow(handle->lowlevel->hWnd, SW_NORMAL);
UpdateWindow(handle->lowlevel->hWnd);
SetFocus(handle->lowlevel->hWnd);
#else
Atom wndtype = XInternAtom(handle->lowlevel->display, "_NET_WM_WINDOW_TYPE", False);
Atom wndmenu = XInternAtom(handle->lowlevel->display, "_NET_WM_WINDOW_TYPE_MENU", False);
@@ -183,14 +209,14 @@ void MwSubMenuAppear(MwWidget handle, MwMenu menu, MwPoint* point) {
for(i = 0; i < arrlen(menu->sub); i++) {
int tw = MwTextWidth(handle, menu->sub[i]->name);
h += MwTextHeight(handle, menu->sub[i]->name) + 5;
h += MwTextHeight(handle, menu->sub[i]->name) + 3;
if(tw > w) {
w = tw;
}
}
w += 10 + 15;
h += 5;
h += 3;
MwVaApply(handle,
MwNwidth, w,