控件出处

https://components.xamarin.com/

https://components.xamarin.com/gettingstarted/ZumeroDataGrid/true

效果图

 
 

上正文

Xamarin.forms项目右键->管理NUGET

Android、ios项目依次添加。

注册控件

Ios:

    AppDelegate.cs

    public
override
bool FinishedLaunching(UIApplication app, NSDictionary options)

{

global::Xamarin.Forms.Forms.Init();

 
 

Zumero.DataGridComponent.Init();

     ……

Android:

    MainActivity.cs

    protected
override
void OnCreate(Bundle bundle)

{

base.OnCreate(bundle);

 
 

global::Xamarin.Forms.Forms.Init(this, bundle);

Zumero.DataGridComponent.Init();

     ……

Forms 应用

Xaml:

    xmlns:d="clr-namespace:Zumero;assembly=Zumero.DataGrid"
//声明

    应用如下:

<d:DataGrid
x:Name="datagrid"
Rows="{Binding DataRows}"
BackgroundColor="Black"
RowHeight="40"
HeaderHeight="40"
HorizontalOptions="FillAndExpand"
VerticalOptions="FillAndExpand">

<d:DataGrid.FrozenColumn>

<d:Column
Width="40">

<d:Column.HeaderView>

<Label
Text="姓名"
BackgroundColor="Gray"
TextColor="Black"
XAlign="Center"
YAlign="Center"></Label>

</d:Column.HeaderView>

<d:Column.Template>

<DataTemplate>

<Label
Text="{Binding SampleName}"
BackgroundColor="White"
TextColor="Black"
XAlign="Center"
YAlign="Center"></Label>

</DataTemplate>

</d:Column.Template>

</d:Column>

</d:DataGrid.FrozenColumn>

<d:DataGrid.Columns>

<d:DataGrid.Columns>

<d:Column
Width="150">

<d:Column.HeaderView>

<Label
Text="文本"
BackgroundColor="Gray"
TextColor="Black"
XAlign="Center"
YAlign="Center"></Label>

</d:Column.HeaderView>

<d:Column.Template>

<DataTemplate>

<Label
Text="{Binding SampleDescription}"
BackgroundColor="White"
TextColor="Black"
XAlign="Center"
YAlign="Center"></Label>

</DataTemplate>

</d:Column.Template>

</d:Column>

</d:DataGrid.Columns>

</d:DataGrid>

属性说明

        DataGrid

            Rows="{Binding DataRows}"     //数据源
固定写法对应后端代码
datagrid.Rows = new
ObservableCollection<object>

            RowHeight="40"         //行高

            HeaderHeight="40"        //表头高度

        d:DataGrid.FrozenColumn        //
Fxed列,固定不会随拖拽变动 同columns类似

        d:DataGrid.Columns            //列,格式同上文中内容

        d:Column.HeaderView            //列表头布局

        d:Column.Template            //列模板

        DataTemplate                //数据模板

        d:DataGrid.Columns-》d:Column-》d:Column.HeaderView-》Label

d:Column.Template-》DataTemplate-》Label

事件绑定

        <Button
Text="详细"
Clicked="OnCodeButtonClicked"
BorderWidth="0"
BackgroundColor="Green"
TextColor="White"></Button>

        通过Clicked事件进行回调处理

CS代码:

    初始化数据绑定:

    OpenCode、OpenXaml 参数类型对应 Func<Page>

    用于数据绑定按钮点击弹出对应上文中的 《详细》 Button

        protected
override
void OnAppearing()

        {

            base.OnAppearing();

 
 

            datagrid.Rows = new
ObservableCollection<object>

            {

                new
SampleObject

                {

                    SampleName = "Presidents",

                    SampleDescription = "Shows images, dates. Includes headers and a frozen column.",

                    OpenCode = () => { return
new
PresidentsCode(); },

                    OpenXaml = () => { return
new
PresidentsXaml(); },

                },

                new
SampleObject

                {

                    SampleName = "Countries",

                    SampleDescription = "Lots of rows. Unicode text.",

                    OpenCode = () => { return
new
CountriesCode(); },

                    OpenXaml = () => { return
new
CountriesXaml(); },

                },

                new
SampleObject

                {

                    SampleName = "Dynamic",

                    SampleDescription = "Dynamic generation of one million 'virtual' rows.",

                    OpenCode = () => { return
new
DynamicCode(); },

                    OpenXaml = () => { return
new
DynamicXaml(); },

                },

                new
SampleObject

                {

                    SampleName = "XSquared",

                    SampleDescription = "Includes slider controls with two way binding.",

                    OpenCode = () => { return
new
XSquaredCode(); },

                    OpenXaml = () => { return
new
XSquaredXaml(); },

                },

            };

        }

    事件弹窗:

        void OnCodeButtonClicked(object sender, EventArgs args)

        {

            Button button = (Button)sender;

            this.Navigation.PushAsync(((SampleObject)button.BindingContext).OpenCode());

        }

Xamarin.Forms DataGrid的更多相关文章

  1. Xamarin.Forms 开发资源集合(复制)

    复制:https://www.cnblogs.com/mschen/p/10199997.html 收集整理了下 Xamarin.Forms 的学习参考资料,分享给大家,稍后会不断补充: UI样式 S ...

  2. Xamarin.Forms 开发资源集合

    收集整理了下 Xamarin.Forms 的学习参考资料,分享给大家,稍后会不断补充: UI样式 Snppts: Xamarin Forms UI Snippets. Prebuilt Templat ...

  3. Xamarin devexpress datagrid 样式

    DevExpress的提供光与暗的内置,可以应用到主题GridControl改变其外观.   主题 iOS版 Android版 光(默认适用于iOS) 黑暗(默认为Android) 应用预定义的主题 ...

  4. xamarin.forms新建项目android编译错误

    vs2015 update3 新建的xamarin.forms项目中的android项目编译错误.提示缺少android_m2repository_r22.zip,96659D653BDE0FAEDB ...

  5. Xamarin.Forms 简介

    An Introduction to Xamarin.Forms 来源:http://developer.xamarin.com/guides/cross-platform/xamarin-forms ...

  6. Xamarin.Forms 免费电子书

    Xamarin Evolve 正在举行,现在已经放出2本免费的Xamarin.Forms 免费电子书,据现场的同学说这两天还有Xamarin.Forms 重磅消息发布: Creating Mobile ...

  7. 老司机学新平台 - Xamarin Forms开发框架之MvvmCross插件精选

    在前两篇老司机学Xamarin系列中,简单介绍了Xamarin开发环境的搭建以及Prism和MvvmCross这两个开发框架.不同的框架,往往不仅仅使用不同的架构风格,同时社区活跃度不同,各种功能模块 ...

  8. 老司机学新平台 - Xamarin Forms开发框架二探 (Prism vs MvvmCross)

    在上一篇Xamarin开发环境及开发框架初探中,曾简单提到MvvmCross这个Xamarin下的开发框架.最近又评估了一些别的,发现老牌Mvvm框架Prism现在也支持Xamarin Forms了, ...

  9. 使用Xamarin.Forms平台开发移动应用指南

    下载书:链接: http://pan.baidu.com/s/1c29H9KG 密码: 7esm 注:捣鼓虚拟机把Hyper-V关闭,后来Xamarin搞挂了,所以暂停翻译. 第1章 Xamarin. ...

随机推荐

  1. <一>初探js特效魅力之选项卡05

    初探js特效魅力05 接下来为大家介绍的选项卡的切换 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN&quo ...

  2. 什么是券商PB业务

    PB业务(Prime Broker,主经纪商业务).所谓PB业务就是指向对冲基金等高端机构客户提供集中托管清算.后台运营.研究支持.杠杆融资.证券拆借.资金募集等一站式综合金融服务的统称.而该业务的基 ...

  3. 加入gitignore文件没有起作用怎么办

    步骤一: 假设有未提交的文件先提交到Git. 步骤二: 在Git根文件夹下运行以下的Git命令: git rm -r --cached . git add . git commit -m " ...

  4. mount, findmnt,df命令

    ■    The  mount  command gives an overview of all mounted devices. To get this information, the /pro ...

  5. js数组的操作及数组与字符串的相互转化

    数组与字符串的相互转化 <script type="text/javascript">var obj="new1abcdefg".replace(/ ...

  6. boostrap预定义样式风格

    预定义样式分为五种:primary(首选项).success(成功).info(一般信息).warning(警告).danger(危险),demo如下,设置不同的class展示不同的样式 <!D ...

  7. CSS3 用户界面

    CSS3用户界面 在CSS3中,新的用户界面特性包括重设元素尺寸,盒尺寸以及轮廓等. 用户界面属性: resize box-sizing outline-offset 浏览器支持 属性 浏览器支持 r ...

  8. oralce中exists not exists in not in对于NULL的处理

    1.   先讨论 in 与 not in中存在NULL的情况, sql语句如下: 1 select 1 result1 from dual where 1 not in (2, 3); 2 3 4 s ...

  9. Maven构建SSM架构,并分离层次,使用Maven 组织多项目

    参考http://www.cnblogs.com/quanyongan/archive/2013/05/28/3103243.html一步一步搭建,感谢QuantSeven 1.建好的目录结构 说明: ...

  10. VS2010 C++ 优化配置

    个人感觉VC6.0太土了,而且有很多bug存在,且微软早就不对其更新.所以,在选择C++编程的时候.使用IDE,VC6.0一段时间以后,我毅然决然的放弃了,觉得还是使用VS2010比较有前途. 但是当 ...