【转】RadControls for Silverlight(学习1-GridView)

【转】RadControls for Silverlight(学习1-GridView)引用:Telerik(官网:http://www.telerik.com/)是保加利亚的一个软件公司,专注于微软.Net平台的表示层与内容管理控件。我们提供高度稳定性和丰富性能的组件产品,并可应用在非常严格的环境中。现在拥有Microsoft,HP,Alcoa,BP,HarperCollins,Siemens,T-Mobile,HJHeinz和一些最主要的教育机构和很多政府机…

大家好,又见面了,我是你们的朋友全栈君。

引用:Telerik(官 网:http://www.telerik.com/)是保加利亚的一个软件公司,专注于微软.Net平台的表示层与内容管理控件。我们提供高度稳定性和丰富性能的组件产品,并可应用在非常严格的环境中。现在拥有 Microsoft, HP, Alcoa, BP, Harper Collins, Siemens, T-Mobile, HJ Heinz和一些最主要的教育机构和很多政府机关等客户。

我在使用的版本是RadControls_for_Silverlight4_2011_1_0316,开发工具采用VS2010 +SQLServer2008R2进行测试学习

Grid是我们做系统必不可少的控件了,所以我准备从这个开始,为自己留下学习痕迹。

先是了解控件属性便于下一步学习,常用属性

RadGridView

常用属性

说明

DEMO名称

AutoGenerateColumns=”False”

是否自动产生列

 

IsReadOnly=”True”

IsReadOnly=”{Binding IsChecked, Mode=TwoWay, ElementName=IsReadOnlyCheckBox}”

是否只读

Click Event

command

ShowGroupPanel=”False”

是否显示分组面板(常用,一般情况下是不会用到这个的)

 

DataLoadMode=”Asynchronous”

数据加载模式

 

RowIndicatorVisibility=”Collapsed”

行指示

 

SelectionMode=”Extended”

 

Command

CanUserDeleteRows=”{Binding IsChecked, Mode=TwoWay, ElementName=CanUserDeleteRowsCheckBox}”

是否可删除行

Command

ScrollViewer.HorizontalScrollBarVisibility=”Auto”

ScrollViewer.VerticalScrollBarVisibility=”Auto”

横向竖向滚动条设定

 

IsFilteringAllowed=”False”

列过滤查询是否可用

Enable/Disable

ShowColumnFooters=”True”

是否显示列脚

Totals

ShowGroupFooters=”True”

是否显示分组列脚

Totals

GridLinesVisibility=

Both

Horizontal

Vertical

网络线设置

gridlinevisiblity

GridViewDataColumn

属性

说明

DEMO名称

IsGroupable=”False”

列是否加入分组

 

IsFilterable=”False”

列是否可过滤查询

 

IsSortable=”False”

列是否可排序

 

DataFormatString=”{}{0:c2}”

DataFormatString=”{}{0:d}”

列输入格式

 

GridViewDataColumn.FilteringControl :可自定义表头查询控件

1、产生自动编号-Row Number

· 自定义列与绑定列并存

XAML
    <Grid>
        <telerik:RadGridView x:Name="RadGridView1" ItemsSource="{Binding Customers}" AutoGeneratingColumn="RadGridView1_AutoGeneratingColumn">
            <telerik:RadGridView.Columns>
                <custom:MyColumn Header="#" Width="50" />
            </telerik:RadGridView.Columns>
        </telerik:RadGridView>
    </Grid>
 

· 自动绑定后的列取消功能(如果取消的列较多,还是需要考虑用别的方法替代)

 private void RadGridView1_AutoGeneratingColumn(object sender, Telerik.Windows.Controls.GridViewAutoGeneratingColumnEventArgs e)
        {
            if (e.Column.UniqueName == "Order" || e.Column.UniqueName == "Product") 
            {
                e.Cancel = true;
            }
        }

· 自定义列的处理

public class MyColumn : Telerik.Windows.Controls.GridViewColumn
    {
        public override FrameworkElement CreateCellElement(Telerik.Windows.Controls.GridView.GridViewCell cell, object dataItem)
        {
            TextBlock textBlock = cell.Content as TextBlock;
 
            if (textBlock == null)
            {
                textBlock = new TextBlock();
            }
 
            textBlock.Text = (this.DataControl.Items.IndexOf(dataItem) + 1).ToString();
 
            return textBlock;
        }
    }
 

2、行、列、单元格只读设置

private void ChangeEnableStateColumn(bool isEnabled)
   {
            GridViewHeaderRow headerRow = RadGridView1.ChildrenOfType<GridViewHeaderRow>().FirstOrDefault();
            if (headerRow != null)
            {
                GridViewCellBase cell = (from c in headerRow.Cells
                                        where c.Column.UniqueName == "EmployeeID"
                                             select c).FirstOrDefault();
                if (cell != null)
                {
                    cell.IsEnabled = isEnabled;
                }
            }
 
            foreach (object item in RadGridView1.Items)
            {
                GridViewRow row = RadGridView1.ItemContainerGenerator.ContainerFromItem(item) as GridViewRow;
                if (row != null)
                {
                    GridViewCellBase cell = (from c in row.Cells
                                             where c.Column.UniqueName == "EmployeeID"
                                             select c).FirstOrDefault();
                    if (cell != null)
                    {
                        cell.IsEnabled = isEnabled;
                    }
                }
            }
  }
 
private void ChangeEnableStateCell(bool isEnabled)
{
            if (RadGridView1.Items.Count > 0)
            {
                GridViewRow row = RadGridView1.ItemContainerGenerator.ContainerFromItem(RadGridView1.Items[0]) as GridViewRow;
                if (row != null)
                {
                    GridViewCellBase cell = (from c in row.Cells
                                             where c.Column.UniqueName == "EmployeeID"
                                             select c).FirstOrDefault();
                    if (cell != null)
                    {
                        cell.IsEnabled = isEnabled;
                    }
                }
            }
}
 
private void ChangeEnableStateRow(bool isEnabled)
        {
            if (RadGridView1.Items.Count > 0)
            {
                GridViewRow row = RadGridView1.ItemContainerGenerator.ContainerFromItem(RadGridView1.Items[0]) as GridViewRow;
                if (row != null)
                {
                    row.IsEnabled = isEnabled;
                }
            }
}
XAML
    <Grid>
        <telerik:RadGridView x:Name="RadGridView1" ItemsSource="{Binding Customers}" AutoGeneratingColumn="RadGridView1_AutoGeneratingColumn">
            <telerik:RadGridView.Columns>
                <custom:MyColumn Header="#" Width="50" />
            </telerik:RadGridView.Columns>
        </telerik:RadGridView>
    </Grid>

3、设置网格线颜色

private void VerticalGridLinesColorPicker_SelectedColorChanged(object sender, EventArgs e)
{
RadGridView1.VerticalGridLinesBrush = new SolidColorBrush(VerticalGridLinesColorPicker.SelectedColor);
}
 
private void HorizontalGridLinesColorPicker_SelectedColorChanged(object sender, EventArgs e)
{
RadGridView1.HorizontalGridLinesBrush = new SolidColorBrush(HorizontalGridLinesColorPicker.SelectedColor);
}      

4、保存用户对网格的设置

DEMO中saveandload settings中的Radgridviewsetting.cs非常用用:)

 

引用地址:http://www.cnblogs.com/forrestsun/archive/2011/05/13/2045859.html

转载于:https://www.cnblogs.com/sishierfei/p/3308681.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161987.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SAP WebIDE的本地安装方式「建议收藏」

    SAP WebIDE的本地安装方式「建议收藏」#CreatedbyJerryWang,lastmodifiedonJun02,20151.https://store.sap.com/下载安装文件:![clipboard1](https://user-images.githubusercontent.com/5669954/27470901-38a99006-57f6-11e7-8c0e-57f5cbf86e…

    2022年10月18日
    5
  • web大前端必备的VSCode插件,常用的(15个)「建议收藏」

    web大前端必备的VSCode插件,常用的(15个)「建议收藏」VisualStudioCode是由微软开发的一款免费、跨平台的文本编辑器。由于其卓越的性能和丰富的功能,它很快就受到了大家的喜爱。就像大多数IDE一样,VSCode也有一个扩展和主题市场,包含了数以千计质量不同的插件。为了帮助大家挑选出值得下载的插件,我们针对性的收集了一些实用、有趣的插件与大家分享。1.Open-In-Browser由于VSCode没有提供直接在浏览…

    2022年7月25日
    42
  • Dijkstra算法

    Dijkstra算法

    2021年12月3日
    48
  • oracle amm和asmm,在Oracle中,什么是ASMM和AMM?

    oracle amm和asmm,在Oracle中,什么是ASMM和AMM?A答案ASMM(AutomaticSharedMemoryManagement,自动共享内存管理)是Oracle10g引入的概念。通过使用ASMM,就不需要手工设置相关内存组件的大小,而只为SGA设置一个总的大小,Oracle的MMAN进程(MemoryManagerProcess,内存管理进程)会随着时间推移,根据系统负载的变化和内存需要,自动调整SGA中各个组件的内存大小。ASMM…

    2022年6月7日
    36
  • 连表查询的介绍_连接表

    连表查询的介绍_连接表1、连表查询的原因(1)如果查询结果不在一个表中,在多个表中,那就需要将表关联,进行连表查询。(2)连表查询大多数都作用在外键得基础上。—表与表之间有关联。2.1表与表之间存在的关系(1)一对多:在多的一方添加外键列(2)多对多:需要创建一个中间表,该表中至少有两个外键列2.2连表查询2.3内连接内连接演示—结果都是一样,只是语法不同。看个人习惯用哪个?1.查询每一个员工的姓名,及关联的部门的名称〔隐式内连接实现)2.查询每一个员工的姓名,及关.

    2025年11月13日
    4
  • 查询接口调用成功,但未查询到数据_dde怎么看

    查询接口调用成功,但未查询到数据_dde怎么看DTU轮询采集指令YeeCOMDTU提供了22组周期串口轮询,1组定时串口查询功能,根据配置规则自动输出串口指令,可实现自动采集外设数据并上报服务器,替代服务器的轮询,减小服务器开销。注1:第1组串口轮询最多可配置6条,单条最大长度28;第2组串口轮询最多可配置4条;单条最大长度28;1组固定时间,最多可以配置5条;单条最大长度20;如还不够或特殊需求可以由服务器下发指令或定制DTU版本。注2:轮询指令可灵活配置,常见

    2022年10月14日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号