posts - 118,  comments - 276,  views - 45万
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
继承ContentControl可以很方便实现包含内容(Content)的控件,方案一:
自定义控件代码如下:

复制代码
    public class DockPanel : ContentControl
    {
        
public DockPanel()
        {
            
this.DefaultStyleKey = typeof(DockPanel);
        }
    }
复制代码

themes/Generic.xaml代码如下:

复制代码
    <Style TargetType="local:DockPanel">
        
<Setter Property="Template">
            
<Setter.Value>
                
<ControlTemplate TargetType="local:DockPanel">
                    
<Grid>
                        
<Border>
                            
<Grid>
                                
<ContentPresenter Content="{TemplateBinding Content}" />
                            
</Grid>
                        
</Border>
                    
</Grid>
                
</ControlTemplate>
            
</Setter.Value>
        
</Setter>
    
</Style>
复制代码

引用页面代码:

复制代码
<UserControl x:Class="SilverlightApplication1.Page"
    xmlns
="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
    xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml" 
    xmlns:cinlap
="clr-namespace:SilverlightClassLibrary1;assembly=SilverlightClassLibrary1"
    Width
="400" Height="300">
    
<Grid x:Name="LayoutRoot" Background="Yellow" Width="400" Height="300" >          
        
<cinlap:DockPanel>
            
<cinlap:DockPanel.Content>
                
<StackPanel Background="Red"/>
            
</cinlap:DockPanel.Content>
        
</cinlap:DockPanel>
    
</Grid>  
</UserControl>
复制代码

方案二:

自定义控件:
复制代码
    public class MyContentControl : Control
    {
        
public static readonly DependencyProperty ContentPanelProperty =
            DependencyProperty.Register(
"ContentPanel"typeof(Panel), typeof(MyContentControl), null);

        
public MyContentControl()
        {
            
this.DefaultStyleKey = typeof(MyContentControl);
        }

        
public Panel ContentPanel
        {
            
get
            {
                
return (Panel)this.GetValue(ContentPanelProperty);
            }
            
set
            {
                
this.SetValue(ContentPanelProperty, value);
            }
        }
    }
复制代码

themes/Generic.xaml代码如下:
复制代码
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
                    xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml" 
                    xmlns:local
="clr-namespace:SilverlightClassLibrary1" >
    
<Style TargetType="local:MyContentControl">
        
<Setter Property="Template">
            
<Setter.Value>
                
<ControlTemplate TargetType="local:MyContentControl">
                    
<Grid>
                        
<Border>
                            
<Grid>                                
                                
<ContentPresenter Content="{TemplateBinding ContentPanel}"/>
                            
</Grid>
                        
</Border>
                    
</Grid>
                
</ControlTemplate>
            
</Setter.Value>
        
</Setter>
    
</Style>
</ResourceDictionary>
复制代码

引用页面代码:
复制代码
    <Grid x:Name="LayoutRoot" Background="Yellow" Width="400" Height="300" >          
        
<cinlap:MyContentControl>
            
<cinlap:MyContentControl.ContentPanel>
                
<StackPanel Background="Red"/>
            
</cinlap:MyContentControl.ContentPanel>
        
</cinlap:MyContentControl>
    
</Grid>
复制代码

补充:
Silverlight自带的内容控件中一般使在ContentPresenter时绑定了以下两个属性:

HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
VerticalAlignment="{TemplateBinding VerticalContentAlignment}"

经试验,定义了这两个属性后,内容元素不能自动缩放,所以在自定义Content控件时,可视自已实际应用运用这两个属性。

posted on   think8848  阅读(933)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示