Ehlib表格区填满表格线的解决方案
来源:互联网 发布:java gui 对话框 编辑:程序博客网 时间:2024/06/08 15:04
表格区填满表格线的问题,公布如下:
3。6版本中修改DBGridEh.pas单元的UpdateRowCount过程:
procedure TCustomDBGridEh.UpdateRowCount;
var BetweenRowHeight, t: Integer;
OldRowCount, OccupiedHeight, VisibleDataRowCount, NewRowCount: Integer;
。。。。。。。。。。。。。。
begin
...............................
with FDataLink do
if not Active or (RecordCount = 0) or not HandleAllocated then
begin
.................
end else
begin
VisibleDataRowCount := (ClientHeight - OccupiedHeight {- LineHeight}) div DefaultLineRowHeight;
if VisibleDataRowCount <= 0 then VisibleDataRowCount := 1;
FDataLink.BufferCount := VisibleDataRowCount;
if FFooterRowCount = 0 then //增加的一个条件,用户可以用FooterRowCount值来决定是否填满表格线
VisibleDataRowCount := FDataLink.RecordCount;
Inc(OccupiedHeight, DefaultLineRowHeight * VisibleDataRowCount);
NewRowCount := VisibleDataRowCount + TopDataOffset;
if FooterRowCount > 0 then
begin
NewRowCount := NewRowCount + FooterRowCount + 1;
SetRowCount(NewRowCount);
BetweenRowHeight := ClientHeight - OccupiedHeight {- LineHeight};
if BetweenRowHeight < 0 then BetweenRowHeight := 0;
//RowHeights[TopDataOffset + VisibleDataRowCount] := BetweenRowHeight;//原代码行
RowHeights[TopDataOffset + VisibleDataRowCount] := 0;//修改后的代码行
//把多余的不足一行的高度加在最后一行,增加下面一行代码
RowHeights[FTitleOffset + VisibleDataRowCount] := DefaultRowHeight+BetweenRowHeight;
end else
SetRowCount(NewRowCount);
UpdateActive;
end;
if OldRowCount <> RowCount then Invalidate;
end;
4.14版本中也是修改DBGridEh.pas单元的UpdateRowCount过程:
procedure TCustomDBGridEh.UpdateRowCount;
var
BetweenRowHeight,{恢复被注释掉的变量BetweenRowHeight} t: Integer;
OldRowCount, OccupiedHeight, VisibleDataRowCount, NewRowCount: Integer;
。。。。。。。。。。。。。
begin
...........................
with FDataLink do
if not Active or (RecordCount = 0) or not HandleAllocated then
begin
//MoveColRow(Col, TitleOffset, False, False);
SetRowCount(1 + TopDataOffset);
ContraRowCount := FooterRowCount;
//恢复原代码中被注释掉的语句行
(*========================================================================*)
SetRowCount(1 + TopDataOffset);
Inc(OccupiedHeight, DefaultLineRowHeight);
if HandleAllocated then
begin
if (FooterRowCount > 0) then
begin
SetRowCount(RowCount + FooterRowCount + 1);
BetweenRowHeight := ClientHeight - OccupiedHeight {- LineHeight};
if BetweenRowHeight < 0 then BetweenRowHeight := 0;
RowHeights[TopDataOffset + 1] := BetweenRowHeight;
end;
end;
(*========================================================================*)
end else
begin
VisibleDataRowCount := (ClientHeight - OccupiedHeight {- LineHeight}) div DefaultLineRowHeight;
if VisibleDataRowCount <= 0 then VisibleDataRowCount := 1;
FDataLink.BufferCount := VisibleDataRowCount;
if FFooterRowCount = 0 then //增加的一个条件,用户可以用FooterRowCount值来决定是否填满表格线
VisibleDataRowCount := FDataLink.RecordCount;
Inc(OccupiedHeight, DefaultLineRowHeight * VisibleDataRowCount);
NewRowCount := VisibleDataRowCount + TopDataOffset;
if FooterRowCount > 0 then
begin
SetRowCount(NewRowCount);
ContraRowCount := FooterRowCount;
//恢复原代码中注释掉的部分
(*========================================================================*)
NewRowCount := NewRowCount + FooterRowCount + 1;
SetRowCount(NewRowCount);
BetweenRowHeight := ClientHeight - OccupiedHeight {- LineHeight};
if BetweenRowHeight < 0 then BetweenRowHeight := 0;
//RowHeights[TopDataOffset + VisibleDataRowCount] := BetweenRowHeight;//这一行仍然不要,改成下面的代码
(*========================================================================*)
RowHeights[TopDataOffset + VisibleDataRowCount] := 0;//修改后的代码行
//把多余的不足一行的高度加在最后一行,增加下面一行代码
RowHeights[FTitleOffset + VisibleDataRowCount] := DefaultRowHeight+BetweenRowHeight;
end else
SetRowCount(NewRowCount);
UpdateActive;
end;
if OldRowCount <> RowCount then Invalidate;
end;
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib表格区填满表格线的解决方案
- Ehlib:修正表格的Lookup下拉框的焦點小BUG
- EhLib表格控件DBGridEh自动排序、自动过滤的实现
- 让图片填满Word表格里的单元格
- 给birt的表格添加表格线
- EasyJWeb+JPA(Hibernate3.2)+Spring2构架缓存技术
- 绘制恒线速度的参数曲线
- EasyJWeb的验证系统的Bug及使用心得
- 瀏覽器平台上的戰爭,Silverlight,Flash,Flex,JavaFX
- 不要把所有鸡蛋都放在一个篮子里——使用RoboCopy实现网络备份
- Ehlib表格区填满表格线的解决方案
- EasyJWeb中防重复提交使用及原理
- WPF UI介面的革新
- 出差见闻(一)--温州的出租车:起步价15元
- 企业如何辨别ERP是否稳定
- Active Directory和Exchange灾难恢复参考文档
- 人性化的验证(Validate)系统
- CA Unicenter网络管理软件简介
- 核心流程决定ERP项目的信息化选型