xmake.repo/packages/n/noesis/latest/Include/NsGui/ContentPresenter.h

130 lines
3.7 KiB
C
Raw Permalink Normal View History

2024-12-22 19:15:02 +08:00
////////////////////////////////////////////////////////////////////////////////////////////////////
// NoesisGUI - http://www.noesisengine.com
// Copyright (c) 2013 Noesis Technologies S.L. All Rights Reserved.
////////////////////////////////////////////////////////////////////////////////////////////////////
#ifndef __GUI_CONTENTPRESENTER_H__
#define __GUI_CONTENTPRESENTER_H__
#include <NsCore/Noesis.h>
#include <NsGui/FrameworkElement.h>
namespace Noesis
{
class DataTemplate;
class DataTemplateSelector;
class TextBlock;
////////////////////////////////////////////////////////////////////////////////////////////////////
/// Displays the content of ContentControl.
///
/// http://msdn.microsoft.com/en-us/library/system.windows.controls.contentpresenter.aspx
////////////////////////////////////////////////////////////////////////////////////////////////////
class NS_GUI_CORE_API ContentPresenter: public FrameworkElement
{
public:
ContentPresenter();
~ContentPresenter();
/// Gets or sets content
//@{
BaseComponent* GetContent() const;
void SetContent(BaseComponent* content);
void SetContent(const char* content);
//@}
/// Gets or sets the base name to use during automatic aliasing.
//@{
const char* GetContentSource() const;
void SetContentSource(const char* source);
//@}
/// Gets or sets the format used to display the content of the control as a string.
//@{
const char* GetContentStringFormat() const;
void SetContentStringFormat(const char* value);
//@}
/// Gets or sets the template used to display the content of the control.
//@{
DataTemplate* GetContentTemplate() const;
void SetContentTemplate(DataTemplate* value);
//@}
/// Gets or sets the DataTemplateSelector, which allows the application writer to provide
/// custom logic for choosing the template that is used to display the content of the control.
//@{
DataTemplateSelector* GetContentTemplateSelector() const;
void SetContentTemplateSelector(DataTemplateSelector* selector);
//@}
public:
/// Dependency properties
//@{
static const DependencyProperty* ContentProperty;
static const DependencyProperty* ContentSourceProperty;
static const DependencyProperty* ContentStringFormatProperty;
static const DependencyProperty* ContentTemplateProperty;
static const DependencyProperty* ContentTemplateSelectorProperty;
//@}
protected:
// Invoked when Content property changes
virtual void OnContentChanged(BaseComponent* oldContent, BaseComponent* newContent);
/// From BaseRefCounted
//@{
int32_t OnDestroy() override;
//@}
/// From DependencyProperty
//@{
void OnInit() override;
bool OnPropertyChanged(const DependencyPropertyChangedEventArgs& args) override;
//@}
/// From FrameworkElement
//@{
void CloneOverride(FrameworkElement* clone, FrameworkTemplate* template_) const override;
void OnPreApplyTemplate() override;
//@}
private:
friend class ItemsControl;
void PrepareContainer(BaseComponent* item, DataTemplate* itemTemplate,
DataTemplateSelector* itemTemplateSelector);
void ClearContainer(BaseComponent* item);
void InvalidateVisualTree(bool disconnectChild = true);
bool RemoveOldParent(Visual* child) const;
TextBlock* GetDefaultTemplate() const;
void EnsureDefaultTemplate();
void RemoveDefaultTemplate();
void ResetTemplate();
private:
union
{
mutable struct
{
bool refreshVisualTree : 1;
bool localDataContext : 1;
} mFlags;
// To quickly set all flags to 0
uint32_t mAllFlags;
};
NS_DECLARE_REFLECTION(ContentPresenter, FrameworkElement)
};
}
#endif