动态创建菜单问题(50分)

  • 主题发起人 主题发起人 holyszq
  • 开始时间 开始时间
H

holyszq

Unregistered / Unconfirmed
GUEST, unregistred user!
我用Add(NewItem(Caption ,0,false,true,OnClick,0,Menu_Name));
来动态添加菜单,那如何为该级的ImageIndex赋值呢?谢谢!!!
 
var
mTemp:TMenuItem;
begin
//.............
//生成菜单
mTemp:=TMenuItem.Create(pmField);
with mtemp do
begin
Caption := rsTemp.Fields.FieldName;
Hint := rsTemp.Fields.FieldName;
AutoCheck := true;
Checked := true;
OnClick := pmfieldClick; //菜单的单击事件过程
ImageIndex:= 1; //这里
end;
pmfield.Items.Add(mTemp); //把菜单项增加到弹出菜单中
end;
 
我想你可以这样
with N1 do
begin
Add(NewItem(Caption ,0,false,true,OnClick,0,Menu_Name));
Items[Count-1].ImageIndex:=AInteger;
end
 
function SetBlackFont(Item: TFont): Boolean;
var
AF: TFont;
begin
Try
AF := TFont.Create;
AF.Name := '宋体';
AF.Color := clBlack;
AF.Size := 9;
AF.Style := ([fsBold]);
Item.Assign(AF);
AF.Free;
Result := True;
Except
on Exception Do
Result := False;
end;

end;
function CreateActionList(mainActions: TActionList;
Out CategoryList: TStrings): Boolean;
var
i: Integer;
CDS: TClientDataSet;
begin
Try
CDS := TClientDataSet.Create(Nil);
with CDS do
begin
with FieldDefs do
begin
with AddFieldDef do begin

Name := 'tag';
DataType := ftInteger;
Required := True;
end;
with AddFieldDef do begin
Name := 'name';
DataType := ftString;
Size := 50;
end;
end;
CreateDataSet;
end;

with MainActions do
if ActionCount > 0 then
for i := 0 to ActionCount -1 Do
if (Not CDS.Locate('name',Actions.Category,[loCaseInsensitive])) and
TAction(Actions).Enabled then
begin
CDS.Append;
CDS.FieldByName('tag').Value := Actions.Tag;
CDS.FieldByName('name').Value := Actions.Category;
CDS.Post;
end;
with CDS Do
begin
IndexDefs.Add('tag_index','tag',[ixPrimary]);
IndexFieldNames := 'tag';
First;
While not EOF Do
begin
CategoryList.Append(FieldByName('Name').Value);
Next;
end;
Free;
end;
Result := True;
except
On Exception Do
Result := False;
end;
end;
//************************
function CreateActionItem(Menu: TMainMenu; n: integer; Group: TfcOutLookPage;
mainActions: TActionList; Imgs: TImageList) : Boolean;
var
i: Integer;
actItem: TfcOutLookListItem;
//Menu-----------
Menuitem: TMenuItem;
//Menu-----------
begin
Menu.Images := Imgs ;
try
For i := 0 To MainActions.ActionCount - 1 Do
if (MainActions.Actions.Category = Group.Button.Caption) and
TAction(MainActions.Actions).Enabled then
begin
actItem := Group.OutlookList.Items.add;
with actItem Do
begin
OutlookList.Images := Imgs;
OutlookList.Transparent := True;
Action := MainActions.Actions;
ImageIndex := TAction(MainActions.Actions).ImageIndex;
end;
//Menu------
Menuitem:=TmenuItem.Create(Menu);
Menuitem.Caption :=actitem.DisplayName;
Menuitem.Action := MainActions.Actions;
Menuitem.ImageIndex := TAction(MainActions.Actions).ImageIndex;
Menu.items[n].Add (Menuitem) ;
//Menu-----
end;
Result := True;
Except
On Exception Do
Result := False;
end;
end;
procedure CreateOutBar(Menu: TMainMenu;BAR: TfcOutLookBar;MActions: TActionList;
MImgs: TImageList);
var
NameList: TStrings;
i,n: Integer;
btnItem: TfcOutLookPage;
//Menu------------
Menuitem: TMenuItem;
//Menu-------------
begin
try
NameList := TStringList.Create;
//收集ActionList中的分组名称
if not CreateActionList(MActions,Namelist) Then Exit;
//在OutBar中添加分组
for i := 0 to NameList.Count - 1 Do
begin
btnItem := BAR.OutlookItems.Add;
btnItem.Button.Caption := NameList.Strings;
if Not SetBlackFont(btnItem.OutLookList.Font) then exit;
//Menu-------
Menuitem := TMenuItem.Create(Menu);
try
Menuitem.Caption := NameList.Strings+' ';
Menu.Items.insert(i, Menuitem);
n:=i;
except
Menuitem.Free;
raise; { reraise the exception }
end;
//Menu--------
//添加功能组项
if Not CreateActionItem(Menu , n, btnItem, MActions,MImgs) then Exit;
end;
Finally
NameList.Free;
Menuitem.Free;
end;
end;
//***************************************
 
参考:

http://www.delphibbs.com/delphibbs/dispq.asp?lid=1506002
 

Similar threads

D
回复
0
查看
2K
DelphiTeacher的专栏
D
D
回复
0
查看
1K
DelphiTeacher的专栏
D
D
回复
0
查看
1K
DelphiTeacher的专栏
D
I
回复
0
查看
339
import
I
后退
顶部