Spread for Windows Forms快速入门(7)---单元格的交互操作

简介:

单元格的编辑模式

通常情况下,当终端用户双击单元格时,编辑控件将允许用户在该单元格中输入内容。在一个单元格中编辑的能力被称为编辑模式。一些属性和方法可以用来自定义编辑模式的使用。

当一个单元格处于编辑模式时,活动单元格将显示一个I型光标,如下图所示。当该单元格不处于编辑模式时,活动单元格将显示一个焦点长方形,如下图所示。

clip_image002

clip_image004

处于编辑模式下的单元格

被选中但是并不处于编辑模式下的单元格

一个单元格将进入编辑模式(开启编辑模式),当:

用户在单元格中输入内容

用户双击单元格

EditMode属性设置为true

一个单元格离开编辑模式(关闭编辑模式),当

用户按下回车键

用户激活了另外一个单元格

应用程序丢失焦点

EditMode属性设置为false

当一个单元格进入编辑模式,默认情况下,光标位于单元格中文本的末端。你可以设置EditModeReplace属性, 将光标改变为选择单元格中存在的文本。

如果你愿意,你可以使用EditModePermanent属性指定一个单元格, 当该单元格变为活动单元格时一直处于编辑模式。

你可以使用StartCellEditing 和 StopCellEditing方法启动和结束编辑模式。

锁定单元格

你可以锁定一个单元格或者一个区域内的单元格,并使之不能被终端用户编辑。 你也可以将锁定单元格的外观设置为其他样式,以便于用户分辨。

你可以使用单元格对象,列对象,行对象,或者交替行对象中的Locked 属性锁定单元格。你还可以为StyleInfo对象设置Locked属性,并将该风格应用到你希望锁定的单元格上。你还需要设置SheetView对象的 Protect属性锁定单元格。 Locked属性将锁定的单元格标识出来,设置Protect属性可以确定是否锁定这些单元格。对于标记为锁定的单元格,要锁定用户的输入,表单的 Protect属性必须设置为True(默认情况下为True),否则用户依然可以与单元格进行交互。

另外一种锁定单元格的方法是将单元格类型设置为文本单元格(使用TextCellType)并且将属性设置为只读(ReadOnly)。 这样,单元格就不可以编辑了。

确定表单的Protect属性被设置为True后,你可以锁定一些列的单元格并在某一行中解锁这些单元格。 示例代码如下:

fpSpread1.ActiveSheet.Protect = true;

fpSpread1.ActiveSheet.LockBackColor = Color.LightCyan;

fpSpread1.ActiveSheet.LockForeColor = Color.Green;

fpSpread1.ActiveSheet.Columns[0, 3].Locked = true;

fpSpread1.ActiveSheet.Cells[1,1,1,2].Locked = false;

单元格的合并

你可以将若干个单元格合并起来,创建一个合并区域,如下图所示。合并单元格用于创建一个大型的单元格,位于以前几个分列的单元格之上。举例来说,如果你创建了从B2到D3的单元格的合并区域,大型的单元格就占据了单元格B2至D3的空间。

clip_image006

控件分为四个部分:表角,列标题,行标题,以及数据区域。你可以在某一部分创建若干个合并区域,但是你不能创建横跨好几部分的区域。 举例来说,你不能将数据区域的单元格与行标题的单元格合并,并且你不能将列标题的单元格与表角的单元格合并。这里主要介绍在数据区域如何合并单元格。

当你创建单元格的合并区域时。合并区域的第一个单元格的数据(通常被称为锚点单元格)占据了合并区域的所有空白区。当你创建一个合并区域时,原来在各个单元格的数据依旧在合并区域的各个单元格中,但是不会显示出来。 合并区域仅仅是将数据隐藏了。 如果你将这一组单元格的合并区域移除,合并区域单元格的内容,先前被隐藏的内容,就会正常显示。通过调用AddSpanCell 方法,你可以创建一个单元格的合并区域。合并区域内的单元格种类不会发生改变。合并的单元格采用合并区域中最左边的单元格类型。

调用GetCellSpan方法返回一个单元格是否在合并区域中的判定值。并且如果此单元格在合并区域中,该方法就会返回CellRange对象,该对象包含锚点单元格的行数和列数, 以及合并区域中的行列数。

通过调用RemoveSpanCell方法你可以将合并区域从一组单元格区域中移除。你可以通过此方法移除单元格合并区域,指定合并区域的锚点单元格,以便移除合并区域。当你想要移除一个合并区域时,以前显示在各个单元格中的数据又重新显示在你的眼前。单元格的数据从未没移除,只是被合并区域隐藏而已。

下面的示例代码定义了一些内容然后合并了六个相连的单元格。

// Create some content in two cells.

fpSpread1.ActiveSheet.Cells[1,1].Text = "These six cells are spanned.";

fpSpread1.ActiveSheet.Cells[2,2].Text = "This is text in 2,2.";

// Span six cells including the ones with different content.

fpSpread1.ActiveSheet.AddSpanCell(1, 1, 2, 3);

使用拖拽操作填充单元格

在使用Spread进行应用程序开发时,你可以允许最终用户从一个或若干个单元格的区域内拖拽数据到另外一个单元格或者另外一组单元格内。对于选中的单元格或一组单元格 ,你也可以将其他的单元格填充到一行 (或者若干行如果超过一列被选中)或者一列(或者若干列如果超过一行被选中)。

这里显示的示例从原始选中的单元格中向一列中填充了几个单元格。

clip_image008

使用FillDirection枚举类型,你可以自定义填充的方向。

下面的示例代码对控件进行了设置以便允许拖拽填充特性。

fpSpread1.AllowDragFill = true;




本文转自 powertoolsteam 51CTO博客,原文链接:http://blog.51cto.com/powertoolsteam/634366,如需转载请自行联系原作者

相关文章
|
4月前
|
人工智能 机器人 C++
【C++/Python】Windows用Swig实现C++调用Python(史上最简单详细,80岁看了都会操作)
【C++/Python】Windows用Swig实现C++调用Python(史上最简单详细,80岁看了都会操作)
102 0
|
6天前
|
C# Windows 监控
WPF应用跨界成长秘籍:深度揭秘如何与Windows服务完美交互,扩展功能无界限!
【8月更文挑战第31天】WPF(Windows Presentation Foundation)是 .NET 框架下的图形界面技术,具有丰富的界面设计和灵活的客户端功能。在某些场景下,WPF 应用需与 Windows 服务交互以实现后台任务处理、系统监控等功能。本文探讨了两者交互的方法,并通过示例代码展示了如何扩展 WPF 应用的功能。首先介绍了 Windows 服务的基础知识,然后阐述了创建 Windows 服务、设计通信接口及 WPF 客户端调用服务的具体步骤。通过合理的交互设计,WPF 应用可获得更强的后台处理能力和系统级操作权限,提升应用的整体性能。
18 0
|
6天前
|
数据库 Windows
超详细步骤解析:从零开始,手把手教你使用 Visual Studio 打造你的第一个 Windows Forms 应用程序,菜鸟也能轻松上手的编程入门指南来了!
【8月更文挑战第31天】创建你的第一个Windows Forms (WinForms) 应用程序是一个激动人心的过程,尤其适合编程新手。本指南将带你逐步完成一个简单WinForms 应用的开发。首先,在Visual Studio 中创建一个“Windows Forms App (.NET)”项目,命名为“我的第一个WinForms 应用”。接着,在空白窗体中添加一个按钮和一个标签控件,并设置按钮文本为“点击我”。然后,为按钮添加点击事件处理程序`button1_Click`,实现点击按钮后更新标签文本为“你好,你刚刚点击了按钮!”。
21 0
|
2月前
|
Windows
【Windows】 Win10下报错:该文件没有与之关联的应用来执行该操作。请安装应用,若已经安装应用,请在“默认应用设置”页面中创建关联
【Windows】 Win10下报错:该文件没有与之关联的应用来执行该操作。请安装应用,若已经安装应用,请在“默认应用设置”页面中创建关联
354 1
|
2月前
|
Windows
【Windows】 Win10文件目录的删除,新建等需要手动刷新操作 亲测有效
【Windows】 Win10文件目录的删除,新建等需要手动刷新操作 亲测有效
132 0
|
3月前
|
缓存 Windows
Windows单屏操作快捷键知识分享
Alt+Tab 切换应用(切换界面) Win+数字键 切换任务栏的相对应用
38 5
|
3月前
|
存储 数据安全/隐私保护 Windows
逆向学习Windows篇:进程句柄操作详解
逆向学习Windows篇:进程句柄操作详解
69 0
|
3月前
|
Java 大数据 Scala
Scala快速入门--Scala环境搭建【Windows10】图解
Scala快速入门--Scala环境搭建【Windows10】图解
32 0
|
4月前
|
存储 人工智能 资源调度
【windows批处理batch】.bat文件 字符串处理相关操作(字符串定义、分割、拼接、替换、切片、查找)
【windows批处理batch】.bat文件 字符串处理相关操作(字符串定义、分割、拼接、替换、切片、查找)
|
4月前
|
Serverless API 数据安全/隐私保护
Serverless 应用引擎产品使用之阿里函数计算中在本地搭建Windows开发环境与阿里云函数计算进行交互如何解决
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
下一篇
DDNS