Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2009.06.14;
Скачать: CL | DM;

Вниз

Скопировать Chart из Excel в Image   Найти похожие ветки 

 
yaric   (2008-05-21 09:47) [0]

Необходимо забрать с листа график и отобразить на канве компонента TImage

Пробую так возникает ошибка. Плиз подскажите что неправильно..


var i:Integer;
   ch,sh : OleVariant;
begin
 lcid:=0;
 lcid := GetUserDefaultLCId;
 fXL := TExcelApplication.Create(nil);
 try
   fXL.ConnectKind := ckNewInstance;
   fXl.Application.AutomationSecurity := 1;
   fXL.DisplayAlerts[lcid] := False;
   fXL.AutoQuit := False;
   fXL.Visible[lcid] := false;
   fXL.Connect;
   fxl.Workbooks.Add("c:\1.xls", lcid);

   ch:=(iDispatch(sh) as _Worksheet).ChartObjects("Chart. 1",lcid);  //ошИБКА
   (iDispatch(ch) as ChartObject).CopyPicture(xlscreen,xlbitmap);

   if Clipboard.HasFormat(CF_BITMAP)
   then Image1.Picture.Bitmap.Handle:=Clipboard.GetAsHandle(CF_bitmap);

 except
   ShowMessage("Невозможно соединиться с MS Excel");
 end;


 
Palladin ©   (2008-05-21 12:24) [1]

эта ошибка, гласящая что она ошибка, наиболее распространенная ошибка в мире и решается очень легко

(С)


 
Style ©   (2008-05-21 12:45) [2]

А кто 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;



Страницы: 1 вся ветка

Текущий архив: 2009.06.14;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.012 c
15-1239121494
theAddon
2009-04-07 20:24
2009.06.14
Помогите написать небольшую программку


15-1239067996
MBo
2009-04-07 05:33
2009.06.14
Высокая концентрация программерской мысли на квадратный метр ;)


4-1211208395
R1ka
2008-05-19 18:46
2009.06.14
WinApi, WM_PAINT


15-1239292132
CoderM
2009-04-09 19:48
2009.06.14
Реализация Captcha


2-1240665137
Bohon_sky
2009-04-25 17:12
2009.06.14
команда в Делфи 7 , которая бы запускала некоторый exe-файл.