А кто Workbook, Worksheet объявлять будет???
sh - вообще это что???
ch:=(iDispatch(sh) as _Worksheet).ChartObjects('Chart. 1',lcid);
к тому же метод не правильно используется в описании ChartObjects(Index, lcid) . т.е. первый параметр Index, а не Name
короче вот так работает:
procedure TForm1.Button1Click(Sender: TObject);
var
fXL: TExcelApplication;
Sheet: _Worksheet;
Book: _Workbook;
Chart: ChartObject;
lcid: THandle;
begin
lcid := GetUserDefaultLCId;
fXL := TExcelApplication.Create(nil);
try
fXL.ConnectKind := ckNewInstance;
fXL.DisplayAlerts[lcid] := False;
fXL.AutoQuit := False;
fXL.Visible[lcid] := true;
fXL.Connect;
Book := fxl.Workbooks.Add('c:\1.xls', lcid);
Sheet := (Book.ActiveSheet as _Worksheet);
Chart := Sheet.ChartObjects(1,lcid) as ChartObject;
Chart.CopyPicture(xlscreen,xlbitmap);
if Clipboard.HasFormat(CF_BITMAP)
then Image1.Picture.Bitmap.Handle:=Clipboard.GetAsHandle(CF_bitmap);
except
ShowMessage('Превед медвед йа не икселъ');
end;
end;