我有一个跨平台的应用程序,其中包含TFDMemtable(FireDAC)。
我的问题是,如何根据此表中的记录手动构建TListView?
我的表格按字母顺序包含男性姓名列表。
e.g。 Adam,Anthony,Alan,Brian,Bill,Bob,Ben,Charlie,Craig,Christopher,Colin等。
我希望listview包含名称的分组,所以A,B,C等。
到目前为止,我有以下内容:
procedure BuildNameList;
var Litem : TListViewItem;
c : Char;
begin
ListView1.BeginUpdate;
try
ListView1.ClearItems;
for c := 'A' to 'Z' do
begin
with ListView1.Items.Add do
begin
Text := char(c);
Purpose := TListItemPurpose.Header;
end;
with dmod.tableNames do
begin
First;
while not Eof do
begin
Litem := ListView1.Items.Add;
Litem.Text := dmod.tableNames.FieldByName('ForeName').AsString;
Next;
end;
end;
end;
finally
ListView1.EndUpdate;
end;
上面的代码没有给出我所追求的结果,会发生的是我在每个字母组(A-Z)下都复制了每个名字。
任何建议/帮助将不胜感激。 感谢
答案 0 :(得分:2)
您需要稍微更改逻辑以首先添加标题,然后添加该标题下的名称,然后添加下一个标题和一组名称。这是一个完整的测试应用程序,演示。您需要在表单上删除FMX TListView和TClientDataSet,并连接FormCreate事件以查看它是否有效。 (请注意,ClientDataSet上需要索引以确保名称的顺序正确;如果它们没有按字母顺序排列,则代码将无法工作,因为它无法根据需要找到数据以添加到部分。)
unit Unit3;
interface
uses
System.SysUtils, System.Types, System.UITypes, System.Classes, System.Variants,
FMX.Types, FMX.Controls, FMX.Forms, FMX.Graphics, FMX.Dialogs, FMX.ListView.Types, Data.DB,
Datasnap.DBClient, FMX.ListView;
type
TForm3 = class(TForm)
ListView1: TListView;
CDS: TClientDataSet;
procedure FormCreate(Sender: TObject);
private
{ Private declarations }
procedure BuildNameList;
public
{ Public declarations }
end;
var
Form3: TForm3;
implementation
{$R *.fmx}
procedure TForm3.BuildNameList;
var
Item: TListViewItem;
Ch: Char;
begin
ListView1.BeginUpdate;
CDS.First;
try
ListView1.ClearItems;
for Ch := 'A' to 'Z' do
begin
Item := ListView1.Items.Add;
Item.Text := Ch;
Item.Purpose := TListItemPurpose.Header;
while (CDS.FieldByName('SurName').AsString[1] = Ch) and (not CDS.Eof) do
begin
Item := ListView1.Items.Add;
Item.Text := CDS.FieldByName('SurName').AsString + ', ' +
CDS.FieldByName('ForeName').AsString;
CDS.Next;
end;
end;
finally
ListView1.EndUpdate;
end;
end;
procedure TForm3.FormCreate(Sender: TObject);
begin
// Create some test data
CDS.FieldDefs.Add('ForeName', ftString, 20);
CDS.FieldDefs.Add('SurName', ftString, 30);
CDS.CreateDataSet;
CDS.Open;
CDS.AppendRecord(['John', 'Smith']);
CDS.AppendRecord(['Jane', 'Doe']);
CDS.AppendRecord(['Ralph', 'Richards']);
CDS.AppendRecord(['Fred', 'Fredericks']);
CDS.AppendRecord(['Sam', 'Samuels']);
CDS.AppendRecord(['Walter', 'Williams']);
CDS.AppendRecord(['Ann', 'Anderson']);
CDS.AppendRecord(['Bob', 'Barnes']);
// Index it to put it in alphabetical order
CDS.IndexDefs.Add('Names', 'SurName;ForeName', []);
CDS.IndexName := 'Names';
BuildNameList;
end;
end.
以下是该示例应用的ListView中心部分的屏幕截图,因此您可以看到结果: