diff options
Diffstat (limited to 'src/Slit.cc')
-rw-r--r-- | src/Slit.cc | 44 |
1 files changed, 39 insertions, 5 deletions
diff --git a/src/Slit.cc b/src/Slit.cc index d61b411..936815d 100644 --- a/src/Slit.cc +++ b/src/Slit.cc | |||
@@ -22,7 +22,7 @@ | |||
22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | 22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
23 | // DEALINGS IN THE SOFTWARE. | 23 | // DEALINGS IN THE SOFTWARE. |
24 | 24 | ||
25 | // $Id: Slit.cc,v 1.51 2003/05/13 13:28:28 fluxgen Exp $ | 25 | // $Id: Slit.cc,v 1.52 2003/05/13 21:09:43 fluxgen Exp $ |
26 | 26 | ||
27 | #include "Slit.hh" | 27 | #include "Slit.hh" |
28 | 28 | ||
@@ -49,6 +49,8 @@ | |||
49 | #include "RootTheme.hh" | 49 | #include "RootTheme.hh" |
50 | #include "FbTk/Theme.hh" | 50 | #include "FbTk/Theme.hh" |
51 | #include "FbMenu.hh" | 51 | #include "FbMenu.hh" |
52 | #include "Transparent.hh" | ||
53 | #include "IntResMenuItem.hh" | ||
52 | 54 | ||
53 | #include <algorithm> | 55 | #include <algorithm> |
54 | #include <iostream> | 56 | #include <iostream> |
@@ -318,6 +320,9 @@ Slit::Slit(BScreen &scr, FbTk::XLayer &layer, const char *filename) | |||
318 | create_mask, &attrib); | 320 | create_mask, &attrib); |
319 | 321 | ||
320 | FbTk::EventManager::instance()->add(*this, frame.window); | 322 | FbTk::EventManager::instance()->add(*this, frame.window); |
323 | m_transp.reset(new FbTk::Transparent(screen().rootPixmap(), frame.window.drawable(), | ||
324 | *screen().slitAlphaResource(), | ||
325 | screen().getScreenNumber())); | ||
321 | 326 | ||
322 | m_layeritem.reset(new FbTk::XLayerItem(frame.window, layer)); | 327 | m_layeritem.reset(new FbTk::XLayerItem(frame.window, layer)); |
323 | 328 | ||
@@ -470,7 +475,7 @@ void Slit::addClient(Window w) { | |||
470 | FbTk::EventManager::instance()->add(*this, client->icon_window); | 475 | FbTk::EventManager::instance()->add(*this, client->icon_window); |
471 | 476 | ||
472 | frame.window.show(); | 477 | frame.window.show(); |
473 | frame.window.clear(); | 478 | clearWindow(); |
474 | reconfigure(); | 479 | reconfigure(); |
475 | 480 | ||
476 | updateClientmenu(); | 481 | updateClientmenu(); |
@@ -557,6 +562,8 @@ void Slit::removeClient(Window w, bool remap) { | |||
557 | 562 | ||
558 | 563 | ||
559 | void Slit::reconfigure() { | 564 | void Slit::reconfigure() { |
565 | m_transp->setAlpha(*screen().slitAlphaResource()); | ||
566 | |||
560 | frame.width = 0; | 567 | frame.width = 0; |
561 | frame.height = 0; | 568 | frame.height = 0; |
562 | 569 | ||
@@ -654,8 +661,7 @@ void Slit::reconfigure() { | |||
654 | if (tmp) | 661 | if (tmp) |
655 | image_ctrl->removeImage(tmp); | 662 | image_ctrl->removeImage(tmp); |
656 | 663 | ||
657 | frame.window.clear(); | 664 | clearWindow(); |
658 | |||
659 | int x, y; | 665 | int x, y; |
660 | 666 | ||
661 | switch (direction()) { | 667 | switch (direction()) { |
@@ -1064,7 +1070,21 @@ void Slit::configureRequestEvent(XConfigureRequestEvent &event) { | |||
1064 | } | 1070 | } |
1065 | 1071 | ||
1066 | void Slit::exposeEvent(XExposeEvent &ev) { | 1072 | void Slit::exposeEvent(XExposeEvent &ev) { |
1073 | clearWindow(); | ||
1074 | } | ||
1075 | |||
1076 | void Slit::clearWindow() { | ||
1067 | frame.window.clear(); | 1077 | frame.window.clear(); |
1078 | if (frame.pixmap != 0) { | ||
1079 | if (screen().rootPixmap() != m_transp->source()) | ||
1080 | m_transp->setSource(screen().rootPixmap(), screen().getScreenNumber()); | ||
1081 | |||
1082 | m_transp->render(frame.window.x(), frame.window.y(), | ||
1083 | 0, 0, | ||
1084 | frame.window.width(), frame.window.height()); | ||
1085 | |||
1086 | } | ||
1087 | |||
1068 | } | 1088 | } |
1069 | 1089 | ||
1070 | void Slit::timeout() { | 1090 | void Slit::timeout() { |
@@ -1162,12 +1182,20 @@ void Slit::setupMenu() { | |||
1162 | using namespace FbTk; | 1182 | using namespace FbTk; |
1163 | 1183 | ||
1164 | FbTk::MacroCommand *s_a_reconf_macro = new FbTk::MacroCommand(); | 1184 | FbTk::MacroCommand *s_a_reconf_macro = new FbTk::MacroCommand(); |
1185 | FbTk::MacroCommand *s_a_reconf_slit_macro = new FbTk::MacroCommand(); | ||
1165 | FbTk::RefCount<FbTk::Command> saverc_cmd(new FbTk::SimpleCommand<Fluxbox>(*Fluxbox::instance(), | 1186 | FbTk::RefCount<FbTk::Command> saverc_cmd(new FbTk::SimpleCommand<Fluxbox>(*Fluxbox::instance(), |
1166 | &Fluxbox::save_rc)); | 1187 | &Fluxbox::save_rc)); |
1167 | FbTk::RefCount<FbTk::Command> reconf_cmd(new FbCommands::ReconfigureFluxboxCmd()); | 1188 | FbTk::RefCount<FbTk::Command> reconf_cmd(new FbCommands::ReconfigureFluxboxCmd()); |
1189 | FbTk::RefCount<FbTk::Command> reconf_slit_cmd(new FbTk::SimpleCommand<Slit>(*this, &Slit::reconfigure)); | ||
1190 | |||
1168 | s_a_reconf_macro->add(saverc_cmd); | 1191 | s_a_reconf_macro->add(saverc_cmd); |
1169 | s_a_reconf_macro->add(reconf_cmd); | 1192 | s_a_reconf_macro->add(reconf_cmd); |
1193 | |||
1194 | s_a_reconf_slit_macro->add(saverc_cmd); | ||
1195 | s_a_reconf_slit_macro->add(reconf_slit_cmd); | ||
1196 | |||
1170 | FbTk::RefCount<FbTk::Command> save_and_reconfigure(s_a_reconf_macro); | 1197 | FbTk::RefCount<FbTk::Command> save_and_reconfigure(s_a_reconf_macro); |
1198 | FbTk::RefCount<FbTk::Command> save_and_reconfigure_slit(s_a_reconf_slit_macro); | ||
1171 | 1199 | ||
1172 | // setup base menu | 1200 | // setup base menu |
1173 | m_slitmenu.setLabel("Slit"); | 1201 | m_slitmenu.setLabel("Slit"); |
@@ -1182,7 +1210,13 @@ void Slit::setupMenu() { | |||
1182 | CommonSet, CommonAutoHide, | 1210 | CommonSet, CommonAutoHide, |
1183 | "Auto hide"), | 1211 | "Auto hide"), |
1184 | screen().doSlitAutoHide(), | 1212 | screen().doSlitAutoHide(), |
1185 | save_and_reconfigure)); | 1213 | save_and_reconfigure_slit)); |
1214 | |||
1215 | FbTk::MenuItem *alpha_menuitem = new IntResMenuItem("Alpha", | ||
1216 | screen().slitAlphaResource(), | ||
1217 | 0, 255); | ||
1218 | alpha_menuitem->setCommand(save_and_reconfigure_slit); | ||
1219 | m_slitmenu.insert(alpha_menuitem); | ||
1186 | 1220 | ||
1187 | m_slitmenu.insert(new SlitDirMenuItem(i18n->getMessage( | 1221 | m_slitmenu.insert(new SlitDirMenuItem(i18n->getMessage( |
1188 | SlitSet, SlitSlitDirection, | 1222 | SlitSet, SlitSlitDirection, |