More WPF uiWindow work.
This commit is contained in:
parent
6e88ab611a
commit
4ec3632920
|
@ -11,10 +11,12 @@ struct uiWindow {
|
||||||
uiWindowsControl c;
|
uiWindowsControl c;
|
||||||
gcroot<libuiWindow ^> *window;
|
gcroot<libuiWindow ^> *window;
|
||||||
|
|
||||||
|
gcroot<Border ^> *border;
|
||||||
int margined;
|
int margined;
|
||||||
|
|
||||||
int (*onClosing)(uiWindow *, void *);
|
int (*onClosing)(uiWindow *, void *);
|
||||||
void *onClosingData;
|
void *onClosingData;
|
||||||
|
gcroot<CancelEventHandler ^> *onClosingDelegate;
|
||||||
};
|
};
|
||||||
|
|
||||||
static void onDestroy(uiWindow *);
|
static void onDestroy(uiWindow *);
|
||||||
|
@ -30,7 +32,6 @@ void libuiWindow::onClosing(Object ^sender, CancelEventArgs ^e)
|
||||||
{
|
{
|
||||||
// TODO copy comments
|
// TODO copy comments
|
||||||
if ((*(this->w->onClosing))(this->w, this->w->onClosingData))
|
if ((*(this->w->onClosing))(this->w, this->w->onClosingData))
|
||||||
// TODO this triggers another onClosing() when it's too late
|
|
||||||
uiControlDestroy(uiControl(this->w));
|
uiControlDestroy(uiControl(this->w));
|
||||||
e->Cancel = true;
|
e->Cancel = true;
|
||||||
}
|
}
|
||||||
|
@ -42,7 +43,14 @@ static int defaultOnClosing(uiWindow *w, void *data)
|
||||||
|
|
||||||
static void onDestroy(uiWindow *w)
|
static void onDestroy(uiWindow *w)
|
||||||
{
|
{
|
||||||
|
// first hide the window
|
||||||
|
(*(w->window))->Hide();
|
||||||
|
// take off the closing event; otherwise it will be recursed
|
||||||
|
(*(w->window))->Closing -= *(w->onClosingDelegate);
|
||||||
|
delete w->onClosingDelegate;
|
||||||
// TODO
|
// TODO
|
||||||
|
// clean up remaining .net objects
|
||||||
|
delete w->border;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void windowCommitShow(uiControl *c)
|
static void windowCommitShow(uiControl *c)
|
||||||
|
@ -104,10 +112,15 @@ int uiWindowMargined(uiWindow *w)
|
||||||
return w->margined;
|
return w->margined;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO according to http://stackoverflow.com/questions/18299107/how-to-handle-control-spacing-in-wpf-window-designer - same for rest of library
|
||||||
void uiWindowSetMargined(uiWindow *w, int margined)
|
void uiWindowSetMargined(uiWindow *w, int margined)
|
||||||
{
|
{
|
||||||
w->margined = margined;
|
w->margined = margined;
|
||||||
//TODO uiWindowsControlQueueRelayout(uiWindowsControl(w));
|
// TODO Margin or Padding?
|
||||||
|
if (w->margined)
|
||||||
|
(*(w->border))->Margin = Thickness(10, 10, 10, 10);
|
||||||
|
else
|
||||||
|
(*(w->border))->Margin = Thickness(0, 0, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
uiWindow *uiNewWindow(const char *title, int width, int height, int hasMenubar)
|
uiWindow *uiNewWindow(const char *title, int width, int height, int hasMenubar)
|
||||||
|
@ -125,10 +138,17 @@ uiWindow *uiNewWindow(const char *title, int width, int height, int hasMenubar)
|
||||||
(*(w->window))->Width = width;
|
(*(w->window))->Width = width;
|
||||||
(*(w->window))->Height = height;
|
(*(w->window))->Height = height;
|
||||||
|
|
||||||
// TODO background color
|
// reference source indicates that this does indeed map to COLOR_BTNFACE
|
||||||
|
(*(w->window))->Background = SystemColors::ControlBrush;
|
||||||
|
|
||||||
(*(w->window))->Closing += gcnew CancelEventHandler(*(w->window),
|
w->border = new gcroot<Border ^>();
|
||||||
|
*(w->border) = gcnew Border();
|
||||||
|
(*(w->window))->Content = *(w->border);
|
||||||
|
|
||||||
|
w->onClosingDelegate = new gcroot<CancelEventHandler ^>();
|
||||||
|
*(w->onClosingDelegate) = gcnew CancelEventHandler(*(w->window),
|
||||||
&libuiWindow::onClosing);
|
&libuiWindow::onClosing);
|
||||||
|
(*(w->window))->Closing += *(w->onClosingDelegate);
|
||||||
uiWindowOnClosing(w, defaultOnClosing, NULL);
|
uiWindowOnClosing(w, defaultOnClosing, NULL);
|
||||||
|
|
||||||
uiWindowsFinishNewControl(w, uiWindow, window);
|
uiWindowsFinishNewControl(w, uiWindow, window);
|
||||||
|
|
Loading…
Reference in New Issue