现在主流的控件模板和样式是引用XAML资源,不过感觉没有c#代码实现那么灵活,现介绍一下代码实现ControlTemplate的方法:
//
控件呈现的显示内容1(这里为Image)
FrameworkElementFactoryfe = new FrameworkElementFactory( typeof (Image), " Image " );
BitmapImagebi = new BitmapImage();
bi.BeginInit();
bi.UriSource = new Uri( @" E:ChartControlHanYangChartControlImageMainBackground.jpg " );
bi.EndInit();
fe.SetValue(Image.SourceProperty,bi);
// 控件呈现的显示内容2(这里为TextBox)
FrameworkElementFactoryfe2 = new FrameworkElementFactory( typeof (TextBox), " TextBox " );
fe2.SetValue(TextBox.WidthProperty, 100.0 );
fe2.SetValue(TextBox.HeightProperty, 100.0 );
// 把要呈现的显示内容封装起来
FrameworkElementFactoryf = new FrameworkElementFactory( typeof (Grid), " Grid " );
f.AppendChild(fe);
f.AppendChild(fe2);
// 控件模板
ControlTemplatect = new ControlTemplate( typeof (Button));
ct.VisualTree = f;
// 修改Button的Template
Buttonbtn = new Button();
btn.Template = ct;
FrameworkElementFactoryfe = new FrameworkElementFactory( typeof (Image), " Image " );
BitmapImagebi = new BitmapImage();
bi.BeginInit();
bi.UriSource = new Uri( @" E:ChartControlHanYangChartControlImageMainBackground.jpg " );
bi.EndInit();
fe.SetValue(Image.SourceProperty,bi);
// 控件呈现的显示内容2(这里为TextBox)
FrameworkElementFactoryfe2 = new FrameworkElementFactory( typeof (TextBox), " TextBox " );
fe2.SetValue(TextBox.WidthProperty, 100.0 );
fe2.SetValue(TextBox.HeightProperty, 100.0 );
// 把要呈现的显示内容封装起来
FrameworkElementFactoryf = new FrameworkElementFactory( typeof (Grid), " Grid " );
f.AppendChild(fe);
f.AppendChild(fe2);
// 控件模板
ControlTemplatect = new ControlTemplate( typeof (Button));
ct.VisualTree = f;
// 修改Button的Template
Buttonbtn = new Button();
btn.Template = ct;