102 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
						|
// NoesisGUI - http://www.noesisengine.com
 | 
						|
// Copyright (c) 2013 Noesis Technologies S.L. All Rights Reserved.
 | 
						|
////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
						|
 | 
						|
 | 
						|
#ifndef __GUI_NAMESCOPE_H__
 | 
						|
#define __GUI_NAMESCOPE_H__
 | 
						|
 | 
						|
 | 
						|
#include <NsCore/Noesis.h>
 | 
						|
#include <NsGui/CoreApi.h>
 | 
						|
#include <NsGui/INameScope.h>
 | 
						|
#include <NsCore/BaseComponent.h>
 | 
						|
#include <NsCore/ReflectionDeclare.h>
 | 
						|
#include <NsCore/HashMap.h>
 | 
						|
#include <NsCore/Delegate.h>
 | 
						|
#include <NsCore/String.h>
 | 
						|
 | 
						|
 | 
						|
namespace Noesis
 | 
						|
{
 | 
						|
 | 
						|
class DependencyObject;
 | 
						|
class DependencyProperty;
 | 
						|
 | 
						|
NS_WARNING_PUSH
 | 
						|
NS_MSVC_WARNING_DISABLE(4251 4275)
 | 
						|
 | 
						|
////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
						|
/// Store relationships between the XAML defined names of objects and their instances.
 | 
						|
///
 | 
						|
/// NameScope is generally more devoted to supplying infrastructure than for common user code
 | 
						|
/// scenarios that involve working with a XAML namescope. For most scenarios, the FindName methods
 | 
						|
/// exposed on FrameworkElement are more appropriate methods to call to search for elements by
 | 
						|
/// XAML-defined name. The Name properties exposed by FrameworkElement are more appropriate
 | 
						|
/// properties to use to set the initial name as markup attributes.
 | 
						|
///
 | 
						|
/// The various methods of NameScope are used by base elements and other classes that maintain XAML
 | 
						|
/// namescopes in order to support RegisterName and FindName. You generally use the API in the
 | 
						|
/// NameScope class only if you are replacing or augmenting the base element behavior for how they
 | 
						|
/// process XAML namescopes for root elements of a XAML page, and as part of templates (which use a
 | 
						|
/// separate XAML namescope from the rest of the page).
 | 
						|
///
 | 
						|
/// https://learn.microsoft.com/en-us/dotnet/api/system.windows.namescope
 | 
						|
////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
						|
class NS_GUI_CORE_API NameScope: public BaseComponent, public INameScope
 | 
						|
{
 | 
						|
public:
 | 
						|
    NameScope();
 | 
						|
    ~NameScope();
 | 
						|
 | 
						|
    /// Gets or sets the attached NameScope property
 | 
						|
    //@{
 | 
						|
    static NameScope* GetNameScope(const DependencyObject* element);
 | 
						|
    static void SetNameScope(DependencyObject* element, NameScope* nameScope);
 | 
						|
    //@}
 | 
						|
 | 
						|
    /// Finds the name of an object if it is registered in the NameScope.
 | 
						|
    /// Returns null if object was not found
 | 
						|
    const char* FindObject(BaseComponent* obj) const;
 | 
						|
 | 
						|
    /// Calls the delegate for each named object registered in the NameScope
 | 
						|
    typedef void (*EnumCallback)(const char*, BaseComponent*, void*);
 | 
						|
    void EnumNamedObjects(EnumCallback callback, void* context = 0) const;
 | 
						|
 | 
						|
    /// From INameScope
 | 
						|
    //@{
 | 
						|
    BaseComponent* FindName(const char* name) const override;
 | 
						|
    void RegisterName(const char* name, BaseComponent* obj) override;
 | 
						|
    void UnregisterName(const char* name) override;
 | 
						|
    void UpdateName(const char* name, BaseComponent* obj) override;
 | 
						|
    INameScope::ChangedDelegate& NameScopeChanged() override;
 | 
						|
    //@}
 | 
						|
 | 
						|
    NS_IMPLEMENT_INTERFACE_FIXUP
 | 
						|
 | 
						|
public:
 | 
						|
    /// Dependency properties
 | 
						|
    //@{
 | 
						|
    static const DependencyProperty* NameScopeProperty; // attached property
 | 
						|
    //@}
 | 
						|
 | 
						|
protected:
 | 
						|
    int32_t OnDestroy() override;
 | 
						|
 | 
						|
private:
 | 
						|
    typedef HashMap<String, BaseComponent*> NameObjectMap;
 | 
						|
    NameObjectMap mNamedObjects;
 | 
						|
 | 
						|
    ChangedDelegate mChanged;
 | 
						|
 | 
						|
    NS_DECLARE_REFLECTION(NameScope, BaseComponent)
 | 
						|
};
 | 
						|
 | 
						|
NS_WARNING_POP
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
#endif
 |