Delphi中OnDrawCell的使用技巧[1]

Delphi中OnDrawCell的使用技巧[1],第1张

人们在利用Delphi开发数据库应用程序时 经常使用表格控件制作报表 灵活地使用表格控件的OnDrawCell事件 可以完成一些特殊效果的显示 能更好地满足用户需求 本文介绍灵活使用OnDrawCell事件的三个技巧

动态更新表格行的颜色

有时需要在报表中动态更新表格行的颜色 例如 在供应商列表中 优先供货的供应商用绿色显示 其他的供应商用红色显示 此时可以在OnDrawCell事件中用如下代码实现

if Table FieldByName( CustNo ) AsInteger > then

DBGrid Canvas Font Color := clRed;

DBGrid DefaultDrawColumnCell(Rect DataCol

Column State)

上述的代码可以根据应用的需要进行扩充 例如需要用黑体显示时 只要将对应行改为

DBGrid Canvas Font Style := [fsBold];

在表格中插入其他可视控件

在数据库编程中 外键约束是保证数据库中的数据按用户要求存放的有效方法 例如 在一个订单处理环境中 订单表和客户表之间就存在外键约束 即订单表中的每条记录在客户表中应该有对应项 这样 在填写订单表时 如果在输入焦点提供客户列表供用户选择 将有效地保证数据的正确性

DBGrid控件和StringGrid控件都派生于TcustomGrid 其中DBGrid控件可以输入数据 Delphi对DBGrid处理的内部机制是在网格上浮动一个DBEdit控件 能够获得焦点 输入数据的网格其实是浮动的DBEdit控件 当焦点转移时把编辑框中的文字显示到表格 其他未获得焦点地方和StingGrid并没有区别 这样就达到了在表格上输入数据的目的 所以 在表格中插入其他可视控件的方法就是在网格上浮动该可视控件 因此从原理上讲 任何控件都可以在表格中插入 本文以在表格中插入下拉框为例 介绍在网格上插入其他控件的具体步骤

.设置属性

读入客户列表到下拉框的Items属性

.设置OnDrawCell事件

OnDrawCell事件在绘制表格的单元格时被触发 当获得焦点的单元格所对应的字段与下拉框所对应的字段一致时 移动下拉框到获得焦点的网格上 并且使下拉框可见 从而达到在表格指定列上显示下拉框的功能 设置表格的OnDrawCell事件如下

if (gdFocused in State) then

begin

//对应字段一致则执行

if (Grid Cells[ACol ]= Company ) then

begin

//移动下拉框到指定位置

ComboBox Left := Rect Left + Grid Left;

ComboBox Top := Rect Top + Grid top;

ComboBox Width :=Rect Right-Rect Left;

ComboBox Height:=Rect Bottom-Rect Top;

// 使下拉框可见并获得焦点

ComboBox Visible := True;

ComboBox SetFocus;

end;

end;

lishixinzhi/Article/program/Delphi/201311/24771

其他语言

用于开发数据库应用程序的语言中 还可以使用目前数常见的 面向对象程序设计 (OOP)语言 如C++ Objact Pascal等 OOP代表了一种完全不同的程序设计方法 在这种程序设计方法中 活动被定义为在 对象 上发生的 *** 作 而不是作为一系列过程来定义的 在数据库应用程序中使用OOP语言的情况正在不断增加

开发数据库应用程序使用的另一种语言是 宏 语言 宏语言不是一种完全的程序设计语言 它实际上是一个用户手工输入的表 这个表被输入到应用程序中 以便自动执行一定的任务 对于某个特定应用的高级语言 宏语言通常可以在低档DBMS软件中或数据库服务器的前端中找到

最后 还有一种 Query By Example (QBE 范例查询)语言 严格地讲QBE不是一种语言 它是面向用户提供了一个或多个空表的界面 这些空表对应于数据库中的表 用户可以通过键盘选择需要查询的列 并在适当的列中填入条件从而定义查询的检索条件 然后DBMS就把QBE转换成相应的动作 以完成用户要求的查询任务

Delphi的数据库特性及功能简介

直到目前为止 计算机软件的开发分为两个不同的体系 其中一个体系是使用传统的程序设计语言(如Pascal Basic和C等)开发数值控制 数值运算等软件 围绕它们的重点是算术 数据结构以及近年产生的面向对象技术 另一个体系则是通用的数据库管理软件领域(数据库应用程序的开发) 这两个体系的发展都极为迅猛 但是二者并没出现混合渗透迹象 如果使用数据库语言进行传统的算术编程 虽然也能完成相应的功能 但是其编程过程可能极为复杂 如果使用传统的编程语言进行数据库编程 通过调用专用的数据库应用程序接口函数和过程 利用这些函数和过程提供的功能 可能也能做得比较完善 但这做起来大多是极其困难的 而Delphi结合了两个体系的优点 它结合了传统的编程语言Object Pascal和数据库语言的强大功能 它即可以用于传统的算术编程又可以用于数据库编程 特别是Delphi具有强大的数据库功能 利用Delphi的数据库工具 我们根本不需要编写任何Object Pascal代码便可以创建一个简单的数据库应用

Delphi是Borland公司于 年底发布的用于开发数据库应用程序的工具 它是面向对象的 它是目前开发客户/服务器数据库应用程序的强有力的工具 Delphi在Window 以上版本的系统环境下运行 目前具有两个版本 Delphi的标准版本和客户/服务器版本 标准版本包含一个Borland Database Engine的局部拷贝 它允许用户创建能访问dBASE Paradox和Local InterBase 服务器的数据库应用 它还支持具有 ODBC 接口的数据库 Delphi的客户/服务器版本包括Borland SQL Link 它能直接访问 ORACLE SyBase 和Microsoft SQL Server Informix以及InterBase数据库服务器

Delphi可以访问多种数据库管理系统的数据库 凭借窗体(Forms)和报表(Reports) BDE(Borland Database Engine)可以访问诸如Paradox dBASE 本地InterBase 服务器的数据库 也可以访问远程数据库服务器上的数据库(如ORACLE SyBase Informix等客户/服务器数据库中的数据库) 或任何经ODBC(Open Database Connecticity) 可访问的数据库管理系统中的数据库

Delphi的数据库特性

跟其他的应用程序一样 Delphi提供了许多部件以方便地创建数据库应用程序 数据库对象的数据成员既可在设计阶段设置 也可在运行阶段通过程序代码进行设置 Delphi的部件板上提供了两页数据库应用程序开发中所要使用的部件

数据访问页(Data Access Page)上的部件用于直接访问数据库中的数据库表

数据控制页(Data Control Page)上的部件用来与用户交互 显示 修改数据库中的数据

数据库应用程序首先是利用Delphi提供的数据库部件与BDE建立联系 然后再通过BDE与数据库联系 下图阐述了Delphi的数据库工具和部件 Delphi数据库应用程序与BDE 数据源之间的关系

下表概括了Delphi的数据库特性

表 Delphi的数据库特性

━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

工具和部件   主 要 用 途

──────────────────────────────────────

Data Access Components  访问数据库 数据库表 存贮过程等

──────────────────────────────────────

Data Control Components  与用户交互 提供显示 修改数据库中数据的界面

──────────────────────────────────────

Database Desktop(DBD)  建立 索引 查询数据库表以及访问 编辑来自各数据中的数据

──────────────────────────────────────

ReportSmith  建立 浏览和打印数据库表中的数据

──────────────────────────────────────

Borland Database Engine  数据库应用通过BDE访问dBASE Paradox数据库中的数据(BDE)  和本地InterBase数据库服务器中的数据

──────────────────────────────────────

BDE Configuration  建立和管理BDE与数据库建立连接时所使用的数据库的

Utility  别名

──────────────────────────────────────

Local InterBase Server  它是一个单用户 多例程的本地SQL数据库服务器 可在单机环境下用来开发或测试客户/服务器数据库应用程序 然后再将之扩展成一个访问远程数据库服务器如ORACLE SyBase Informix等

──────────────────────────────────────

InterBase SQL Link  连接Delphi数据库应用程序一本地InterBase服务器的驱动程序

Delphi上述这些特性使得我们创建数据库应用程序通过BDE能够很灵活地与 dBASE Paradox Local InterBase数据库服务器进行连接并可以方便地访问其中的数据 我们在创建一个简单的数据库应用时通过使用Delphi提供的上述工具和部件甚至可以不需编写任何程序

BDE被自动地包含在Delphi中 因此 我们在创建数据库应用程序时 不必关心BDE的有关内容 Delphi的安装程序自动为Paradox dBASE和本地InterBaseServer 安装相应的驱动程序 并建立了有关的配置 DBE Configuration Utility 可以建立应用程序与数据库的连接信息 还可以为数据库设置别名

下表列出了Delphi开发Client/Server应用程序的有关特性 这些特性扩展了 Delphi访问远程数据库的功能 如SQL数据库服务器(ORACLE SyBase Informix Microsoft SQL Server InterBase)

表 Delphi Client/server数据库特性

━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

工 具   主 要 用 途

─────────────────────────────────

SQL Drivers  SQL Drivers中的SQL link和ReportSmith为Delphi数据库应用程序提供了访问远程SQL服务器的驱动程序 如访问ORACLE SyBase Microsoft SQL server Informix Intermix

 ─────────────────────────────────

lishixinzhi/Article/program/Delphi/201311/25183

以上就是关于Delphi中OnDrawCell的使用技巧[1]全部的内容,包括:Delphi中OnDrawCell的使用技巧[1]、DELPHI基础教程:Delphi开发数据库应用程序概述(一)[2]、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/10122492.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存