Devexpress 提供了datagrid 控件对于xamarin 进行支持。整个世界美好了,已经无法用语言来形容一个 被列表控件折磨的要死的人看到熟悉的图标时候的激动了。还有一点引用官网的原话:

    

And yes, it·s free!

好了感慨结束进入正文:

下载dll

https://components.xamarin.com/view/devexpress-grid

下载后:

根据pcl、android、ios不同项目添加右键引用目录很清晰。

初始化

以下初始化代码添加到Android(在MainActivity.cs文件),iOS设备(该AppDelegate.cs文件)和Windows Phone(在MainPage.xaml.cs的文件)的项目。

DevExpress.Mobile.Forms.Init
();

控件使用

Xaml

创建xaml page 界面代码如下

<?xml
version="1.0"
encoding="utf-8" ?>

<ContentPage
xmlns="http://xamarin.com/schemas/2014/forms"

xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"

x:Class="BarCode.Pages.DevExpressDataGrid"

xmlns:dxGrid = "clr-namespace:DevExpress.Mobile.DataGrid;assembly=DevExpress.Mobile.Grid.v15.2" >

<dxGrid:GridControl
x:Name="grid">

</dxGrid:GridControl>

</ContentPage>

Cs 数据绑定

在此步骤中,您将创建一个内存中的数据源对象,并使用数据填充它。

注:虽然DevExpress的网格完全支持标准Xamarin数据绑定机制,本教程使用内存中的数据,以避免外部文件或数据库的依赖。

声明顺序类封装一个单独的数据记录。它的公共属性(日期,发货产品数量)将作为数据源字段。

///
<summary>

/// 排序类

///
</summary>

public
class
Order : ModelObject

{

 

DateTime date;

bool shipped;

Product product;

int quantity;

 

public Order()

{

this.date = DateTime.Today;

this.shipped = false;

this.product = new
Product("", 0);

this.quantity = 0;

}

 

public Order(DateTime date, bool shipped, Product product, int quantity)

{

this.date = date;

this.shipped = shipped;

this.product = product;

this.quantity = quantity;

}

 

public
DateTime Date

{

get { return date; }

set

{

if (date != value)

{

date = value;

RaisePropertyChanged("Date");

}

}

}

 

public
bool Shipped

{

get { return shipped; }

set

{

if (shipped != value)

{

shipped = value;

RaisePropertyChanged("Shipped");

}

}

}

 

public
Product Product

{

get { return product; }

set

{

if (product != value)

{

product = value;

RaisePropertyChanged("Product");

}

}

}

 

public
int Quantity

{

get { return quantity; }

set

{

if (quantity != value)

{

quantity = value;

RaisePropertyChanged("Quantity");

}

}

}

}

 

///
<summary>

/// 商品类

///
</summary>

public
class
Product : ModelObject

{

string name;

int unitPrice;

 

public Product(string name, int unitPrice)

{

this.name = name;

this.unitPrice = unitPrice;

}

 

public
string Name

{

get { return name; }

set { name = value; }

}

 

public
int UnitPrice

{

get { return unitPrice; }

set { unitPrice = value; }

}

}

 

public
class
ModelObject : System.ComponentModel.INotifyPropertyChanged

{

public
event System.ComponentModel.PropertyChangedEventHandler PropertyChanged;

 

protected
void RaisePropertyChanged(string name)

{

if (PropertyChanged != null)

PropertyChanged(this, new System.ComponentModel.PropertyChangedEventArgs(name));

}

}

 

/***********************/

public
abstract
class
OrdersRepository

{

readonly System.Collections.ObjectModel.ObservableCollection<Order> orders;

 

public OrdersRepository()

{

this.orders = new System.Collections.ObjectModel.ObservableCollection<Order>();

}

 

public System.Collections.ObjectModel.ObservableCollection<Order> Orders

{

get { return orders; }

}

}

 

public
class
TestOrdersRepository : OrdersRepository

{

 

const
int orderCount = 100;

readonly
List<Product> products;

readonly
Random random;

 

public TestOrdersRepository() : base()

{

this.random = new
Random((int)DateTime.Now.Ticks);

this.products = new
List<Product>();

 

GenerateProducts();

 

for (int i = 0; i < orderCount; i++)

Orders.Add(GenerateOrder(i));

}

 

Order GenerateOrder(int number)

{

Order order = new
Order(new
DateTime(2014, 1, 1).AddDays(random.Next(0, 60)),

number % 3 == 0, RandomItem<Product>(products), random.Next(1, 100));

return order;

}

 

T RandomItem<T>(IList<T> list)

{

int index = (int)(random.NextDouble() * 0.99 * (list.Count));

return list[index];

}

 

void GenerateProducts()

{

products.Add(new
Product("Tofu", 50));

products.Add(new
Product("Chocolade", 34));

products.Add(new
Product("Ikura", 70));

products.Add(new
Product("Chai", 3));

products.Add(new
Product("Boston Crab Meat", 36));

products.Add(new
Product("Ravioli Angelo", 18));

products.Add(new
Product("Ipon Coffee", 10));

products.Add(new
Product("Questo Cabrales", 25));

}

    }            

绑定的DevExpress网格数据和创建新列

设置BindingContext为内容页的实例TestOrdersRepository类(在.cs如下证明文件)。

 
 

TestOrdersRepository model =new
TestOrdersRepository ();

                                                    

BindingContext = model;

                                

 
 

一旦网格绑定到数据源,创建列,并将其绑定到数据字段。下面列类型(** **的GridColumn子类)可用于在网格控制使用:TextColumnNumberColumnDateColumnSwitchColumnImageColumn

建立相应的列对象,采用每列绑定到相应的数据字段GridColumn.FieldName财产和列添加到GridControl.Columns集合。

您可以创建未绑定列和显示基于对等栏目适用的公式计算值。要启动,相应的列对象添加到GridControl.Columns收集并设置以下列属性。

  • GridColumn.FieldName -一个唯一的字符串,一个不匹配网格控制的基础数据源的任何字段名称。

  • GridColumn.UnboundExpression -式(字符串表达式)来自动为该列计算的值。

  • GridColumn.UnboundType -列数据类型(布尔,日期时间,小数,整数,字符串或对象)。

在下面的例子中,共列绑定和显示产品数量乘以单价

 
 

XAML

<dxGrid:GridControl x:Name="grid" ItemsSource="{Binding Orders}">

<dxGrid:GridControl.Columns>

<dxGrid:TextColumn FieldName="Product.Name" Caption =
"Product" Width =
"170"
/>

<dxGrid:NumberColumn FieldName="Product.UnitPrice" Caption =
"Price" DisplayFormat="C0"/>

<dxGrid:NumberColumn FieldName="Quantity"/>

<dxGrid:NumberColumn FieldName="Total"

UnboundType="Integer" UnboundExpression="[Quantity] * [Product.UnitPrice]"

IsReadOnly="True" DisplayFormat="C0"/>

<dxGrid:DateColumn FieldName="Date" DisplayFormat="d"/>

<dxGrid:SwitchColumn FieldName="Shipped"
/>

</dxGrid:GridControl.Columns>

</dxGrid:GridControl>

新建项目行

为了帮助最终用户简化数据输入,该网格的DevExpress包括一个Microsoft Outlook风格的新项目行选项。要激活它,设定GridControl.NewItemRowVisibility属性为true,如下图所示。

<dxGrid:GridControl x:Name="grid" ItemsSource="{Binding Orders}" NewItemRowVisibility =
"true">

<!--
...
-->

</dxGrid:GridControl>

数据排序

默认时,DevExpress的电网将针对一列的数据进行排序。要启动排序,设置所需的列的GridColumn.SortOrder属性为Ascending or Descending。一旦排序顺序被选中,电网将首次明确所有以前的规定适用排序操作,然后重新排序的数据。

要针对多个列的数据进行排序,设定GridControl.SortMode属性GridSortMode.Multiple,并指定GridColumn.SortOrder所需的列。要指定排序顺序优先级,使用GridColumn.SortIndex您的排序列的财产。

要禁用最终用户排序,使用GridColumn.AllowSort属性。

下面的例子来排序订单Product.Name数量,并禁止终端用户排序的发货列。

 
 

XAML

<dxGrid:GridControl x:Name="grid" ItemsSource="{Binding Orders}"

NewItemRowVisibility =
"true"

CalculateCustomSummary="grid_CustomSummary"

SortMode =
"Multiple">

<dxGrid:GridControl.Columns>

<dxGrid:TextColumn FieldName="Product.Name" Caption =
"Product" Width =
"170"

SortOrder =
"Descending" SortIndex =
"0"/>

<!--
...
-->

<dxGrid:NumberColumn FieldName="Quantity"

SortOrder =
"Ascending" SortIndex =
"1"/>

<!--
...
-->

<dxGrid:SwitchColumn FieldName="Shipped" AllowSort =
"False"/>

</dxGrid:GridControl.Columns>

</dxGrid:GridControl>

数据分组

该DevExpress的网格控制,您可以针对它的列中显示的值分组。使用日期使用下面的代码组订单GridColumn.IsGroupedGridColumn.GroupInterval属性

XAML

<dxGrid:GridControl x:Name="grid" ItemsSource="{Binding Orders}" NewItemRowVisibility =
"true">

<dxGrid:GridControl.Columns>

<!--
...
-->

<dxGrid:DateColumn FieldName="Date" DisplayFormat="d"

IsGrouped =
"true" GroupInterval =
"Date"/>

<!--
...
-->

</dxGrid:GridControl.Columns>

</dxGrid:GridControl>

数据摘要

该DevExpress的网格,可以显示全部或组汇总 - 对分别在整个数据集或记录组计算的聚合函数值 - 已启用数据分组时。

总摘要存储在GridControl.TotalSummaries集合。组摘要存储在GridControl.GroupSummaries集合。在这两种情况下,从个人摘要被指定GridColumnSummary对象。要激活汇总计算,你将需要指定数据字段(** ** GridColumnSummary.FieldName),聚合函数类型(** ** GridColumnSummary.Type),并汇总值格式(** ** GridColumnSummary.DisplayFormat)。

预定义的聚合函数类型有计数,最大值,最小值,总和与平均值。

在这个例子中,一组摘要用于显示的最大为每个记录组值,和一个总摘要在显示所有值的总和总计列。

下面还示例代码演示了如何使用定义的聚合函数的自定义来算的"非运"订单数。聚合函数可以通过设置来实现GridColumnSummary.Type属性自定义和处理GridControl.CalculateCustomSummary事 ​​件。

XAML

<dxGrid:GridControl x:Name="grid" ItemsSource="{Binding Orders}"

NewItemRowVisibility =
"true"

CalculateCustomSummary="OnCalculateCustomSummary">

<!--
...
-->

<dxGrid:GridControl.GroupSummaries>

<dxGrid:GridColumnSummary FieldName="Total" Type="Max"

DisplayFormat="Max Total: {0:C0}"/>

</dxGrid:GridControl.GroupSummaries>

 
 

<dxGrid:GridControl.TotalSummaries>

<dxGrid:GridColumnSummary FieldName="Total" Type="Sum"

DisplayFormat=
"Total: {0:C0}"/>

<dxGrid:GridColumnSummary FieldName="Shipped" Type="Custom"

DisplayFormat=
"Not Shipped: {0}"/>

</dxGrid:GridControl.TotalSummaries>

</dxGrid:GridControl>

C#

int count;

// ...

 
 

void
OnCalculateCustomSummary(object sender,
CustomSummaryEventArgs e)
{

if
(e.FieldName.ToString
()
==
"Shipped")

if
(e.IsTotalSummary){

if
(e.SummaryProcess == CustomSummaryProcess.Start)
{

count =
0;

}

if
(e.SummaryProcess == CustomSummaryProcess.Calculate)
{

if
(!(bool)e.FieldValue)

count++;

e.TotalValue = count;

}

}

}

数据过滤

该DevExpress的电网支持对多列数据过滤。

要应用过滤器针对特定列,使用GridColumn.AutoFilterValue属性。要指定比较运算符,使用GridColumn.AutoFilterCondition属性。

要激活过滤为最终用户,使电网的内置使用自动过滤器面板GridControl.AutoFilterPanelVisibility财产。自动过滤器的功能可以用于经由任何列被禁用GridColumn.AllowAutoFilter属性。

XAML

<dxGrid:GridControl x:Name="grid" ItemsSource="{Binding Orders}"

NewItemRowVisibility =
"true"

CalculateCustomSummary="grid_CustomSummary"

SortMode =
"Multiple" AutoFilterPanelVisibility="true">

<dxGrid:GridControl.Columns>

<!--
...
-->

<dxGrid:SwitchColumn FieldName="Shipped" AllowSort =
"False" AllowAutoFilter="false"/>

</dxGrid:GridControl.Columns>

</dxGrid:GridControl>

要创建一个包含适用于多列多条件筛选表达式,使用GridControl.FilterExpressionGridControl.FilterString作为必要的属性。

一旦过滤器已经被应用,则DevExpress的网格自动显示在其容器底部的过滤板。面板提供了旨在暂时禁用或清除过滤器的当前应用的过滤条件,按键的反馈。控制面板的知名度,使用GridControl.FilterPanelVisibility属性。

列宽自适应

AllowResizeColumns="True"//用户用手指手势拖动列宽

AllowHorizontalScrollingVirtualization="True" //是否支持横向滚动 需要配合 columnsautowidth

ColumnsAutoWidth="True"//列宽自适应

结果

如果你按照这个一步一步的教程,你得到的应用程序看起来应该像下面这样。

  

Xamarin devexpress Grid的更多相关文章

  1. Xamarin devexpress datagrid 样式

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

  2. DevExpress Grid使用checkBox选中的方法

    到官网得到消息自13.2版本后的Dev Grid中均内置了CheckBox列多选功能.在寻找答案的过程的成果进行记录. 一.13.2版本以后用法 启用多选列 对Gird中的View进行以下属性设置: ...

  3. Xamarin.Forms——WebView技术研究

    在Xamarin中有一些Forms原生不太好实现的内容可以考虑使用HTML.Javascript.CSS那一套前端技术来实现,使用WebView来承载显示本地或网络上的HTML文件.不像OpenUri ...

  4. Xamarin.Forms WebView

    目前本地或网络的网页内容和文件加载 WebView是在您的应用程序显示Web和HTML内容的视图.不像OpenUri,这需要用户在Web浏览器的设备上,WebView中显示您的应用程序内的HTML内容 ...

  5. 实例:用户界面控件Kendo UI vs DevExpress对比评测一

    在一次使用ASP.NET MVC进行开发的Web项目中,我们需要用户界面控件来帮助实现界面的大部分功能.由于项目比较复杂,我们最终确定对 Kendo UI 和 DevExpress 这两款国际知名的用 ...

  6. 搞懂Xamarin.Forms布局,看这篇应该就够了吧

    Xamarin.Forms 布局介绍 什么是布局?可以简单的理解为,我们通过将布局元素有效的组织起来,让屏幕变成我们想要的样子! 我们通过画图的方式来描述一下Xamarin.Forms的布局. 小节锚 ...

  7. 利用Warensoft Stock Service编写高频交易软件

    利用Warensoft Stock Service编写高频交易软件 无论是哪种交易软件,对于程序员来讲,最麻烦的就是去实现各种算法.本文以SAR算法的实现过程为例,为大家说明如何使用Warensoft ...

  8. 利用Warensoft Stock Service编写高频交易软件--DEMO

    利用Warensoft Stock Service编写高频交易软件 无论是哪种交易软件,对于程序员来讲,最麻烦的就是去实现各种算法.本文以SAR算法的实现过程为例,为大家说明如何使用Warensoft ...

  9. DevExpress WinForms使用教程:Data Grid - Find Panel模式

    [DevExpress WinForms v18.2下载] DevExpress WinForms用户都熟知,Data Grid是整个产品线的主要产品.在v18.2中添加了一些新的功能,例如之前教程中 ...

随机推荐

  1. hyperv虚拟机网络速度慢问题的解决办法

    服务器安装了windows2012R2进行虚拟化,虚拟机也是用的是windows2012R2的操作系统,这样可以一次激活对应的虚拟机. 在使用虚拟机的过程中发现问题,虚拟机主机的网速正常,无论是ftp ...

  2. javascript表单行为效果展示

    效果如下 以上效果是在点击下一步的时候触发的效果显示 代码如下 ////加工厂$(function() { $("#planttwo").click(function () { v ...

  3. HUNNU--湖师大--11410--Eligibility

    [I] Eligibility Regional Contest Director Osama Ismail knows that an individual cannot participate i ...

  4. [MongoDB] Introduce to MongoDB

    1. Use or create a database: use wandRecorder You will use keyword to create or fetch a exicting dat ...

  5. UML解惑:图说UML中的六大关系--转

    UML定义的关系主要有六种:依赖.类属.关联.实现.聚合和组合.这些类间关系的理解和使用是掌握和应用UML的关键,而也就是这几种关系,往往会让初学者迷惑.这里给出这六种主要UML关系的说明和类图描述, ...

  6. Android EditText的使用及值得注意的地方

    Android上有很多输入法应用,每种输入法都有各自的特点,输入法多数时候是和EditText配合使用,结合我自己的亲身实践分享一下使用EditText过程中遇到的一些问题及解决方法. 设置默认输入法 ...

  7. 【解决】WordPress FTP连接服务器时出错,请检查设置,WordPress需要访问您网页服务器的权限

    刚装好wordpress,发现后台预装了两个插件,想删掉,结果要登录FTP,死活登不上去,提示"连接服务器时出错,请检查设置,WordPress需要访问您网页服务器的权限",网上也 ...

  8. phpmyadmin登陆提示#2002 无法登录 MySQL 服务器和设置自增

    看看mysql启动没有,结果是mysql服务没有启动,找了半天,是这个原因,那就右键计算机->管理->服务->启动mysql服务 设置自增:在显示出来的一行字段定义中把浏览器的滚动条 ...

  9. String在JAVA里是固定长度的吗?为什么可用“+”连接

    所谓长度固定不是你理解的意思而是说String类中存储的char[]是final的,不能修改,你对String的操作实际上是产生了一个新的String,对于某一个String来说,长度就是固定的了 S ...

  10. sqlserver2012 评估期已过问题处理

    由于之前安装sqlserver2012忘记输入序列号,现在出现评估期已过的问题,网上忙活半天,才解决,发现网上叙述都很凌乱,而且只有大意,新手很难操作,所以把我操作的过程分享给大家 1 开始菜单找到s ...