UIMLView.cpp 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881
  1. #include "UIMLView.h"
  2. #include "XML.h"
  3. #include "TextFeld.h"
  4. #include "Knopf.h"
  5. #include "Tabelle.h"
  6. #include "Fenster.h"
  7. #include "Schrift.h"
  8. #include "Bildschirm.h"
  9. #include "Rahmen.h"
  10. #include "Scroll.h"
  11. #include "Bild.h"
  12. using namespace Framework;
  13. UIMLElement::UIMLElement()
  14. : ReferenceCounter()
  15. {}
  16. UIMLElement::~UIMLElement()
  17. {}
  18. //! wendet die layout parameter zu einer Zeichnung an
  19. void UIMLElement::layout(XML::Element& element, Zeichnung& z, int pWidth, int pHeight, UIMLContainer& generalLayouter)
  20. {
  21. int width = z.getBreite();
  22. int height = z.getHeight();
  23. if (element.hasAttribute("width"))
  24. {
  25. Text w = element.getAttributeValue("width");
  26. if (!w.istGleich("auto"))
  27. {
  28. width = (int)w;
  29. if (w.getText()[w.getLength() - 1] == '%')
  30. width = (int)((pWidth / 100.0) * width);
  31. }
  32. }
  33. if (element.hasAttribute("height"))
  34. {
  35. Text h = element.getAttributeValue("height");
  36. if (!h.istGleich("auto"))
  37. {
  38. height = (int)h;
  39. if (h.getText()[h.getLength() - 1] == '%')
  40. height = (int)((pHeight / 100.0) * height);
  41. }
  42. }
  43. z.setSize(width, height);
  44. if (element.hasAttribute("align-left"))
  45. {
  46. Text la = element.getAttributeValue("align-left");
  47. int x = 0;
  48. if (la.istGleich("start"))
  49. x = 0;
  50. else if (la.istGleich("end"))
  51. x = pWidth;
  52. else if (la.istGleich("center"))
  53. x = pWidth / 2 - width / 2;
  54. else
  55. {
  56. XML::Editor ed = element.zParent()->selectChildsByAttribute("id", la);
  57. generalLayouter.layout(*ed.begin().val(), *generalLayouter.zZeichnungById(la), pWidth, pHeight, generalLayouter);
  58. Zeichnung* laz = generalLayouter.zZeichnungById(la);
  59. if (laz)
  60. x = laz->getX() + laz->getBreite();
  61. }
  62. if (element.hasAttribute("margin-left"))
  63. {
  64. Text mt = element.getAttributeValue("margin-left");
  65. int m = (int)mt;
  66. if (mt.getText()[mt.getLength() - 1] == '%')
  67. m = (int)((pWidth / 100.0) * m);
  68. x += m;
  69. }
  70. z.setX(x);
  71. }
  72. else if (element.hasAttribute("align-right"))
  73. {
  74. Text ra = element.getAttributeValue("align-right");
  75. int x = 0;
  76. if (ra.istGleich("start"))
  77. x = -z.getBreite();
  78. else if (ra.istGleich("end"))
  79. x = pWidth - z.getBreite();
  80. else if (ra.istGleich("center"))
  81. x = pWidth / 2 - width / 2;
  82. else
  83. {
  84. XML::Editor ed = element.zParent()->selectChildsByAttribute("id", ra);
  85. generalLayouter.layout(*ed.begin().val(), *generalLayouter.zZeichnungById(ra), pWidth, pHeight, generalLayouter);
  86. Zeichnung* raz = generalLayouter.zZeichnungById(ra);
  87. if (raz)
  88. x = raz->getX() - z.getBreite();
  89. }
  90. if (element.hasAttribute("margin-right"))
  91. {
  92. Text mt = element.getAttributeValue("margin-right");
  93. int m = (int)mt;
  94. if (mt.getText()[mt.getLength() - 1] == '%')
  95. m = (int)((pWidth / 100.0) * m);
  96. x -= m;
  97. }
  98. z.setX(x);
  99. }
  100. if (element.hasAttribute("align-top"))
  101. {
  102. Text ta = element.getAttributeValue("align-top");
  103. int y = 0;
  104. if (ta.istGleich("start"))
  105. y = 0;
  106. else if (ta.istGleich("end"))
  107. y = pHeight;
  108. else if (ta.istGleich("center"))
  109. y = pHeight / 2 - height / 2;
  110. else
  111. {
  112. XML::Editor ed = element.zParent()->selectChildsByAttribute("id", ta);
  113. generalLayouter.layout(*ed.begin().val(), *generalLayouter.zZeichnungById(ta), pWidth, pHeight, generalLayouter);
  114. Zeichnung* taz = generalLayouter.zZeichnungById(ta);
  115. if (taz)
  116. y = taz->getY() + taz->getHeight();
  117. }
  118. if (element.hasAttribute("margin-top"))
  119. {
  120. Text mt = element.getAttributeValue("margin-top");
  121. int m = (int)mt;
  122. if (mt.getText()[mt.getLength() - 1] == '%')
  123. m = (int)((pHeight / 100.0) * m);
  124. y += m;
  125. }
  126. z.setY(y);
  127. }
  128. else if (element.hasAttribute("align-bottom"))
  129. {
  130. Text ba = element.getAttributeValue("align-bottom");
  131. int y = 0;
  132. if (ba.istGleich("start"))
  133. y = -z.getHeight();
  134. else if (ba.istGleich("end"))
  135. y = pHeight - z.getHeight();
  136. else if (ba.istGleich("center"))
  137. y = pHeight / 2 - height / 2;
  138. else
  139. {
  140. XML::Editor ed = element.zParent()->selectChildsByAttribute("id", ba);
  141. generalLayouter.layout(*ed.begin().val(), *generalLayouter.zZeichnungById(ba), pWidth, pHeight, generalLayouter);
  142. Zeichnung* baz = generalLayouter.zZeichnungById(ba);
  143. if (baz)
  144. y = baz->getY() - z.getHeight();
  145. }
  146. if (element.hasAttribute("margin-bottom"))
  147. {
  148. Text mt = element.getAttributeValue("margin-bottom");
  149. int m = (int)mt;
  150. if (mt.getText()[mt.getLength() - 1] == '%')
  151. m = (int)((pHeight / 100.0) * m);
  152. y -= m;
  153. }
  154. z.setY(y);
  155. }
  156. int x = z.getX();
  157. int y = z.getY();
  158. if (element.hasAttribute("x"))
  159. {
  160. Text xt = element.getAttributeValue("x");
  161. x = (int)xt;
  162. if (xt.getText()[xt.getLength() - 1] == '%')
  163. x = (int)((pWidth / 100.0) * x);
  164. }
  165. if (element.hasAttribute("y"))
  166. {
  167. Text yt = element.getAttributeValue("y");
  168. y = (int)yt;
  169. if (yt.getText()[yt.getLength() - 1] == '%')
  170. y = (int)((pHeight / 100.0) * y);
  171. }
  172. z.setPosition(x, y);
  173. pWidth = z.getInnenBreite();
  174. pHeight = z.getInnenHeight();
  175. // recursive layout
  176. for (auto i = element.getChilds(); i; i++)
  177. generalLayouter.layout(*i.val(), *generalLayouter.zZeichnungById(i->getAttributeValue("id")), pWidth, pHeight, generalLayouter);
  178. }
  179. UIMLContainer::UIMLContainer()
  180. : UIMLElement()
  181. {}
  182. UIMLContainer::~UIMLContainer()
  183. {}
  184. UIMLTextField::UIMLTextField()
  185. : UIMLElement()
  186. {}
  187. bool UIMLTextField::isApplicableFor(XML::Element& element)
  188. {
  189. return element.getName().istGleich("textfield");
  190. }
  191. Zeichnung* UIMLTextField::parseElement(XML::Element& element, UIMLContainer& generalFactory)
  192. {
  193. TextFeld* t = generalFactory.getFactory().createTextFeld(generalFactory.getFactory().initParam);
  194. t->addStyle(TextFeld::Style::TextFeld);
  195. return t;
  196. }
  197. void UIMLTextField::layout(XML::Element& element, Zeichnung& z, int pWidth, int pHeight, UIMLContainer& generalLayouter)
  198. {
  199. z.setStyle(TextFeld::Style::HCenter, element.hasAttribute("text-align-horizontal") && element.getAttributeValue("text-align-horizontal").istGleich("center"));
  200. z.setStyle(TextFeld::Style::VCenter, element.hasAttribute("text-align-vertical") && element.getAttributeValue("text-align-vertical").istGleich("center"));
  201. if (element.hasAttribute("font-size"))
  202. ((TextFeld*)&z)->setSchriftSize((unsigned char)(int)element.getAttributeValue("font-size"));
  203. z.setStyle(TextFeld::Style::Editierbar, !element.hasAttribute("disabled") || (element.getAttributeValue("disabled").getLength() != 0 && !element.getAttributeValue("disabled").istGleich("true")));
  204. ((TextFeld*)&z)->setText(element.getText());
  205. if (element.hasAttribute("width"))
  206. {
  207. Text w = element.getAttributeValue("width");
  208. if (w.istGleich("auto"))
  209. {
  210. z.setWidth(((TextFeld*)&z)->getNeededWidth());
  211. }
  212. }
  213. if (element.hasAttribute("height"))
  214. {
  215. Text h = element.getAttributeValue("height");
  216. if (h.istGleich("auto"))
  217. {
  218. z.setHeight(((TextFeld*)&z)->getNeededHeight());
  219. }
  220. }
  221. UIMLElement::layout(element, z, pWidth, pHeight, generalLayouter);
  222. }
  223. UIMLButton::UIMLButton()
  224. : UIMLElement()
  225. {}
  226. bool UIMLButton::isApplicableFor(XML::Element& element)
  227. {
  228. return element.getName().istGleich("button");
  229. }
  230. Zeichnung* UIMLButton::parseElement(XML::Element& element, UIMLContainer& generalFactory)
  231. {
  232. Knopf* k = generalFactory.getFactory().createKnopf(generalFactory.getFactory().initParam);
  233. return k;
  234. }
  235. void UIMLButton::layout(XML::Element& element, Zeichnung& z, int pWidth, int pHeight, UIMLContainer& generalLayouter)
  236. {
  237. if (element.hasAttribute("font-size"))
  238. ((Knopf*)&z)->setSchriftSize((unsigned char)(int)element.getAttributeValue("font-size"));
  239. ((Knopf*)&z)->setText(element.getText());
  240. UIMLElement::layout(element, z, pWidth, pHeight, generalLayouter);
  241. }
  242. UIMLCheck::UIMLCheck()
  243. : UIMLElement()
  244. {}
  245. bool UIMLCheck::isApplicableFor(XML::Element& element)
  246. {
  247. return element.getName().istGleich("check");
  248. }
  249. Zeichnung* UIMLCheck::parseElement(XML::Element& element, UIMLContainer& generalFactory)
  250. {
  251. KontrollKnopf* k = generalFactory.getFactory().createKontrollKnopf(generalFactory.getFactory().initParam);
  252. return k;
  253. }
  254. void UIMLCheck::layout(XML::Element& element, Zeichnung& z, int pWidth, int pHeight, UIMLContainer& generalLayouter)
  255. {
  256. ((KontrollKnopf*)&z)->setText(element.getText());
  257. ((KontrollKnopf*)&z)->setSText(element.getText());
  258. z.setStyle(KontrollKnopf::Style::Selected, element.hasAttribute("selected"));
  259. if (element.hasAttribute("font-size"))
  260. ((KontrollKnopf*)&z)->setSSize((unsigned char)(int)element.getAttributeValue("font-size"));
  261. UIMLElement::layout(element, z, pWidth, pHeight, generalLayouter);
  262. }
  263. UIMLText::UIMLText()
  264. : UIMLElement()
  265. {}
  266. bool UIMLText::isApplicableFor(XML::Element& element)
  267. {
  268. return element.getName().istGleich("text");
  269. }
  270. Zeichnung* UIMLText::parseElement(XML::Element& element, UIMLContainer& generalFactory)
  271. {
  272. TextFeld* t = generalFactory.getFactory().createTextFeld(generalFactory.getFactory().initParam);
  273. t->addStyle(TextFeld::Style::Text);
  274. return t;
  275. }
  276. void UIMLText::layout(XML::Element& element, Zeichnung& z, int pWidth, int pHeight, UIMLContainer& generalLayouter)
  277. {
  278. z.setStyle(TextFeld::Style::HCenter, element.hasAttribute("text-align-horizontal") && element.getAttributeValue("text-align-horizontal").istGleich("center"));
  279. z.setStyle(TextFeld::Style::VCenter, element.hasAttribute("text-align-vertical") && element.getAttributeValue("text-align-vertical").istGleich("center"));
  280. if (element.hasAttribute("font-size"))
  281. ((TextFeld*)&z)->setSchriftSize((unsigned char)(int)element.getAttributeValue("font-size"));
  282. z.setStyle(TextFeld::Style::Editierbar, !element.hasAttribute("disabled") || (element.getAttributeValue("disabled").getLength() != 0 && !element.getAttributeValue("disabled").istGleich("true")));
  283. ((TextFeld*)&z)->setText(element.getText());
  284. if (element.hasAttribute("width"))
  285. {
  286. Text w = element.getAttributeValue("width");
  287. if (w.istGleich("auto"))
  288. {
  289. z.setWidth(((TextFeld*)&z)->getNeededWidth());
  290. }
  291. }
  292. if (element.hasAttribute("height"))
  293. {
  294. Text h = element.getAttributeValue("height");
  295. if (h.istGleich("auto"))
  296. {
  297. z.setHeight(((TextFeld*)&z)->getNeededHeight());
  298. }
  299. }
  300. UIMLElement::layout(element, z, pWidth, pHeight, generalLayouter);
  301. }
  302. UIMLTextArea::UIMLTextArea()
  303. : UIMLElement()
  304. {}
  305. bool UIMLTextArea::isApplicableFor(XML::Element& element)
  306. {
  307. return element.getName().istGleich("textarea");
  308. }
  309. Zeichnung* UIMLTextArea::parseElement(XML::Element& element, UIMLContainer& generalFactory)
  310. {
  311. TextFeld* t = generalFactory.getFactory().createTextFeld(generalFactory.getFactory().initParam);
  312. t->addStyle(TextFeld::Style::TextGebiet);
  313. return t;
  314. }
  315. void UIMLTextArea::layout(XML::Element& element, Zeichnung& z, int pWidth, int pHeight, UIMLContainer& generalLayouter)
  316. {
  317. z.setStyle(TextFeld::Style::HCenter, element.hasAttribute("text-align-horizontal") && element.getAttributeValue("text-align-horizontal").istGleich("center"));
  318. z.setStyle(TextFeld::Style::VCenter, element.hasAttribute("text-align-vertical") && element.getAttributeValue("text-align-vertical").istGleich("center"));
  319. if (element.hasAttribute("font-size"))
  320. ((TextFeld*)&z)->setSchriftSize((unsigned char)(int)element.getAttributeValue("font-size"));
  321. z.setStyle(TextFeld::Style::Editierbar, !element.hasAttribute("disabled") || (element.getAttributeValue("disabled").getLength() != 0 && !element.getAttributeValue("disabled").istGleich("true")));
  322. ((TextFeld*)&z)->setText(element.getText());
  323. ((TextFeld*)&z)->zTextRenderer()->textFormatieren(((TextFeld*)&z)->zText(), z.getInnenBreite());
  324. if (element.hasAttribute("width"))
  325. {
  326. Text w = element.getAttributeValue("width");
  327. if (w.istGleich("auto"))
  328. {
  329. z.setWidth(((TextFeld*)&z)->getNeededWidth());
  330. }
  331. }
  332. if (element.hasAttribute("height"))
  333. {
  334. Text h = element.getAttributeValue("height");
  335. if (h.istGleich("auto"))
  336. {
  337. z.setHeight(((TextFeld*)&z)->getNeededHeight());
  338. }
  339. }
  340. UIMLElement::layout(element, z, pWidth, pHeight, generalLayouter);
  341. }
  342. UIMLTable::UIMLTable()
  343. : UIMLElement()
  344. {}
  345. bool UIMLTable::isApplicableFor(XML::Element& element)
  346. {
  347. return element.getName().istGleich("table");
  348. }
  349. Zeichnung* UIMLTable::parseElement(XML::Element& element, UIMLContainer& generalFactory)
  350. {
  351. ObjTabelle* t = generalFactory.getFactory().createObjTabelle(generalFactory.getFactory().initParam);
  352. int index = 0;
  353. for (auto i = element.getChilds(); i; i++)
  354. {
  355. Text id;
  356. if (i->hasAttribute("id"))
  357. id = i->getAttributeValue("id");
  358. else
  359. {
  360. id = Text("_") += index++;
  361. i->setAttribute("id", id);
  362. }
  363. if (i->getName().istGleich("tr"))
  364. {
  365. t->addZeile(id);
  366. Text line = id;
  367. int c = 1;
  368. for (auto j = i->getChilds(); j; j++)
  369. {
  370. Zeichnung* z = generalFactory.parseElement(*i.val(), generalFactory);
  371. if (t->getSpaltenAnzahl() < c)
  372. t->addSpalte(Text(c - 1));
  373. if (z)
  374. t->setZeichnungZ(Text(c - 1), line, dynamic_cast<Zeichnung*>(z->getThis()));
  375. c++;
  376. }
  377. }
  378. }
  379. return t;
  380. }
  381. void UIMLTable::layout(XML::Element& element, Zeichnung& z, int pWidth, int pHeight, UIMLContainer& generalLayouter)
  382. {
  383. z.setStyle(ObjTabelle::Style::HScroll, element.hasAttribute("scroll") && element.getAttributeValue("scroll").istGleich("horizontal"));
  384. z.setStyle(ObjTabelle::Style::VScroll, element.hasAttribute("scroll") && element.getAttributeValue("scroll").istGleich("vertical"));
  385. z.setStyle(ObjTabelle::Style::scroll, element.hasAttribute("scroll") && element.getAttributeValue("scroll").istGleich("both"));
  386. UIMLElement::layout(element, z, pWidth, pHeight, generalLayouter);
  387. ObjTabelle* objT = (ObjTabelle*)&z;
  388. if (objT->getZeilenAnzahl() > 0)
  389. {
  390. if (element.hasAttribute("line-height"))
  391. {
  392. int height = (int)element.getAttributeValue("line-height");
  393. for (int i = 0; i < objT->getZeilenAnzahl(); i++)
  394. objT->setZeilenHeight(i, height);
  395. }
  396. for (int i = 0; i < objT->getSpaltenAnzahl(); i++)
  397. {
  398. if (objT->zZeichnung(i, 0))
  399. objT->setSpaltenBreite(i, objT->zZeichnung(i, 0)->getBreite());
  400. }
  401. }
  402. }
  403. UIMLFrame::UIMLFrame()
  404. : UIMLElement()
  405. {}
  406. bool UIMLFrame::isApplicableFor(XML::Element& element)
  407. {
  408. return element.getName().istGleich("frame");
  409. }
  410. Zeichnung* UIMLFrame::parseElement(XML::Element& element, UIMLContainer& generalFactory)
  411. {
  412. Fenster* f = generalFactory.getFactory().createFenster(generalFactory.getFactory().initParam);
  413. for (auto i = element.getChilds(); i; i++)
  414. {
  415. Zeichnung* z = generalFactory.parseElement(*i.val(), generalFactory);
  416. if (z)
  417. f->addMember(dynamic_cast<Zeichnung*>(z->getThis()));
  418. }
  419. return f;
  420. }
  421. void UIMLFrame::layout(XML::Element& element, Zeichnung& z, int pWidth, int pHeight, UIMLContainer& generalLayouter)
  422. {
  423. if (element.hasAttribute("title"))
  424. ((Fenster*)&z)->setTitel(element.getAttributeValue("title"));
  425. if (element.hasAttribute("title-height"))
  426. ((Fenster*)&z)->zTTextFeld()->setSize(((Fenster*)&z)->zTTextFeld()->getBreite(), (int)element.getAttributeValue("title-height"));
  427. UIMLElement::layout(element, z, pWidth, pHeight, generalLayouter);
  428. }
  429. // Erstellt eine UIML View
  430. UIMLView::UIMLView()
  431. : ZeichnungHintergrund()
  432. {
  433. style = Style::MEIgnoreInside | Style::MEIgnoreParentInside | Style::MEIgnoreSichtbar | Style::MEIgnoreVerarbeitet;
  434. members = new Trie< Zeichnung >();
  435. dom = 0;
  436. nextId = 0;
  437. memset(&init, 0, sizeof(UIInit));
  438. addKnownElement(new UIMLTextField());
  439. addKnownElement(new UIMLButton());
  440. addKnownElement(new UIMLCheck());
  441. addKnownElement(new UIMLText());
  442. addKnownElement(new UIMLTextArea());
  443. addKnownElement(new UIMLTable());
  444. addKnownElement(new UIMLFrame());
  445. }
  446. // Erstellt eine UIML View zu einem UIML Text
  447. // uiml: Ein xml element gemät des ksg uiml standarts
  448. UIMLView::UIMLView(XML::Element* uiml, UIInit& init)
  449. : UIMLView()
  450. {
  451. this->init = init;
  452. setUIML(uiml);
  453. }
  454. // Erstellt eine UIML View zu einem UIML Text
  455. // uiml: Ein xml text gemät des ksg uiml standarts
  456. UIMLView::UIMLView(Text uiml, UIInit& init)
  457. : UIMLView()
  458. {
  459. this->init = init;
  460. setUIML(uiml);
  461. }
  462. UIMLView::~UIMLView()
  463. {
  464. if (dom)
  465. dom->release();
  466. members->release();
  467. }
  468. // Verarbeitet ein Maus Ereignis. Wird vom Framework automatisch aufgerufen.
  469. // me: Das Ereignis
  470. void UIMLView::doMausEreignis(MausEreignis& me, bool userRet)
  471. {
  472. if (dom)
  473. {
  474. bool verarbeitet = me.verarbeitet;
  475. me.verarbeitet |= hatStyleNicht(Style::Sichtbar);
  476. bool insideParent = me.insideParent;
  477. if (!hatStyle(Style::Sichtbar) || !me.insideParent || me.verarbeitet || me.mx < 0 || me.my < 0 || me.mx >= gr.x || me.my >= gr.y || !userRet)
  478. me.insideParent = 0;
  479. int rbr = 0;
  480. if (hatStyle(Style::Rahmen) && rahmen)
  481. rbr = rahmen->getRBreite();
  482. me.mx -= rbr;
  483. me.my -= rbr;
  484. if (hatStyle(Style::VScroll) && vertikalScrollBar)
  485. me.my += vertikalScrollBar->getScroll();
  486. if (hatStyle(Style::HScroll) && horizontalScrollBar)
  487. me.mx += horizontalScrollBar->getScroll();
  488. if (dom)
  489. {
  490. for (auto i = dom->getChilds(); i; i++)
  491. { // TODO render elements backwards
  492. Zeichnung* z = members->z(i->getAttributeValue("id"), i->getAttributeValue("id").getLength());
  493. if (z)
  494. z->doPublicMausEreignis(me);
  495. }
  496. }
  497. me.mx += rbr;
  498. me.my += rbr;
  499. if (hatStyle(Style::VScroll) && vertikalScrollBar)
  500. me.my -= vertikalScrollBar->getScroll();
  501. if (hatStyle(Style::HScroll) && horizontalScrollBar)
  502. me.mx -= horizontalScrollBar->getScroll();
  503. if (!hatStyle(Style::Sichtbar) || !me.insideParent || me.verarbeitet || me.mx < 0 || me.my < 0 || me.mx >= gr.x || me.my >= gr.y || !userRet)
  504. me.insideParent = insideParent;
  505. else
  506. me.verarbeitet = 1;
  507. if (hatStyleNicht(Style::Sichtbar))
  508. me.verarbeitet = verarbeitet;
  509. }
  510. }
  511. //! entfernt alle bekannten elemente, die im uiml verwendet werden können
  512. void UIMLView::removeAllKnownElements()
  513. {
  514. knownElements.leeren();
  515. }
  516. //! fügt ein neues bekanntes element hinzu, dass danach im uiml verwendet werden kann.
  517. void UIMLView::addKnownElement(UIMLElement* element)
  518. {
  519. knownElements.add(element);
  520. }
  521. //! prüft, ob ein xml Element ein bekanntes uiml Element ist;
  522. bool UIMLView::isKnownElement(XML::Element* zElement)
  523. {
  524. for (UIMLElement* element : knownElements)
  525. {
  526. if (element->isApplicableFor(*zElement))
  527. return 1;
  528. }
  529. return 0;
  530. }
  531. // setzt den inhalt der view
  532. // uiml: Ein xml element gemät des ksg uiml standarts
  533. void UIMLView::setUIML(XML::Element* uiml)
  534. {
  535. if (dom)
  536. dom->release();
  537. dom = uiml;
  538. members->leeren();
  539. nextId = 0;
  540. if (dom)
  541. {
  542. for (auto i = dom->getChilds(); i; i++)
  543. {
  544. parseElement(*i.val(), *this);
  545. }
  546. }
  547. }
  548. // setzt den inhalt der view
  549. // uiml: Ein xml text gemät des ksg uiml standarts
  550. void UIMLView::setUIML(Text uiml)
  551. {
  552. setUIML(new XML::Element(uiml));
  553. }
  554. // Gibt eine zeichnung zurück, welche in uiml eine bestimmte id hat
  555. // id: die id der Zeichnung
  556. Zeichnung* UIMLView::zZeichnungById(const char* id)
  557. {
  558. return members->z(id, textLength(id));
  559. }
  560. // Gibt eine zeichnung zurück, welche in uiml eine bestimmte id hat
  561. // id: die id der Zeichnung
  562. Zeichnung* UIMLView::getZeichnungById(const char* id)
  563. {
  564. return members->get(id, textLength(id));
  565. }
  566. // aktualisiert größe und position aller Zeichnungen gemäß den spezifikationen in UIML
  567. void UIMLView::layout()
  568. {
  569. if (dom)
  570. {
  571. for (auto i = dom->getChilds(); i; i++)
  572. {
  573. Text id = i->getAttributeValue("id");
  574. Zeichnung* z = zZeichnungById(id);
  575. if (z)
  576. {
  577. layout(*i.val(), *z, this->getInnenBreite(), this->getInnenHeight(), *this);
  578. }
  579. }
  580. }
  581. }
  582. // fügt ein element hinzu
  583. // uiml: Ein xml text gemät des KSG UIML standarts, welcher das neue Objekt darstellt
  584. Text UIMLView::addMember(Text uiml)
  585. {
  586. XML::Element* e = new XML::Element(uiml);
  587. if (parseElement(*e, *this))
  588. dom->addChildAtFront(e);
  589. return e->getAttributeValue("id");
  590. }
  591. // fügt ein element zu einem Elternelement hinzu (funktioniert momentan nur mit frame Objekten)
  592. // uiml: Ein xml text gemät des KSG UIML standarts, welcher das neue Objekt darstellt
  593. Text UIMLView::addMember(Text uiml, Text parentId)
  594. {
  595. XML::Element* e = new XML::Element(uiml);
  596. XML::Editor ed = dom->selectChildren();
  597. while (ed.begin())
  598. {
  599. XML::Editor ed2 = ed.whereAttributeEquals("id", parentId);
  600. if (ed2.begin())
  601. {
  602. if (ed2.begin()->getName().istGleich("frame"))
  603. {
  604. Zeichnung* z = parseElement(*e, *this);
  605. if (z)
  606. {
  607. dynamic_cast<Fenster*>(members->z(parentId, parentId.getLength()))->addMember(dynamic_cast<Zeichnung*>(z->getThis()));
  608. ed2.begin()->addChild(e);
  609. }
  610. return e->getAttributeValue("id");
  611. }
  612. }
  613. ed = ed.selectChildren();
  614. }
  615. e->release();
  616. return "";
  617. }
  618. // entfernt ein element
  619. // id: id des Elements
  620. void UIMLView::removeMember(Text id)
  621. {
  622. XML::Editor e = dom->selectChildsByAttribute("id", id);
  623. e.remove();
  624. members->remove(id, id.getLength());
  625. }
  626. // Verarbeitet ein Tastatur Ereignis. Wird vom Framework automatisch aufgerufen
  627. // te: Das Ereignis
  628. void UIMLView::doTastaturEreignis(TastaturEreignis& te)
  629. {
  630. bool verarbeitet = te.verarbeitet;
  631. ZeichnungHintergrund::doTastaturEreignis(te);
  632. te.verarbeitet = verarbeitet;
  633. if (dom)
  634. {
  635. for (auto i = dom->getChilds(); i; i++)
  636. { // TODO render elements backwards
  637. Zeichnung* z = members->z(i->getAttributeValue("id"), i->getAttributeValue("id").getLength());
  638. if (z)
  639. z->doTastaturEreignis(te);
  640. }
  641. }
  642. }
  643. // Updated den Zeichenhintergrund
  644. // tickVal: Die vergangene Zeit in Sekunden, die seit dem Letzten Aufruf dieser Funktion verstrichen ist
  645. // return: 1, wenn das Bild neu gezeichnet werden muss. 0 sonnst
  646. bool UIMLView::tick(double tickVal)
  647. {
  648. if (dom)
  649. {
  650. for (auto i = dom->getChilds(); i; i++)
  651. { // TODO render elements backwards
  652. Zeichnung* z = members->z(i->getAttributeValue("id"), i->getAttributeValue("id").getLength());
  653. if (z)
  654. rend |= z->tick(tickVal);
  655. }
  656. }
  657. return ZeichnungHintergrund::tick(tickVal);
  658. }
  659. // Zeichnet den Hintergrund eines Zeichnunges nach rObj
  660. void UIMLView::render(Bild& rObj)
  661. {
  662. if (hatStyle(Zeichnung::Style::Sichtbar))
  663. {
  664. ZeichnungHintergrund::render(rObj);
  665. if (dom)
  666. {
  667. if (!rObj.setDrawOptions(pos.x + getRahmenBreite(), pos.y + getRahmenBreite(), gr.x + getRahmenBreite() * 2, gr.y + getRahmenBreite() * 2))
  668. return;
  669. bool vSc = hatStyle(Style::VScroll) && vertikalScrollBar;
  670. bool hSc = hatStyle(Style::HScroll) && horizontalScrollBar;
  671. rObj.addScrollOffset(hSc ? horizontalScrollBar->getScroll() : 0, vSc ? vertikalScrollBar->getScroll() : 0);
  672. for (int i = dom->getChildCount() - 1; i >= 0; i--)
  673. { // TODO render elements backwards
  674. XML::Element* e = dom->zChild(i);
  675. Zeichnung* z = members->z(e->getAttributeValue("id"), e->getAttributeValue("id").getLength());
  676. if (z)
  677. z->render(rObj);
  678. }
  679. rObj.releaseDrawOptions();
  680. }
  681. }
  682. }
  683. // Gibt den Dom Tree ohne erhöhten reference counter zurück
  684. // Änderungen am Dom Tree sollten vermieden werden (nur änderungen von attributen einzelner elemente sind erlaubt)
  685. XML::Element* UIMLView::zDom() const
  686. {
  687. return dom;
  688. }
  689. // Gibt den Dom Tree zurück
  690. // Änderungen am Dom Tree sollten vermieden werden (nur änderungen von attributen einzelner elemente sind erlaubt)
  691. XML::Element* UIMLView::getDom() const
  692. {
  693. return dom ? dynamic_cast<XML::Element*>(dom->getThis()) : 0;
  694. }
  695. bool UIMLView::isApplicableFor(XML::Element& element)
  696. {
  697. for (UIMLElement* e : knownElements)
  698. {
  699. if (e->isApplicableFor(element))
  700. return 1;
  701. }
  702. return 0;
  703. }
  704. Zeichnung* UIMLView::parseElement(XML::Element& element, UIMLContainer& generalFactory)
  705. {
  706. Text id;
  707. if (element.hasAttribute("id"))
  708. id = element.getAttributeValue("id");
  709. else
  710. {
  711. id = Text("_") += nextId++;
  712. element.setAttribute("id", id);
  713. }
  714. Zeichnung* z = members->z(id, id.getLength());
  715. if (!z)
  716. {
  717. // precompute attributes
  718. if (element.hasAttribute("margin"))
  719. {
  720. Text m = element.getAttributeValue("margin");
  721. if (!element.hasAttribute("margin-left"))
  722. element.setAttribute("margin-left", m);
  723. if (!element.hasAttribute("margin-top"))
  724. element.setAttribute("margin-top", m);
  725. if (!element.hasAttribute("margin-right"))
  726. element.setAttribute("margin-right", m);
  727. if (!element.hasAttribute("margin-bottom"))
  728. element.setAttribute("margin-bottom", m);
  729. }
  730. if (element.hasAttribute("class"))
  731. {
  732. Text c = element.getAttributeValue("class");
  733. while (1)
  734. {
  735. Text* t;
  736. if (c.hat(","))
  737. t = c.getTeilText(0, c.positionVon(','));
  738. else
  739. t = new Text(c);
  740. XML::Editor ce = dom->selectChildsByName("class").whereAttributeEquals("id", *t);
  741. for (auto i = ce.begin(); i; i++)
  742. {
  743. for (auto j = i->getAttributeNames(), k = i->getAttributeValues(); j && k; j++, k++)
  744. {
  745. if (!element.hasAttribute(j->getText()))
  746. element.setAttribute(j->getText(), i->getText());
  747. }
  748. }
  749. t->release();
  750. if (c.hat(","))
  751. c.remove(0, c.positionVon(',' + 1));
  752. else
  753. break;
  754. }
  755. }
  756. if (element.hasAttribute("text-align"))
  757. {
  758. if (!element.hasAttribute("text-align-horizontal"))
  759. element.setAttribute("text-align-horizontal", element.getAttributeValue("text-align"));
  760. if (!element.hasAttribute("text-align-vertical"))
  761. element.setAttribute("text-align-vertical", element.getAttributeValue("text-align"));
  762. }
  763. // create objects
  764. for (UIMLElement* e : knownElements)
  765. {
  766. if (e->isApplicableFor(element))
  767. {
  768. z = e->parseElement(element, *this);
  769. break;
  770. }
  771. }
  772. if (z)
  773. members->set(id, id.getLength(), z);
  774. }
  775. else
  776. z->getThis();
  777. return z;
  778. }
  779. void UIMLView::layout(XML::Element& element, Zeichnung& z, int pWidth, int pHeight, UIMLContainer& generalLayouter)
  780. {
  781. for (UIMLElement* e : knownElements)
  782. {
  783. if (e->isApplicableFor(element))
  784. {
  785. e->layout(element, z, pWidth, pHeight, *this);
  786. break;
  787. }
  788. }
  789. }
  790. const UIInit& UIMLView::getFactory()
  791. {
  792. return init;
  793. }
  794. //! calculates the needed size for all content elements to be visible
  795. Punkt UIMLView::calculateContentSize()
  796. {
  797. Punkt maxP(0, 0);
  798. for (int i = dom->getChildCount() - 1; i >= 0; i--)
  799. { // TODO render elements backwards
  800. XML::Element* e = dom->zChild(i);
  801. Zeichnung* z = members->z(e->getAttributeValue("id"), e->getAttributeValue("id").getLength());
  802. if (z)
  803. {
  804. maxP.x = MAX(maxP.x, z->getPosition().x + z->getBreite());
  805. maxP.y = MAX(maxP.y, z->getPosition().y + z->getHeight());
  806. }
  807. }
  808. maxP.x += 2 * getRahmenBreite();
  809. maxP.y += 2 * getRahmenBreite();
  810. return maxP;
  811. }