mirror of https://github.com/adamdruppe/arsd.git
minigui styling 2.0 start
This commit is contained in:
parent
ad8ff20a84
commit
0b34c82758
2
dom.d
2
dom.d
|
@ -6828,7 +6828,7 @@ int intFromHex(string hex) {
|
||||||
///.
|
///.
|
||||||
static immutable string[] selectorTokens = [
|
static immutable string[] selectorTokens = [
|
||||||
// It is important that the 2 character possibilities go first here for accurate lexing
|
// It is important that the 2 character possibilities go first here for accurate lexing
|
||||||
"~=", "*=", "|=", "^=", "$=", "!=", // "::" should be there too for full standard
|
"~=", "*=", "|=", "^=", "$=", "!=",
|
||||||
"::", ">>",
|
"::", ">>",
|
||||||
"<<", // my any-parent extension (reciprocal of whitespace)
|
"<<", // my any-parent extension (reciprocal of whitespace)
|
||||||
// " - ", // previous-sibling extension (whitespace required to disambiguate tag-names)
|
// " - ", // previous-sibling extension (whitespace required to disambiguate tag-names)
|
||||||
|
|
9
jni.d
9
jni.d
|
@ -1137,6 +1137,15 @@ struct ActivateJniEnv {
|
||||||
"no jvm dll" in the message. That error can also be thrown if
|
"no jvm dll" in the message. That error can also be thrown if
|
||||||
you have a 32 bit program but try to load a 64 bit JVM, or vice
|
you have a 32 bit program but try to load a 64 bit JVM, or vice
|
||||||
versa.
|
versa.
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
an opaque object you should hold on to but not actually use.
|
||||||
|
Its destructor does necessary cleanup tasks to unload the jvm
|
||||||
|
but otherwise its effect is global.
|
||||||
|
|
||||||
|
As long as that object is in scope, you can work with java classes
|
||||||
|
globally and it will use that jvm's environment and load classes and jars
|
||||||
|
through the java classpath.
|
||||||
+/
|
+/
|
||||||
auto createJvm()() {
|
auto createJvm()() {
|
||||||
version(Windows)
|
version(Windows)
|
||||||
|
|
|
@ -96,7 +96,7 @@ void loadMiniguiPublicClasses() {
|
||||||
import std.traits;
|
import std.traits;
|
||||||
import std.conv;
|
import std.conv;
|
||||||
|
|
||||||
foreach(memberName; __traits(allMembers, mixin("arsd.minigui"))) static if(__traits(compiles, __traits(getMember, mixin("arsd.minigui"), memberName))) {
|
foreach(memberName; __traits(allMembers, mixin("arsd.minigui"))) static if(!__traits(isDeprecated, __traits(getMember, mixin("arsd.minigui"), memberName))) {
|
||||||
alias Member = ident!(__traits(getMember, mixin("arsd.minigui"), memberName));
|
alias Member = ident!(__traits(getMember, mixin("arsd.minigui"), memberName));
|
||||||
static if(is(Member == class) && !isAbstractClass!Member && is(Member : Widget) && __traits(getProtection, Member) != "private") {
|
static if(is(Member == class) && !isAbstractClass!Member && is(Member : Widget) && __traits(getProtection, Member) != "private") {
|
||||||
widgetFactoryFunctions[memberName] = (string[string] args, Widget parent) {
|
widgetFactoryFunctions[memberName] = (string[string] args, Widget parent) {
|
||||||
|
|
|
@ -2665,6 +2665,14 @@ public:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/++
|
||||||
|
Event listeners added with [addEventListener] have their exceptions swallowed by the event loop. This delegate can handle them again before it proceeds.
|
||||||
|
|
||||||
|
History:
|
||||||
|
Added May 12, 2021
|
||||||
|
+/
|
||||||
|
void delegate(Exception e) nothrow eventUncaughtException;
|
||||||
|
|
||||||
/** Add listener for custom event. Can be used like this:
|
/** Add listener for custom event. Can be used like this:
|
||||||
*
|
*
|
||||||
* ---------------------
|
* ---------------------
|
||||||
|
@ -2691,8 +2699,10 @@ public:
|
||||||
if (auto co = cast(ET)o) {
|
if (auto co = cast(ET)o) {
|
||||||
try {
|
try {
|
||||||
dg(co);
|
dg(co);
|
||||||
} catch (Exception) {
|
} catch (Exception e) {
|
||||||
// sorry!
|
// sorry!
|
||||||
|
if(eventUncaughtException)
|
||||||
|
eventUncaughtException(e);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -7298,6 +7308,8 @@ enum FontWeight : int {
|
||||||
heavy = 900
|
heavy = 900
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// FIXME: i need a font cache and it needs to handle disconnects.
|
||||||
|
|
||||||
/++
|
/++
|
||||||
Represents a font loaded off the operating system or the X server.
|
Represents a font loaded off the operating system or the X server.
|
||||||
|
|
||||||
|
@ -7980,7 +7992,7 @@ struct ScreenPainter {
|
||||||
impl.create(handle);
|
impl.create(handle);
|
||||||
impl.referenceCount = 1;
|
impl.referenceCount = 1;
|
||||||
window.activeScreenPainter = impl;
|
window.activeScreenPainter = impl;
|
||||||
// writeln("constructed");
|
//import std.stdio; writeln("constructed");
|
||||||
}
|
}
|
||||||
|
|
||||||
copyActiveOriginals();
|
copyActiveOriginals();
|
||||||
|
@ -8001,7 +8013,7 @@ struct ScreenPainter {
|
||||||
impl.referenceCount--;
|
impl.referenceCount--;
|
||||||
//writeln("refcount -- ", impl.referenceCount);
|
//writeln("refcount -- ", impl.referenceCount);
|
||||||
if(impl.referenceCount == 0) {
|
if(impl.referenceCount == 0) {
|
||||||
//writeln("destructed");
|
//import std.stdio; writeln("destructed");
|
||||||
impl.dispose();
|
impl.dispose();
|
||||||
*window.activeScreenPainter = ScreenPainterImplementation.init;
|
*window.activeScreenPainter = ScreenPainterImplementation.init;
|
||||||
//import std.stdio; writeln("paint finished");
|
//import std.stdio; writeln("paint finished");
|
||||||
|
@ -8062,21 +8074,33 @@ struct ScreenPainter {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/// Sets the clipping region for drawing. If width == 0 && height == 0, disabled clipping.
|
/++
|
||||||
void setClipRectangle(Point pt, int width, int height) {
|
Sets the clipping region for drawing. If width == 0 && height == 0, disabled clipping.
|
||||||
if(impl is null) return;
|
|
||||||
|
Returns:
|
||||||
|
The old clip rectangle.
|
||||||
|
|
||||||
|
History:
|
||||||
|
Return value was `void` prior to May 10, 2021.
|
||||||
|
|
||||||
|
+/
|
||||||
|
arsd.color.Rectangle setClipRectangle(Point pt, int width, int height) {
|
||||||
|
if(impl is null) return currentClipRectangle;
|
||||||
if(pt == currentClipRectangle.upperLeft && width == currentClipRectangle.width && height == currentClipRectangle.height)
|
if(pt == currentClipRectangle.upperLeft && width == currentClipRectangle.width && height == currentClipRectangle.height)
|
||||||
return; // no need to do anything
|
return currentClipRectangle; // no need to do anything
|
||||||
|
auto old = currentClipRectangle;
|
||||||
currentClipRectangle = arsd.color.Rectangle(pt, Size(width, height));
|
currentClipRectangle = arsd.color.Rectangle(pt, Size(width, height));
|
||||||
transform(pt);
|
transform(pt);
|
||||||
|
|
||||||
impl.setClipRectangle(pt.x, pt.y, width, height);
|
impl.setClipRectangle(pt.x, pt.y, width, height);
|
||||||
|
|
||||||
|
return old;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// ditto
|
/// ditto
|
||||||
void setClipRectangle(arsd.color.Rectangle rect) {
|
arsd.color.Rectangle setClipRectangle(arsd.color.Rectangle rect) {
|
||||||
if(impl is null) return;
|
if(impl is null) return currentClipRectangle;
|
||||||
setClipRectangle(rect.upperLeft, rect.width, rect.height);
|
return setClipRectangle(rect.upperLeft, rect.width, rect.height);
|
||||||
}
|
}
|
||||||
|
|
||||||
///
|
///
|
||||||
|
@ -8331,6 +8355,12 @@ struct ScreenPainter {
|
||||||
lowerRightInclusive.x - upperLeft.x + 1, lowerRightInclusive.y - upperLeft.y + 1);
|
lowerRightInclusive.x - upperLeft.x + 1, lowerRightInclusive.y - upperLeft.y + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// overload added on May 12, 2021
|
||||||
|
/// ditto
|
||||||
|
void drawRectangle(Rectangle rect) {
|
||||||
|
drawRectangle(rect.upperLeft, rect.size);
|
||||||
|
}
|
||||||
|
|
||||||
/// Arguments are the points of the bounding rectangle
|
/// Arguments are the points of the bounding rectangle
|
||||||
void drawEllipse(Point upperLeft, Point lowerRight) {
|
void drawEllipse(Point upperLeft, Point lowerRight) {
|
||||||
if(impl is null) return;
|
if(impl is null) return;
|
||||||
|
@ -10961,12 +10991,24 @@ version(X11) {
|
||||||
arsd.color.Rectangle _clipRectangle;
|
arsd.color.Rectangle _clipRectangle;
|
||||||
void setClipRectangle(int x, int y, int width, int height) {
|
void setClipRectangle(int x, int y, int width, int height) {
|
||||||
_clipRectangle = arsd.color.Rectangle(Point(x, y), Size(width, height));
|
_clipRectangle = arsd.color.Rectangle(Point(x, y), Size(width, height));
|
||||||
if(width == 0 || height == 0)
|
if(width == 0 || height == 0) {
|
||||||
XSetClipMask(display, gc, None);
|
XSetClipMask(display, gc, None);
|
||||||
else {
|
|
||||||
|
version(with_xft) {
|
||||||
|
if(xftFont is null || xftDraw is null)
|
||||||
|
return;
|
||||||
|
XftDrawSetClip(xftDraw, null);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
XRectangle[1] rects;
|
XRectangle[1] rects;
|
||||||
rects[0] = XRectangle(cast(short)(x), cast(short)(y), cast(short) width, cast(short) height);
|
rects[0] = XRectangle(cast(short)(x), cast(short)(y), cast(short) width, cast(short) height);
|
||||||
XSetClipRectangles(XDisplayConnection.get, gc, 0, 0, rects.ptr, 1, 0);
|
XSetClipRectangles(XDisplayConnection.get, gc, 0, 0, rects.ptr, 1, 0);
|
||||||
|
|
||||||
|
version(with_xft) {
|
||||||
|
if(xftFont is null || xftDraw is null)
|
||||||
|
return;
|
||||||
|
XftDrawSetClipRectangles(xftDraw, 0, 0, rects.ptr, 1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11711,13 +11753,15 @@ mixin DynamicLoad!(XRender, "Xrender", 1, false, true) XRenderLibrary;
|
||||||
struct BOX {
|
struct BOX {
|
||||||
short x1, x2, y1, y2;
|
short x1, x2, y1, y2;
|
||||||
}
|
}
|
||||||
struct Region {
|
struct _XRegion {
|
||||||
c_long size;
|
c_long size;
|
||||||
c_long numRects;
|
c_long numRects;
|
||||||
BOX* rects;
|
BOX* rects;
|
||||||
BOX extents;
|
BOX extents;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
alias Region = _XRegion*;
|
||||||
|
|
||||||
// ok actually Xft
|
// ok actually Xft
|
||||||
|
|
||||||
struct XftFontInfo;
|
struct XftFontInfo;
|
||||||
|
@ -17858,6 +17902,8 @@ static:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Color selectionXorColor = Color(255, 255, 127);
|
||||||
|
|
||||||
void highlightSelection(ScreenPainter painter) {
|
void highlightSelection(ScreenPainter painter) {
|
||||||
if(selectionStart is selectionEnd)
|
if(selectionStart is selectionEnd)
|
||||||
return; // no selection
|
return; // no selection
|
||||||
|
@ -17870,7 +17916,7 @@ static:
|
||||||
|
|
||||||
painter.rasterOp = RasterOp.xor;
|
painter.rasterOp = RasterOp.xor;
|
||||||
painter.outlineColor = Color.transparent;
|
painter.outlineColor = Color.transparent;
|
||||||
painter.fillColor = Color(255, 255, 127);
|
painter.fillColor = selectionXorColor;
|
||||||
|
|
||||||
auto at = selectionStart.inlineElement;
|
auto at = selectionStart.inlineElement;
|
||||||
auto atOffset = selectionStart.offset;
|
auto atOffset = selectionStart.offset;
|
||||||
|
|
Loading…
Reference in New Issue