DevExpress的提供的内置,可以应用到主题GridControl改变其外观。

 

主题

iOS版

Android版


(默认适用于iOS)

黑暗
(默认为Android)

应用预定义的主题

主题类存储提供的主题名称。要更改主题,分配主题类的相应字段的ThemeManager.ThemeName

 

 
 

C#

  

using Xamarin.Forms;

using DevExpress.Mobile.DataGrid.Theme;

 
 

// ...  

 
 

ThemeManager.ThemeName = Themes.Dark;

 
 

// ...  

 
 

自定义主题

要自定义应用的主题,使用ThemeBase类。它为您提供各种定制,使您可以更改主题的外观,并将其应用到电网。您可以使用这些定制来改变背景颜色,字体和所需的网格单元(头,属性组行等)

重要

要应用定制,调用ThemeManager.RefreshTheme方法。

ThemeBase类的属性提供访问不同的定制,你可以调整来改变外观设置(例如,字体属性,边框和背景颜色等)网格的相应的视觉元素(如数据单元格,行分组过滤器面板等)。在本实施例中,使用下面的定制。

 
 

为了跟踪时刻变化的主题,无论是处理ThemeManager.ThemeChanged事件或使用IThemeChangingHandler.OnThemeChanged方法。

这个例子定制光主题,因为它是在下面的图片中显示。

 
 

 

 
 

C#:MainPage.xaml.cs

  

using System;

using System.Collections.Generic;

using Xamarin.Forms;

using DevExpress.Mobile.DataGrid;

using DevExpress.Mobile.DataGrid.Theme;

 
 

namespace ThemeCustomizing {

 
 

public
partial
class MainPage : ContentPage {

 
 

int count = 0;

public MainPage() {

 
 

InitializeComponent();

 
 

 
 

TestOrdersRepository model = new TestOrdersRepository();

BindingContext = model;

 
 

ThemeManager.ThemeName = Themes.Light;

 
 

// Header customization.

ThemeManager.Theme.HeaderCustomizer.BackgroundColor = Color.FromRgb(187, 228, 208);

ThemeFontAttributes myFont = new ThemeFontAttributes("Verdana",

ThemeFontAttributes.FontSizeFromNamedSize(NamedSize.Large),

FontAttributes.None, Color.White);

ThemeManager.Theme.HeaderCustomizer.Font = myFont;

 
 

 
 

// Cell customization.

ThemeManager.Theme.CellCustomizer.SelectionColor = Color.FromRgb(186, 220, 225);

ThemeFontAttributes myFont1 = new ThemeFontAttributes("Verdana",

ThemeFontAttributes.FontSizeFromNamedSize(NamedSize.Medium),

FontAttributes.None, Color.Black);

ThemeManager.Theme.CellCustomizer.Font = myFont1;

 
 

 
 

// Various customization.

ThemeManager.Theme.TotalSumaryCustomizer.BackgroundColor = Color.FromRgb(163, 162, 168);

ThemeFontAttributes myFont2 = new ThemeFontAttributes("Verdana",

ThemeFontAttributes.FontSizeFromNamedSize(NamedSize.Default),

FontAttributes.None, Color.Black);

ThemeManager.Theme.TotalSummaryCustomizer.Font = myFont2;

ThemeManager.Theme.NewItemRowCustomizer.Font = myFont2;

 
 

 
 

ThemeManager.RefreshTheme();

}

 
 

void OnCalculateCustomSummary(object sender, CustomSummaryEventArgs e) {

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

if (e.IsTotalSummary) {

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

if (!(bool)e.FieldValue)

count++;

e.TotalValue = count;

}

}

}

 
 

}

 
 

}

自定义模板列、滑动显示按钮

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

AllowResizeColumns="True"

AllowHorizontalScrollingVirtualization="True"

ColumnsAutoWidth="False"

SwipeButtonShowing="OnSwipeButtonShowing"


SwipeButtonClick="OnSwipeButtonClick"

>

<dxGrid:GridControl.Columns>

<dxGrid:TemplateColumn
FieldName="Name"
Caption ="112"
Width ="60"
IsReadOnly="true"
AllowGroup="False"
AllowSort="False" >

<dxGrid:TemplateColumn.DisplayTemplate>

<DataTemplate>

<Button
Text="{Binding Value}"

Clicked="nameClient"

BorderWidth="0"

                                    BackgroundColor="Green"

                                    TextColor="White"

></Button>

</DataTemplate>

</dxGrid:TemplateColumn.DisplayTemplate>

</dxGrid:TemplateColumn>

<dxGrid:TextColumn
FieldName="Name"
Caption = "名字"
Width = "100" />

<dxGrid:NumberColumn
FieldName="UnitPrice"
Caption = "价格"
DisplayFormat="C0"/>

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

<dxGrid:SwitchColumn
FieldName="Shipped" />

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

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

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

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

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

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

 

</dxGrid:GridControl.Columns>

<dxGrid:GridControl.LeftSwipeButtons>

<dxGrid:SwipeButtonInfo
ButtonName="LeftButton"
Caption="打印"
BackgroundColor="Green"
Width="150"/>

</dxGrid:GridControl.LeftSwipeButtons>

</dxGrid:GridControl>

特殊说明:如果直接使用绑定的文本则使用 Value关键字,绑定对象则可以直接使用Value.XXX

后端.cs代码绑定事件

void OnSwipeButtonShowing(object sender, DevExpress.Mobile.DataGrid.SwipeButtonShowingEventArgs e)

{

if ((!(Boolean)grid.GetCellValue(e.RowHandle, "Shipped"))

&& (e.ButtonInfo.ButtonName == "RightButton"))

{

e.IsVisible = false;

}

}

 

void OnSwipeButtonClick(object sender, DevExpress.Mobile.DataGrid.SwipeButtonEventArgs e)

{

if (e.ButtonInfo.ButtonName == "LeftButton")

{

string orderDate = (string)grid.GetCellValue(e.RowHandle, " Name");

string orderDateDay = orderDate;

DisplayAlert("Alert from " + e.ButtonInfo.ButtonName, "Day: " + orderDateDay, "OK");

}

if (e.ButtonInfo.ButtonName == "RightButton")

{

grid.DeleteRow(e.RowHandle);

}

}

Xamarin devexpress datagrid 样式的更多相关文章

  1. WPF DataGrid 样式设置

    隔行换色,鼠标单击,悬浮样式都有,其具体效果如图 1 所示. 图 1 WPF DataGrid 样式设置效果图 其中: 界面设计代码下所示 ? + 查看代码 1 2 3 4 5 6 7 8 9 10 ...

  2. DevExpress皮肤样式

    [时间] 2016-02-15 11:41:11 天气晴 没有雾霾难得的好天气!!! [工具] (1)Visual Studio 2015 (2)DevExpress15.2.3 [感言] 一直以来都 ...

  3. WPF DataGrid 样式分享

    原文:WPF DataGrid 样式分享 隔行换色,鼠标单击,悬浮样式都有 先看效果: 代码: <DataGrid AutoGenerateColumns="False" N ...

  4. Xamarin devexpress Grid

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

  5. Xamarin.Forms DataGrid

    控件出处 https://components.xamarin.com/ https://components.xamarin.com/gettingstarted/ZumeroDataGrid/tr ...

  6. WPF随手小记之二 ——改变DataGrid样式

    大部分时候我们并不需要手动改变DataGrid的样式,因为用默认的其实也看得过去,而且在DataGrid中的数据也远比外观重要. 但总有时候,我们需要做点必要的UI修改来使DataGrid更美观. 一 ...

  7. Xamarin.Forms之样式

    使用XAML样式设置Xamarin.Forms应用的样式Xamarin.Forms应用程序的样式传统上是通过使用Style类将一组属性值分组到一个对象中来完成的,然后可以将其应用于多个视觉元素实例. ...

  8. wpf 收集的不错的datagrid样式

    <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" x ...

  9. DataGrid样式

    1.自定义列(DataGridTemplateColumn) <DataGridTemplateColumn Width="130"> <DataGridTemp ...

随机推荐

  1. JavaScript新手学习笔记1——数组

    今天,我复习了一下JavaScript的数组相关的知识,总结一下数组的API: 总共有11个API:按照学习的先后顺序来吧,分别是: ① toString()  语法:arr.toString(); ...

  2. java.net.MulticastSocket Example--reference

    In this example we are going to explain how to use MulticastSocket in Java, in order to enable a ser ...

  3. SQL 使用Cursor(游标)遍历结果集

    使用Cursor(游标)可以在存储过程中遍历select 结果集,对其进行相关的操作. Cursor(游标)语法格式 DECLARE 游标名称 CURSOR FOR SELECT 字段1,字段2,字段 ...

  4. 在公网(internet)上建立website时不能用http访问

    我们在internet的IDC提供的虚拟机上建了新的web site, 域名也从阿里巴巴那里得到二级域名,也经过映射到了虚机的IP, 在本机都可以用域名以Http方式访问,但在internet上的其它 ...

  5. python 下的数据结构与算法---8:哈希一下【dict与set的实现】

    少年,不知道你好记不记得第三篇文章讲python内建数据结构的方法及其时间复杂度时里面关于dict与set的时间复杂度[为何访问元素为O(1)]原理我说后面讲吗?其实就是这篇文章讲啦. 目录: 一:H ...

  6. 执行CMD命令

    可以执行多条命令,用“\r\n”分割 using System; using System.Diagnostics; namespace Tool { public class CMDHelper { ...

  7. 连接、关联、JOIN、APPLY(SQL Server)

    连接方式 连接类型 个人总结 阐述(生成两个集合的约束笛卡儿积) INNER    JOIN 内连接 关联相同的(用于查找关联的信息) FROM C AS c INNER JOIN D AS d ON ...

  8. Oracle 增加修改删除字段

    Oracle 增加修改删除字段 添加字段的语法:alter table tablename add (column datatype [default value][null/not null],…. ...

  9. mysql存储过程controller的not found造成混乱的解决办法

    打草稿 问题:对于select  var1 into var2 ,单select的结果为空的时候(空的意思是没有找到数据,不是该值为null) ,会触发controller的not found 当游标 ...

  10. pod install后出现: [!] `<PBXResourcesBuildPhase UUID=`xxxx`>` attempted to initialize an object with an unknown UUID

    [!] `<PBXResourcesBuildPhase UUID=`xxx`>` attempted to initialize an object with an unknown UU ...