aboutsummaryrefslogtreecommitdiff
path: root/Src/Wasabi/api/skin/widgets/xuihideobject.cpp
diff options
context:
space:
mode:
authorJean-Francois Mauguit <jfmauguit@mac.com>2024-09-24 09:03:25 -0400
committerGitHub <noreply@github.com>2024-09-24 09:03:25 -0400
commitbab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/Wasabi/api/skin/widgets/xuihideobject.cpp
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/Wasabi/api/skin/widgets/xuihideobject.cpp')
-rw-r--r--Src/Wasabi/api/skin/widgets/xuihideobject.cpp50
1 files changed, 50 insertions, 0 deletions
diff --git a/Src/Wasabi/api/skin/widgets/xuihideobject.cpp b/Src/Wasabi/api/skin/widgets/xuihideobject.cpp
new file mode 100644
index 00000000..76ff6b6d
--- /dev/null
+++ b/Src/Wasabi/api/skin/widgets/xuihideobject.cpp
@@ -0,0 +1,50 @@
+#include <precomp.h>
+#include "xuihideobject.h"
+// -----------------------------------------------------------------------
+const wchar_t HideObjectXuiObjectStr[] = L"HideObject"; // This is the xml tag
+char HideObjectXuiSvcName[] = "HideObject xui object";
+
+XMLParamPair HideObject::params[] = {
+ { HIDEOBJECT_HIDE, L"HIDE"},
+};
+// -----------------------------------------------------------------------
+HideObject::HideObject() : HIDEOBJECT_PARENT()
+{
+ myxuihandle = newXuiHandle();
+ CreateXMLParameters(myxuihandle);
+}
+
+void HideObject::CreateXMLParameters(int master_handle)
+{
+ //HIDEOBJECT_PARENT::CreateXMLParameters(master_handle);
+ int numParams = sizeof(params) / sizeof(params[0]);
+ hintNumberOfParams(myxuihandle, numParams);
+ for (int i = 0;i < numParams;i++)
+ addParam(myxuihandle, params[i], XUI_ATTRIBUTE_IMPLIED);
+}
+
+
+// -----------------------------------------------------------------------
+int HideObject::setXuiParam(int xuihandle, int xmlattributeid, const wchar_t *xmlattributename, const wchar_t *value) {
+ if (xuihandle != myxuihandle)
+ return HIDEOBJECT_PARENT::setXuiParam(xuihandle, xmlattributeid, xmlattributename, value);
+
+ switch (xmlattributeid) {
+ case HIDEOBJECT_HIDE:
+ actuator_setTarget(value);
+ break;
+ default:
+ return 0;
+ }
+ return 1;
+}
+
+// -----------------------------------------------------------------------
+void HideObject::actuator_onPerform(GuiObject *target) { // guaranteed non NULL
+ ifc_window *w = target->guiobject_getRootWnd();
+ if (w != NULL) {
+ w->setVisible(0);
+ }
+}
+
+