Hi all,
I’ve create a simple Hotkey control based on LineEdit, e.g to customize shortcuts in a game. You can find it here:
Maybe someone can need it.
Best Stefan
Hi all,
I’ve create a simple Hotkey control based on LineEdit, e.g to customize shortcuts in a game. You can find it here:
Maybe someone can need it.
Best Stefan
What is type Key in the code?
It is defined in InputConstants.h, see
this is from the master branch… im using urho3d version 1.7, no wonder i cant figure out what it is.
Oh, I see there is no InputConsts.h in 1.7. I think you can just change it to an (unsigned) int and use the SDLK_* constants instead.
I got a serious problem…
cant i add custom ui components to precompiled urho3d library? i tried to add several custom ui components shared on forum to my project and all of them worked just fine except style part.
just like this one
auto *edit = window->CreateChild<HotkeyEdit>();
edit->SetStyle("LineEdit");
edit->SetMinSize(200, 32);
auto *edit2 = window->CreateChild<LineEdit>();
edit2->SetStyleAuto();
edit2->SetMinSize(200, 32);
edit2->SetPosition(0, 32);
Hm yes, I also have problems with the styling part from time to tome. For the moment I set the style manually in code, e.g.:
HotkeyEdit* hkEdit = hkContainer->CreateChild<HotkeyEdit>("HotkeyEditor");
Texture2D* tex = cache->GetResource<Texture2D>("Textures/UI.png");
hkEdit->SetTexture(tex);
hkEdit->SetImageRect(IntRect(48, 0, 64, 16));
hkEdit->SetBorder(IntRect(4, 4, 4, 4));
When I don’t set the Texture by code, I get the same white control as you, even when I use SetStyle(“LineEdit”).
Maybe someone can enlighten me what I’m doing wrong.
is this Lumak’s TabGroup?
Yes, it’s great
i need to do your style trick again if i wanna use this TabGroup!
i adjusted code for his TabGroup, but the style part is still not working, wth!
How and when the styling works is not entirely clear to me. In this case i just trial and error around
The styling of all UI-element derived classes are nothing else but a mechanism to apply a set of predefined attributes to the UIElement object. You first define the set of attributes in a “style sheet” or whatever you want to call it, in an XML file. You then reference them by using
UIElement::SetStyle("predefined-style-name")
. The
UIElement::SetStyleAuto()
variant uses the type of the UI-element itself as the name of the style to be applied, i.e.
Button::SetStyleAuto()
is equivalent to
Button::SetStyle("Button")
. But how does the UI subsystem know which “style sheet” you want to use in the first place? In actual fact it does not. So you must do the below quite early on, if you plan to create the UI layout by code.
auto* cache = GetSubsystem<ResourceCache>();
auto* stylesheet = cache->GetResource<XMLFile>("path/to/your/stylesheet.xml");
auto* uiRoot = GetSubsystem<UI>()->GetRoot());
uiRoot->SetDefaultStyle(stylesheet);
When you create a new UIElement object as a child of some other object that is already in the UI hierarchy, the child object will ask the parent object for a style sheet, if the child does not explicitly have one. So, ultimately the query will reach to the root UI element. That’s why the above code is important.
Of course alternatively, you can also set the style sheet you want to use in the individual object before calling the
SetStyle()
. You may want to do this if you want to have different style sheet to be applied than the normal default one, for instance. Or, if you want to create a new object and style it before parenting it.
HTH.
actually i did set default to ui root and i create ui elements directly into ui root. but like in this HotkeyEdit, the Text element inside does apply styles, and the BorderImage just wont.
I did not look at your code so I don’t know what went wrong. But If you understand what I explained above then you should find the Urho3D UI styling mechanism is quite versatile and flexible. The Urho3D project provided style sheet is actually designed to be used by its Editor. I cannot imagine why anyone would want to use it as it is in one own game. So perhaps Lumak has a modified version of that file but you are not.
Lumak’s repo
https://github.com/Lumak/Urho3D-UI-Components
i copied his
DefaultStyle.xml
and
UI.png
and still does not work
;;
back to HotkeyEdit:
I tried setting default
SetDefaultStyle()
then
SetStyle()
,
and
SetStyle()
with second argument specified, both didnt work.
results are same: only the Text element inside applied style
SetStyle("LineEdit", GetSubsystem<ResourceCache>()->GetResource<XMLFile>("UI/DefaultStyle.xml"));
SetTexture(GetSubsystem<ResourceCache>()->GetResource<Texture2D>("Textures/UI.png"));
SetImageRect(IntRect(48, 0, 64, 16));
SetBorder(IntRect(4, 4, 4, 4));
code snippet above works, it seems like the problem is within BorderImage?
Thank you for your explanation, this is indeed very useful.
what, did you figure out how to properly set style?
Not yet, but it made some things clearer. I need to cleanup my client code anyway one time (at them moment it’s a bit messy), then I’ll look into it.
Why does your key enumeration (the
#defines
) not take advantage of binary enum?
For example,
#define SC_MOD_LSHIFT 1 // Left Shift
#define SC_MOD_RSHIFT 1 << 1 // Right Shift
#define SC_MOD_SHIFT SC_MOD_RSHIFT | SC_MOD_LSHIFT // Left or right Shift
Yes, good question. But then the method GetQualName ( https://gist.github.com/stievie/878a4f04d2499dc4f1d12dbb7552b2af#file-hotkeyedit-h-L39 ) wouldn’t work anymore. I know it could be changed to work with it, but this control was a quick solution for a problem I had. I agree there is a lot room for improvements .
Actually, your GetQualName will still work!
It performs a bunch of AND tests on active bits, and collates a result, it will still work perfectly with a binary enum.
You did not test the combined bitflag enumerations in this method, but had you, it would STILL work (with some positive results appearing more than once)
Keep up the good work!