diff options
Diffstat (limited to '')
-rw-r--r-- | linden/indra/llui/llmenugl.h | 774 |
1 files changed, 774 insertions, 0 deletions
diff --git a/linden/indra/llui/llmenugl.h b/linden/indra/llui/llmenugl.h new file mode 100644 index 0000000..77e2b31 --- /dev/null +++ b/linden/indra/llui/llmenugl.h | |||
@@ -0,0 +1,774 @@ | |||
1 | /** | ||
2 | * @file llmenugl.h | ||
3 | * @brief Declaration of the opengl based menu system. | ||
4 | * | ||
5 | * Copyright (c) 2001-2007, Linden Research, Inc. | ||
6 | * | ||
7 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
8 | * to you under the terms of the GNU General Public License, version 2.0 | ||
9 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
10 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
11 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
12 | * online at http://secondlife.com/developers/opensource/gplv2 | ||
13 | * | ||
14 | * There are special exceptions to the terms and conditions of the GPL as | ||
15 | * it is applied to this Source Code. View the full text of the exception | ||
16 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
17 | * online at http://secondlife.com/developers/opensource/flossexception | ||
18 | * | ||
19 | * By copying, modifying or distributing this software, you acknowledge | ||
20 | * that you have read and understood your obligations described above, | ||
21 | * and agree to abide by those obligations. | ||
22 | * | ||
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
25 | * COMPLETENESS OR PERFORMANCE. | ||
26 | */ | ||
27 | |||
28 | #ifndef LL_LLMENUGL_H | ||
29 | #define LL_LLMENUGL_H | ||
30 | |||
31 | #include <list> | ||
32 | |||
33 | #include "llstring.h" | ||
34 | #include "v4color.h" | ||
35 | #include "llframetimer.h" | ||
36 | #include "llevent.h" | ||
37 | |||
38 | #include "llkeyboard.h" | ||
39 | #include "llfloater.h" | ||
40 | #include "lluistring.h" | ||
41 | #include "llview.h" | ||
42 | |||
43 | class LLMenuItemGL; | ||
44 | |||
45 | extern S32 MENU_BAR_HEIGHT; | ||
46 | extern S32 MENU_BAR_WIDTH; | ||
47 | |||
48 | // These callbacks are used by the LLMenuItemCallGL and LLMenuItemCheckGL | ||
49 | // classes during their work. | ||
50 | typedef void (*menu_callback)(void*); | ||
51 | |||
52 | // These callbacks are used by the LLMenuItemCallGL | ||
53 | // classes during their work. | ||
54 | typedef void (*on_disabled_callback)(void*); | ||
55 | |||
56 | // This callback is used by the LLMenuItemCallGL and LLMenuItemCheckGL | ||
57 | // to determine if the current menu is enabled. | ||
58 | typedef BOOL (*enabled_callback)(void*); | ||
59 | |||
60 | // This callback is used by LLMenuItemCheckGL to determine it's | ||
61 | // 'checked' state. | ||
62 | typedef BOOL (*check_callback)(void*); | ||
63 | |||
64 | // This callback is potentially used by LLMenuItemCallGL. If provided, | ||
65 | // this function is called whenever it's time to determine the label's | ||
66 | // contents. Put the contents of the label in the provided parameter. | ||
67 | typedef void (*label_callback)(LLString&,void*); | ||
68 | |||
69 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
70 | // Class LLMenuItemGL | ||
71 | // | ||
72 | // The LLMenuItemGL represents a single menu item in a menu. | ||
73 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
74 | |||
75 | class LLFontGL; | ||
76 | class LLMenuGL; | ||
77 | |||
78 | |||
79 | class LLMenuItemGL : public LLView | ||
80 | { | ||
81 | public: | ||
82 | LLMenuItemGL( const LLString& name, const LLString& label, KEY key = KEY_NONE, MASK = MASK_NONE ); | ||
83 | |||
84 | virtual void setValue(const LLSD& value) { setLabel(value.asString()); } | ||
85 | virtual EWidgetType getWidgetType() const { return WIDGET_TYPE_MENU_ITEM; } | ||
86 | virtual LLString getWidgetTag() const { return LL_MENU_ITEM_TAG; } | ||
87 | |||
88 | virtual LLXMLNodePtr getXML(bool save_children = true) const; | ||
89 | |||
90 | virtual LLString getType() const { return "item"; } | ||
91 | |||
92 | virtual BOOL handleKey(KEY key, MASK mask, BOOL called_from_parent); | ||
93 | virtual BOOL handleHover(S32 x, S32 y, MASK mask); | ||
94 | |||
95 | virtual BOOL handleAcceleratorKey(KEY key, MASK mask); | ||
96 | |||
97 | BOOL getHighlight() const { return mHighlight; } | ||
98 | |||
99 | void setJumpKey(KEY key); | ||
100 | KEY getJumpKey(); | ||
101 | |||
102 | // set the font used by this item. | ||
103 | void setFont(LLFontGL* font); | ||
104 | void setFontStyle(U8 style) { mStyle = style; } | ||
105 | |||
106 | // returns the height in pixels for the current font. | ||
107 | virtual U32 getNominalHeight( void ); | ||
108 | |||
109 | // functions to control the color scheme | ||
110 | static void setEnabledColor( const LLColor4& color ); | ||
111 | static void setDisabledColor( const LLColor4& color ); | ||
112 | static void setHighlightBGColor( const LLColor4& color ); | ||
113 | static void setHighlightFGColor( const LLColor4& color ); | ||
114 | |||
115 | // Marks item as not needing space for check marks or accelerator keys | ||
116 | virtual void setBriefItem(BOOL brief); | ||
117 | |||
118 | virtual BOOL addToAcceleratorList(std::list<LLKeyBinding*> *listp); | ||
119 | void setAllowKeyRepeat(BOOL allow) { mAllowKeyRepeat = allow; } | ||
120 | |||
121 | // return the name label | ||
122 | LLString getLabel( void ) const { return mLabel.getString(); } | ||
123 | |||
124 | // change the label | ||
125 | void setLabel( const LLString& label ); | ||
126 | virtual BOOL setLabelArg( const LLString& key, const LLString& text ); | ||
127 | |||
128 | // Get the parent menu for this item | ||
129 | virtual LLMenuGL* getMenu(); | ||
130 | |||
131 | // returns the normal width of this control in pixels - this is | ||
132 | // used for calculating the widest item, as well as for horizontal | ||
133 | // arrangement. | ||
134 | virtual U32 getNominalWidth( void ); | ||
135 | |||
136 | // buildDrawLabel() - constructs the string used during the draw() | ||
137 | // function. This reduces the overall string manipulation, but can | ||
138 | // lead to visual errors if the state of the object changes | ||
139 | // without the knowledge of the menu item. For example, if a | ||
140 | // boolean being watched is changed outside of the menu item's | ||
141 | // doIt() function, the draw buffer will not be updated and will | ||
142 | // reflect the wrong value. If this ever becomes an issue, there | ||
143 | // are ways to fix this. | ||
144 | // Returns the enabled state of the item. | ||
145 | virtual void buildDrawLabel( void ); | ||
146 | |||
147 | // for branching menu items, bring sub menus up to root level of menu hierarchy | ||
148 | virtual void updateBranchParent( LLView* parentp ){}; | ||
149 | |||
150 | // doIt() - do the primary funcationality of the menu item. | ||
151 | virtual void doIt( void ); | ||
152 | |||
153 | // set the hover status (called by it's menu) | ||
154 | virtual void setHighlight( BOOL highlight ); | ||
155 | |||
156 | // determine if this represents an active sub-menu | ||
157 | virtual BOOL isActive( void ) const; | ||
158 | |||
159 | // determine if this represents an open sub-menu | ||
160 | virtual BOOL isOpen( void ) const; | ||
161 | |||
162 | virtual void setEnabledSubMenus(BOOL enable){}; | ||
163 | |||
164 | // LLView Functionality | ||
165 | virtual BOOL handleKeyHere( KEY key, MASK mask, BOOL called_from_parent ); | ||
166 | virtual BOOL handleMouseUp( S32 x, S32 y, MASK mask ); | ||
167 | virtual void draw( void ); | ||
168 | |||
169 | BOOL getHover() { return mGotHover; } | ||
170 | |||
171 | BOOL getDrawTextDisabled() const { return mDrawTextDisabled; } | ||
172 | |||
173 | protected: | ||
174 | // This function appends the character string representation of | ||
175 | // the current accelerator key and mask to the provided string. | ||
176 | void appendAcceleratorString( LLString& st ); | ||
177 | |||
178 | public: | ||
179 | static LLColor4 sEnabledColor; | ||
180 | static LLColor4 sDisabledColor; | ||
181 | static LLColor4 sHighlightBackground; | ||
182 | static LLColor4 sHighlightForeground; | ||
183 | |||
184 | protected: | ||
185 | static BOOL sDropShadowText; | ||
186 | |||
187 | // mLabel contains the actual label specified by the user. | ||
188 | LLUIString mLabel; | ||
189 | |||
190 | // The draw labels contain some of the labels that we draw during | ||
191 | // the draw() routine. This optimizes away some of the string | ||
192 | // manipulation. | ||
193 | LLUIString mDrawBoolLabel; | ||
194 | LLUIString mDrawAccelLabel; | ||
195 | LLUIString mDrawBranchLabel; | ||
196 | |||
197 | // Keyboard and mouse variables | ||
198 | KEY mJumpKey; | ||
199 | KEY mAcceleratorKey; | ||
200 | MASK mAcceleratorMask; | ||
201 | BOOL mAllowKeyRepeat; | ||
202 | BOOL mHighlight; | ||
203 | BOOL mGotHover; | ||
204 | |||
205 | // If true, suppress normal space for check marks on the left and accelerator | ||
206 | // keys on the right. | ||
207 | BOOL mBriefItem; | ||
208 | |||
209 | // Font for this item | ||
210 | LLFontGL* mFont; | ||
211 | |||
212 | U8 mStyle; | ||
213 | BOOL mDrawTextDisabled; | ||
214 | }; | ||
215 | |||
216 | |||
217 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
218 | // Class LLMenuItemCallGL | ||
219 | // | ||
220 | // The LLMenuItemCallerGL represents a single menu item in a menu that | ||
221 | // calls a user defined callback. | ||
222 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
223 | |||
224 | class LLMenuItemCallGL : public LLMenuItemGL | ||
225 | { | ||
226 | protected: | ||
227 | menu_callback mCallback; | ||
228 | // mEnabledCallback should return TRUE if the item should be enabled | ||
229 | enabled_callback mEnabledCallback; | ||
230 | label_callback mLabelCallback; | ||
231 | void* mUserData; | ||
232 | on_disabled_callback mOnDisabledCallback; | ||
233 | |||
234 | public: | ||
235 | |||
236 | |||
237 | void setMenuCallback(menu_callback callback, void* data) { mCallback = callback; mUserData = data; }; | ||
238 | void setEnabledCallback(enabled_callback callback) { mEnabledCallback = callback; }; | ||
239 | |||
240 | // normal constructor | ||
241 | LLMenuItemCallGL( const LLString& name, | ||
242 | menu_callback clicked_cb, | ||
243 | enabled_callback enabled_cb = NULL, | ||
244 | void* user_data = NULL, | ||
245 | KEY key = KEY_NONE, MASK mask = MASK_NONE, | ||
246 | BOOL enabled = TRUE, | ||
247 | on_disabled_callback on_disabled_cb = NULL); | ||
248 | LLMenuItemCallGL( const LLString& name, | ||
249 | const LLString& label, | ||
250 | menu_callback clicked_cb, | ||
251 | enabled_callback enabled_cb = NULL, | ||
252 | void* user_data = NULL, | ||
253 | KEY key = KEY_NONE, MASK mask = MASK_NONE, | ||
254 | BOOL enabled = TRUE, | ||
255 | on_disabled_callback on_disabled_cb = NULL); | ||
256 | |||
257 | // constructor for when you want to trap the arrange method. | ||
258 | LLMenuItemCallGL( const LLString& name, | ||
259 | const LLString& label, | ||
260 | menu_callback clicked_cb, | ||
261 | enabled_callback enabled_cb, | ||
262 | label_callback label_cb, | ||
263 | void* user_data, | ||
264 | KEY key = KEY_NONE, MASK mask = MASK_NONE, | ||
265 | BOOL enabled = TRUE, | ||
266 | on_disabled_callback on_disabled_c = NULL); | ||
267 | LLMenuItemCallGL( const LLString& name, | ||
268 | menu_callback clicked_cb, | ||
269 | enabled_callback enabled_cb, | ||
270 | label_callback label_cb, | ||
271 | void* user_data, | ||
272 | KEY key = KEY_NONE, MASK mask = MASK_NONE, | ||
273 | BOOL enabled = TRUE, | ||
274 | on_disabled_callback on_disabled_c = NULL); | ||
275 | virtual LLXMLNodePtr getXML(bool save_children = true) const; | ||
276 | |||
277 | virtual LLString getType() const { return "call"; } | ||
278 | |||
279 | virtual EWidgetType getWidgetType() const; | ||
280 | virtual LLString getWidgetTag() const; | ||
281 | |||
282 | void setEnabledControl(LLString enabled_control, LLView *context); | ||
283 | void setVisibleControl(LLString enabled_control, LLView *context); | ||
284 | |||
285 | virtual void setUserData(void *userdata) { mUserData = userdata; } | ||
286 | |||
287 | // called to rebuild the draw label | ||
288 | virtual void buildDrawLabel( void ); | ||
289 | |||
290 | // doIt() - do the primary funcationality of the menu item. | ||
291 | virtual void doIt( void ); | ||
292 | |||
293 | virtual BOOL handleAcceleratorKey(KEY key, MASK mask); | ||
294 | |||
295 | //virtual void draw(); | ||
296 | |||
297 | virtual bool handleEvent(LLPointer<LLEvent> event, const LLSD& userdata); | ||
298 | }; | ||
299 | |||
300 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
301 | // Class LLMenuItemCheckGL | ||
302 | // | ||
303 | // The LLMenuItemCheckGL is an extension of the LLMenuItemCallGL | ||
304 | // class, by allowing another method to be specified which determines | ||
305 | // if the menu item should consider itself checked as true or not. Be | ||
306 | // careful that the check callback provided - it needs to be VERY | ||
307 | // FUCKING EFFICIENT, because it may need to be checked a lot. | ||
308 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
309 | |||
310 | class LLMenuItemCheckGL | ||
311 | : public LLMenuItemCallGL | ||
312 | { | ||
313 | protected: | ||
314 | check_callback mCheckCallback; | ||
315 | BOOL mChecked; | ||
316 | |||
317 | public: | ||
318 | LLMenuItemCheckGL( const LLString& name, | ||
319 | const LLString& label, | ||
320 | menu_callback callback, | ||
321 | enabled_callback enabled_cb, | ||
322 | check_callback check, | ||
323 | void* user_data, | ||
324 | KEY key = KEY_NONE, MASK mask = MASK_NONE ); | ||
325 | LLMenuItemCheckGL( const LLString& name, | ||
326 | menu_callback callback, | ||
327 | enabled_callback enabled_cb, | ||
328 | check_callback check, | ||
329 | void* user_data, | ||
330 | KEY key = KEY_NONE, MASK mask = MASK_NONE ); | ||
331 | LLMenuItemCheckGL( const LLString& name, | ||
332 | const LLString& label, | ||
333 | menu_callback callback, | ||
334 | enabled_callback enabled_cb, | ||
335 | LLString control_name, | ||
336 | LLView *context, | ||
337 | void* user_data, | ||
338 | KEY key = KEY_NONE, MASK mask = MASK_NONE ); | ||
339 | virtual LLXMLNodePtr getXML(bool save_children = true) const; | ||
340 | |||
341 | void setCheckedControl(LLString checked_control, LLView *context); | ||
342 | |||
343 | virtual void setValue(const LLSD& value) { mChecked = value.asBoolean(); } | ||
344 | virtual EWidgetType getWidgetType() const; | ||
345 | virtual LLString getWidgetTag() const; | ||
346 | |||
347 | virtual LLString getType() const { return "check"; } | ||
348 | |||
349 | // called to rebuild the draw label | ||
350 | virtual void buildDrawLabel( void ); | ||
351 | |||
352 | virtual bool handleEvent(LLPointer<LLEvent> event, const LLSD& userdata); | ||
353 | |||
354 | // LLView Functionality | ||
355 | //virtual void draw( void ); | ||
356 | }; | ||
357 | |||
358 | |||
359 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
360 | // Class LLMenuItemToggleGL | ||
361 | // | ||
362 | // The LLMenuItemToggleGL is a menu item that wraps around a user | ||
363 | // specified and controlled boolean. | ||
364 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
365 | |||
366 | class LLMenuItemToggleGL : public LLMenuItemGL | ||
367 | { | ||
368 | protected: | ||
369 | BOOL* mToggle; | ||
370 | |||
371 | public: | ||
372 | LLMenuItemToggleGL( const LLString& name, const LLString& label, | ||
373 | BOOL* toggle, | ||
374 | KEY key = KEY_NONE, MASK mask = MASK_NONE ); | ||
375 | |||
376 | LLMenuItemToggleGL( const LLString& name, | ||
377 | BOOL* toggle, | ||
378 | KEY key = KEY_NONE, MASK mask = MASK_NONE ); | ||
379 | |||
380 | virtual LLString getType() const { return "toggle"; } | ||
381 | |||
382 | // called to rebuild the draw label | ||
383 | virtual void buildDrawLabel( void ); | ||
384 | |||
385 | // doIt() - do the primary funcationality of the menu item. | ||
386 | virtual void doIt( void ); | ||
387 | |||
388 | // LLView Functionality | ||
389 | //virtual void draw( void ); | ||
390 | }; | ||
391 | |||
392 | |||
393 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
394 | // Class LLMenuGL | ||
395 | // | ||
396 | // The Menu class represents a normal rectangular menu somewhere on | ||
397 | // screen. A Menu can have menu items (described above) or sub-menus | ||
398 | // attached to it. Sub-menus are implemented via a specialized | ||
399 | // menu-item type known as a branch. Since it's easy to do wrong, I've | ||
400 | // taken the branch functionality out of public view, and encapsulate | ||
401 | // it in the appendMenu() method. | ||
402 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
403 | |||
404 | class LLMenuArrowGL; | ||
405 | class LLMenuItemBranchGL; | ||
406 | class LLMenuItemTearOffGL; | ||
407 | |||
408 | class LLMenuGL | ||
409 | : public LLUICtrl | ||
410 | { | ||
411 | public: | ||
412 | LLMenuGL( const LLString& name, const LLString& label, LLViewHandle parent_floater = LLViewHandle::sDeadHandle ); | ||
413 | LLMenuGL( const LLString& label, LLViewHandle parent_floater = LLViewHandle::sDeadHandle ); | ||
414 | virtual ~LLMenuGL( void ); | ||
415 | virtual LLXMLNodePtr getXML(bool save_children = true) const; | ||
416 | static LLView* fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFactory *factory); | ||
417 | |||
418 | void parseChildXML(LLXMLNodePtr child, LLView *parent, LLUICtrlFactory *factory); | ||
419 | |||
420 | virtual EWidgetType getWidgetType() const { return WIDGET_TYPE_MENU; } | ||
421 | virtual LLString getWidgetTag() const { return LL_MENU_GL_TAG; } | ||
422 | |||
423 | // LLView Functionality | ||
424 | virtual BOOL handleKey( KEY key, MASK mask, BOOL called_from_parent ); | ||
425 | //virtual BOOL handleKeyHere( KEY key, MASK mask, BOOL called_from_parent ); | ||
426 | virtual BOOL handleUnicodeCharHere( llwchar uni_char, BOOL called_from_parent ); | ||
427 | virtual BOOL handleHover( S32 x, S32 y, MASK mask ); | ||
428 | virtual void draw( void ); | ||
429 | virtual void drawBackground(LLMenuItemGL* itemp, LLColor4& color); | ||
430 | virtual void setVisible(BOOL visible); | ||
431 | |||
432 | virtual BOOL handleAcceleratorKey(KEY key, MASK mask); | ||
433 | |||
434 | LLMenuGL* getChildMenuByName(const LLString& name, BOOL recurse) const; | ||
435 | |||
436 | BOOL clearHoverItem(); | ||
437 | |||
438 | // return the name label | ||
439 | const LLString& getLabel( void ) const { return mLabel.getString(); } | ||
440 | void setLabel(const LLString& label) { mLabel = label; } | ||
441 | |||
442 | static void setDefaultBackgroundColor( const LLColor4& color ); | ||
443 | void setBackgroundColor( const LLColor4& color ); | ||
444 | void setBackgroundVisible( BOOL b ) { mBgVisible = b; } | ||
445 | void setCanTearOff(BOOL tear_off, LLViewHandle parent_floater_handle = LLViewHandle::sDeadHandle); | ||
446 | |||
447 | // Add the menu item to this menu. | ||
448 | virtual BOOL append( LLMenuItemGL* item ); | ||
449 | |||
450 | // add a separator to this menu | ||
451 | virtual BOOL appendSeparator( const LLString &separator_name = "separator" ); | ||
452 | |||
453 | // add a menu - this will create a cascading menu | ||
454 | virtual BOOL appendMenu( LLMenuGL* menu ); | ||
455 | |||
456 | // for branching menu items, bring sub menus up to root level of menu hierarchy | ||
457 | virtual void updateParent( LLView* parentp ); | ||
458 | |||
459 | // setItemEnabled() - pass the name and the enable flag for a | ||
460 | // menu item. TRUE will make sure it's enabled, FALSE will disable | ||
461 | // it. | ||
462 | void setItemEnabled( const LLString& name, BOOL enable ); | ||
463 | |||
464 | // propagate message to submenus | ||
465 | void setEnabledSubMenus(BOOL enable); | ||
466 | |||
467 | void setItemVisible( const LLString& name, BOOL visible); | ||
468 | |||
469 | // sets the left,bottom corner of menu, useful for popups | ||
470 | void setLeftAndBottom(S32 left, S32 bottom); | ||
471 | |||
472 | virtual BOOL handleJumpKey(KEY key); | ||
473 | |||
474 | virtual BOOL jumpKeysActive(); | ||
475 | |||
476 | virtual BOOL isOpen(); | ||
477 | |||
478 | // Shape this menu to fit the current state of the children, and | ||
479 | // adjust the child rects to fit. This is called automatically | ||
480 | // when you add items. *FIX: We may need to deal with visibility | ||
481 | // arrangement. | ||
482 | virtual void arrange( void ); | ||
483 | |||
484 | // remove all items on the menu | ||
485 | void empty( void ); | ||
486 | |||
487 | // Rearrange the components, and do the right thing if the menu doesn't | ||
488 | // fit in the bounds. | ||
489 | // virtual void arrangeWithBounds(LLRect bounds); | ||
490 | |||
491 | void setItemLastSelected(LLMenuItemGL* item); // must be in menu | ||
492 | U32 getItemCount(); // number of menu items | ||
493 | LLMenuItemGL* getItem(S32 number); // 0 = first item | ||
494 | LLMenuItemGL* getHighlightedItem(); | ||
495 | |||
496 | LLMenuItemGL* highlightNextItem(LLMenuItemGL* cur_item, BOOL skip_disabled = TRUE); | ||
497 | LLMenuItemGL* highlightPrevItem(LLMenuItemGL* cur_item, BOOL skip_disabled = TRUE); | ||
498 | |||
499 | void buildDrawLabels(); | ||
500 | void createJumpKeys(); | ||
501 | |||
502 | // Show popup in global screen space based on last mouse location. | ||
503 | static void showPopup(LLMenuGL* menu); | ||
504 | |||
505 | // Show popup at a specific location. | ||
506 | static void showPopup(LLView* spawning_view, LLMenuGL* menu, S32 x, S32 y); | ||
507 | |||
508 | // Whether to drop shadow menu bar | ||
509 | void setDropShadowed( const BOOL shadowed ); | ||
510 | |||
511 | void setParentMenuItem( LLMenuItemGL* parent_menu_item ) { mParentMenuItem = parent_menu_item; } | ||
512 | LLMenuItemGL* getParentMenuItem() { return mParentMenuItem; } | ||
513 | |||
514 | void setTornOff(BOOL torn_off); | ||
515 | BOOL getTornOff() { return mTornOff; } | ||
516 | |||
517 | BOOL getCanTearOff() { return mTearOffItem != NULL; } | ||
518 | |||
519 | KEY getJumpKey() { return mJumpKey; } | ||
520 | void setJumpKey(KEY key) { mJumpKey = key; } | ||
521 | |||
522 | static void setKeyboardMode(BOOL mode) { sKeyboardMode = mode; } | ||
523 | static BOOL getKeyboardMode() { return sKeyboardMode; } | ||
524 | |||
525 | static void onFocusLost(LLView* old_focus); | ||
526 | static LLView *sDefaultMenuContainer; | ||
527 | |||
528 | protected: | ||
529 | void createSpilloverBranch(); | ||
530 | void cleanupSpilloverBranch(); | ||
531 | |||
532 | protected: | ||
533 | static LLColor4 sDefaultBackgroundColor; | ||
534 | static BOOL sKeyboardMode; | ||
535 | |||
536 | LLColor4 mBackgroundColor; | ||
537 | BOOL mBgVisible; | ||
538 | typedef std::list< LLMenuItemGL* > item_list_t; | ||
539 | item_list_t mItems; | ||
540 | typedef std::map<KEY, LLMenuItemGL*> navigation_key_map_t; | ||
541 | navigation_key_map_t mJumpKeys; | ||
542 | LLMenuItemGL* mParentMenuItem; | ||
543 | LLUIString mLabel; | ||
544 | BOOL mDropShadowed; // Whether to drop shadow | ||
545 | BOOL mHorizontalLayout; | ||
546 | BOOL mKeepFixedSize; | ||
547 | BOOL mHasSelection; | ||
548 | LLFrameTimer mFadeTimer; | ||
549 | S32 mLastMouseX; | ||
550 | S32 mLastMouseY; | ||
551 | S32 mMouseVelX; | ||
552 | S32 mMouseVelY; | ||
553 | BOOL mTornOff; | ||
554 | LLMenuItemTearOffGL* mTearOffItem; | ||
555 | LLMenuItemBranchGL* mSpilloverBranch; | ||
556 | LLMenuGL* mSpilloverMenu; | ||
557 | LLViewHandle mParentFloaterHandle; | ||
558 | KEY mJumpKey; | ||
559 | }; | ||
560 | |||
561 | //----------------------------------------------------------------------------- | ||
562 | // class LLPieMenu | ||
563 | // A circular menu of items, icons, etc. | ||
564 | //----------------------------------------------------------------------------- | ||
565 | |||
566 | class LLPieMenu | ||
567 | : public LLMenuGL | ||
568 | { | ||
569 | public: | ||
570 | LLPieMenu(const LLString& name, const LLString& label); | ||
571 | LLPieMenu(const LLString& name); | ||
572 | virtual ~LLPieMenu(); | ||
573 | |||
574 | virtual EWidgetType getWidgetType() const; | ||
575 | virtual LLString getWidgetTag() const; | ||
576 | |||
577 | void initXML(LLXMLNodePtr node, LLView *context, LLUICtrlFactory *factory); | ||
578 | |||
579 | // LLView Functionality | ||
580 | // can't set visibility directly, must call show or hide | ||
581 | virtual void setVisible(BOOL visible); | ||
582 | |||
583 | //virtual BOOL handleKey( KEY key, MASK mask, BOOL called_from_parent ); | ||
584 | virtual BOOL handleHover( S32 x, S32 y, MASK mask ); | ||
585 | virtual BOOL handleMouseDown( S32 x, S32 y, MASK mask ); | ||
586 | virtual BOOL handleRightMouseDown(S32 x, S32 y, MASK mask); | ||
587 | virtual BOOL handleRightMouseUp( S32 x, S32 y, MASK mask ); | ||
588 | virtual BOOL handleMouseUp( S32 x, S32 y, MASK mask ); | ||
589 | virtual void draw(); | ||
590 | virtual void drawBackground(LLMenuItemGL* itemp, LLColor4& color); | ||
591 | |||
592 | virtual BOOL append(LLMenuItemGL* item); | ||
593 | virtual BOOL appendSeparator( const LLString &separator_name = "separator" ); | ||
594 | |||
595 | // the enabled callback is meant for the submenu. The api works | ||
596 | // this way because the menu branch item responsible for the pie | ||
597 | // submenu is constructed here. | ||
598 | virtual BOOL appendMenu(LLPieMenu *menu, | ||
599 | enabled_callback enabled_cb = NULL, | ||
600 | void* user_data = NULL ); | ||
601 | virtual void arrange( void ); | ||
602 | |||
603 | // Display the menu centered on this point on the screen. | ||
604 | void show(S32 x, S32 y, BOOL mouse_down); | ||
605 | void hide(BOOL item_selected); | ||
606 | |||
607 | protected: | ||
608 | LLMenuItemGL *pieItemFromXY(S32 x, S32 y); | ||
609 | S32 pieItemIndexFromXY(S32 x, S32 y); | ||
610 | |||
611 | private: | ||
612 | // These cause menu items to be spuriously selected by right-clicks | ||
613 | // near the window edge at low frame rates. I don't think they are | ||
614 | // needed unless you shift the menu position in the draw() function. JC | ||
615 | //S32 mShiftHoriz; // non-zero if menu had to shift this frame | ||
616 | //S32 mShiftVert; // non-zero if menu had to shift this frame | ||
617 | BOOL mFirstMouseDown; // true from show until mouse up | ||
618 | BOOL mUseInfiniteRadius; // allow picking pie menu items anywhere outside of center circle | ||
619 | LLMenuItemGL* mHoverItem; | ||
620 | BOOL mHoverThisFrame; | ||
621 | LLFrameTimer mShrinkBorderTimer; | ||
622 | F32 mOuterRingAlpha; // for rendering pie menus as both bounded and unbounded | ||
623 | F32 mCurRadius; | ||
624 | BOOL mRightMouseDown; | ||
625 | }; | ||
626 | |||
627 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
628 | // Class LLMenuBarGL | ||
629 | // | ||
630 | // A menu bar displays menus horizontally. | ||
631 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
632 | |||
633 | class LLMenuBarGL : public LLMenuGL | ||
634 | { | ||
635 | protected: | ||
636 | std::list <LLKeyBinding*> mAccelerators; | ||
637 | BOOL mAltKeyTrigger; | ||
638 | |||
639 | public: | ||
640 | LLMenuBarGL( const LLString& name ); | ||
641 | virtual ~LLMenuBarGL(); | ||
642 | virtual LLXMLNodePtr getXML(bool save_children = true) const; | ||
643 | static LLView* fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFactory *factory); | ||
644 | |||
645 | virtual EWidgetType getWidgetType() const { return WIDGET_TYPE_MENU_BAR; } | ||
646 | virtual LLString getWidgetTag() const { return LL_MENU_BAR_GL_TAG; } | ||
647 | |||
648 | virtual BOOL handleAcceleratorKey(KEY key, MASK mask); | ||
649 | virtual BOOL handleKeyHere(KEY key, MASK mask, BOOL called_from_parent); | ||
650 | virtual BOOL handleJumpKey(KEY key); | ||
651 | |||
652 | // rearrange the child rects so they fit the shape of the menu | ||
653 | // bar. | ||
654 | virtual void arrange( void ); | ||
655 | virtual void draw(); | ||
656 | virtual BOOL jumpKeysActive(); | ||
657 | |||
658 | // add a vertical separator to this menu | ||
659 | virtual BOOL appendSeparator( const LLString &separator_name = "separator" ); | ||
660 | |||
661 | // add a menu - this will create a drop down menu. | ||
662 | virtual BOOL appendMenu( LLMenuGL* menu ); | ||
663 | |||
664 | // LLView Functionality | ||
665 | virtual BOOL handleHover( S32 x, S32 y, MASK mask ); | ||
666 | |||
667 | // Returns x position of rightmost child, usually Help menu | ||
668 | S32 getRightmostMenuEdge(); | ||
669 | |||
670 | void resetMenuTrigger() { mAltKeyTrigger = FALSE; } | ||
671 | |||
672 | protected: | ||
673 | void checkMenuTrigger(); | ||
674 | |||
675 | }; | ||
676 | |||
677 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
678 | // Class LLMenuHolderGL | ||
679 | // | ||
680 | // High level view that serves as parent for all menus | ||
681 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
682 | class LLMenuHolderGL : public LLPanel | ||
683 | { | ||
684 | public: | ||
685 | LLMenuHolderGL(); | ||
686 | LLMenuHolderGL(const LLString& name, const LLRect& rect, BOOL mouse_opaque, U32 follows = FOLLOWS_NONE); | ||
687 | virtual ~LLMenuHolderGL(); | ||
688 | |||
689 | virtual EWidgetType getWidgetType() const; | ||
690 | virtual LLString getWidgetTag() const; | ||
691 | |||
692 | virtual BOOL hideMenus(); | ||
693 | void reshape(S32 width, S32 height, BOOL called_from_parent); | ||
694 | void setCanHide(BOOL can_hide) { mCanHide = can_hide; } | ||
695 | |||
696 | // LLView functionality | ||
697 | virtual void draw(); | ||
698 | virtual BOOL handleMouseDown( S32 x, S32 y, MASK mask ); | ||
699 | virtual BOOL handleRightMouseDown( S32 x, S32 y, MASK mask ); | ||
700 | |||
701 | static void setActivatedItem(LLMenuItemGL* item); | ||
702 | BOOL hasVisibleMenu(); | ||
703 | |||
704 | protected: | ||
705 | static LLViewHandle sItemLastSelectedHandle; | ||
706 | static LLFrameTimer sItemActivationTimer; | ||
707 | |||
708 | BOOL mCanHide; | ||
709 | }; | ||
710 | |||
711 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
712 | // Class LLTearOffMenu | ||
713 | // | ||
714 | // Floater that hosts a menu | ||
715 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
716 | class LLTearOffMenu : public LLFloater | ||
717 | { | ||
718 | public: | ||
719 | static LLTearOffMenu* create(LLMenuGL* menup); | ||
720 | virtual ~LLTearOffMenu(); | ||
721 | virtual void onClose(bool app_quitting); | ||
722 | virtual void draw(void); | ||
723 | virtual void onFocusReceived(); | ||
724 | virtual void onFocusLost(); | ||
725 | virtual BOOL handleUnicodeChar(llwchar uni_char, BOOL called_from_parent); | ||
726 | virtual BOOL handleKey(KEY key, MASK mask, BOOL called_from_parent); | ||
727 | virtual void translate(S32 x, S32 y); | ||
728 | |||
729 | protected: | ||
730 | LLTearOffMenu(LLMenuGL* menup); | ||
731 | |||
732 | protected: | ||
733 | LLView* mOldParent; | ||
734 | LLMenuGL* mMenu; | ||
735 | F32 mTargetHeight; | ||
736 | }; | ||
737 | |||
738 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
739 | // Class LLMenuItemTearOffGL | ||
740 | // | ||
741 | // This class represents a separator. | ||
742 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
743 | |||
744 | class LLMenuItemTearOffGL : public LLMenuItemGL | ||
745 | { | ||
746 | public: | ||
747 | LLMenuItemTearOffGL( LLViewHandle parent_floater_handle = (LLViewHandle)LLViewHandle::sDeadHandle ); | ||
748 | |||
749 | virtual EWidgetType getWidgetType() const; | ||
750 | virtual LLString getWidgetTag() const; | ||
751 | |||
752 | virtual LLString getType() const { return "tearoff_menu"; } | ||
753 | |||
754 | virtual void doIt(void); | ||
755 | virtual void draw(void); | ||
756 | virtual U32 getNominalHeight(); | ||
757 | |||
758 | protected: | ||
759 | LLViewHandle mParentHandle; | ||
760 | }; | ||
761 | |||
762 | |||
763 | // *TODO: this is currently working, so finish implementation | ||
764 | class LLEditMenuHandlerMgr | ||
765 | { | ||
766 | public: | ||
767 | LLEditMenuHandlerMgr& getInstance(); | ||
768 | virtual ~LLEditMenuHandlerMgr(); | ||
769 | protected: | ||
770 | LLEditMenuHandlerMgr(); | ||
771 | |||
772 | }; | ||
773 | |||
774 | #endif // LL_LLMENUGL_H | ||