137 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			137 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
						|
// NoesisGUI - http://www.noesisengine.com
 | 
						|
// Copyright (c) 2013 Noesis Technologies S.L. All Rights Reserved.
 | 
						|
////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
						|
 | 
						|
 | 
						|
#ifndef __GUI_CONTEXTMENUSERVICE_H__
 | 
						|
#define __GUI_CONTEXTMENUSERVICE_H__
 | 
						|
 | 
						|
 | 
						|
#include <NsCore/Noesis.h>
 | 
						|
#include <NsCore/Ptr.h>
 | 
						|
#include <NsCore/ReflectionDeclare.h>
 | 
						|
#include <NsGui/CoreApi.h>
 | 
						|
 | 
						|
 | 
						|
namespace Noesis
 | 
						|
{
 | 
						|
 | 
						|
class BaseComponent;
 | 
						|
struct Rect;
 | 
						|
class DependencyObject;
 | 
						|
class DependencyProperty;
 | 
						|
class RoutedEvent;
 | 
						|
class UIElement;
 | 
						|
class ContextMenu;
 | 
						|
struct EventArgs;
 | 
						|
enum PlacementMode: int32_t;
 | 
						|
 | 
						|
////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
						|
/// Provides the system implementation for displaying a ContextMenu.
 | 
						|
///
 | 
						|
/// The following example shows how to use the service to display a ContextMenu on a disabled
 | 
						|
/// button. Notice that you set the ShowOnDisabled property on the button that is the parent of
 | 
						|
/// the context menu.
 | 
						|
///
 | 
						|
/// .. code-block:: xml
 | 
						|
///    :caption: XAML
 | 
						|
///
 | 
						|
///    <Button Height="30" Content="Disabled Button" IsEnabled="False" 
 | 
						|
///         ContextMenuService.ShowOnDisabled="True">
 | 
						|
///      <Button.ContextMenu>
 | 
						|
///        <ContextMenu>
 | 
						|
///          <MenuItem Header="Item 1"/>
 | 
						|
///          <MenuItem Header="Item 2"/>
 | 
						|
///          <MenuItem Header="Item 3"/>
 | 
						|
///        </ContextMenu>
 | 
						|
///      </Button.ContextMenu>
 | 
						|
///    </Button>
 | 
						|
///
 | 
						|
/// https://msdn.microsoft.com/en-us/library/system.windows.controls.contextmenuservice.aspx
 | 
						|
////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
						|
struct NS_GUI_CORE_API ContextMenuService
 | 
						|
{
 | 
						|
    /// Dependency properties
 | 
						|
    //@{
 | 
						|
    static const DependencyProperty* ContextMenuProperty;
 | 
						|
    static const DependencyProperty* HasDropShadowProperty;
 | 
						|
    static const DependencyProperty* HorizontalOffsetProperty;
 | 
						|
    static const DependencyProperty* IsEnabledProperty;
 | 
						|
    static const DependencyProperty* PlacementProperty;
 | 
						|
    static const DependencyProperty* PlacementRectangleProperty;
 | 
						|
    static const DependencyProperty* PlacementTargetProperty;
 | 
						|
    static const DependencyProperty* ShowOnDisabledProperty;
 | 
						|
    static const DependencyProperty* VerticalOffsetProperty;
 | 
						|
    //@}
 | 
						|
 | 
						|
    /// Routed events
 | 
						|
    //@{
 | 
						|
    static const RoutedEvent* ContextMenuClosingEvent;
 | 
						|
    static const RoutedEvent* ContextMenuOpeningEvent;
 | 
						|
    //@}
 | 
						|
 | 
						|
    /// Gets or sets the value of the ContextMenu property of the specified object
 | 
						|
    //@{
 | 
						|
    static ContextMenu* GetContextMenu(DependencyObject* obj);
 | 
						|
    static void SetContextMenu(DependencyObject* obj, ContextMenu* contextMenu);
 | 
						|
    //@}
 | 
						|
 | 
						|
    /// Gets or sets a value that indicates whether the context menu appears with a dropped shadow
 | 
						|
    //@{
 | 
						|
    static bool GetHasDropShadow(DependencyObject* obj);
 | 
						|
    static void SetHasDropShadow(DependencyObject* obj, bool hasDropShadow);
 | 
						|
    //@}
 | 
						|
 | 
						|
    /// Gets or sets the horizontal distance between the target origin and the popup alignment point
 | 
						|
    //@{
 | 
						|
    static float GetHorizontalOffset(DependencyObject* obj);
 | 
						|
    static void SetHorizontalOffset(DependencyObject* obj, float offset);
 | 
						|
    //@}
 | 
						|
 | 
						|
    /// Gets or sets a value that indicates whether the ContextMenu can be shown
 | 
						|
    //@{
 | 
						|
    static bool GetIsEnabled(DependencyObject* obj);
 | 
						|
    static void SetIsEnabled(DependencyObject* obj, bool isEnabled);
 | 
						|
    //@}
 | 
						|
 | 
						|
    /// Gets or sets a value that specifies the placement of the ContextMenu relative to the
 | 
						|
    /// PlacementTarget or PlacementRectangle
 | 
						|
    //@{
 | 
						|
    static PlacementMode GetPlacement(DependencyObject* obj);
 | 
						|
    static void SetPlacement(DependencyObject* obj, PlacementMode mode);
 | 
						|
    //@}
 | 
						|
 | 
						|
    /// Gets or sets the area relative to which the context menu is positioned when it opens
 | 
						|
    //@{
 | 
						|
    static const Rect& GetPlacementRectangle(DependencyObject* obj);
 | 
						|
    static void SetPlacementRectangle(DependencyObject* obj, const Rect& rect);
 | 
						|
    //@}
 | 
						|
 | 
						|
    /// Gets or sets the parent control of the ContextMenu.
 | 
						|
    //@{
 | 
						|
    static UIElement* GetPlacementTarget(DependencyObject* obj);
 | 
						|
    static void SetPlacementTarget(DependencyObject* obj, UIElement* target);
 | 
						|
    //@}
 | 
						|
 | 
						|
    /// Gets or sets a value that indicates whether the ContextMenu should be shown when its parent
 | 
						|
    /// is grayed out
 | 
						|
    //@{
 | 
						|
    static bool GetShowOnDisabled(DependencyObject* obj);
 | 
						|
    static void SetShowOnDisabled(DependencyObject* obj, bool showOnDisable);
 | 
						|
    //@}
 | 
						|
 | 
						|
    /// Gets or sets a value that indicates where along the y-direction to place the ContextMenu
 | 
						|
    /// with respect to the parent control
 | 
						|
    //@{
 | 
						|
    static float GetVerticalOffset(DependencyObject* obj);
 | 
						|
    static void SetVerticalOffset(DependencyObject* obj, float offset);
 | 
						|
    //@}
 | 
						|
 | 
						|
    NS_DECLARE_REFLECTION(ContextMenuService, NoParent)
 | 
						|
};
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
#endif
 |