最初にヘッダーを追加してから、そのヘッダーの下に名前を付け、次にヘッダーと名前のセットを追加する必要があります。ここに示すのは、完全なテストアプリです。 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.
はここで、そのサンプルアプリのリストビューの中央部分のスクリーンショットです:
があなたの提案を –