![]() |
|
|
|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
|
Опции темы | Поиск в этой теме | Опции просмотра |
|
#1
|
|||
|
|||
|
Всех приветствую. Только учусь работать с динамическими объектами, объясню суть вкратце: необходимо реализовать отрисовку на ScrollBox компонентов Panel,на которых будет помещён компонент WebBrowser. Создал процедуру,которая это делает,однако она зависит от количества,которое нужно создать. Если количество маленькое,например, 7 он может создать,но при закрытии приложения выводится ошибка: "Прекращена работа приложения" и ошибки. Но,например,с 20 работает и закрывается всё идеально.Прошу помощи доработать или указать на недостатки.
Код:
..
{ Private declarations }
public
//массив компонентов webbrowser
web: array of TWebBrowser;
//массив компонентов Panel
panel:array of Tpanel;
//общее количество,которое нужно создать
const allcount=14;
//количество объектов,которое поместится в строке в зависимости от размеров экрана
var count:integer;
//отступ сверху
toppos:integer;
//параметры объектов
const widthweb=200;
const heightweb=100;
const interval=30;
..
procedure TForm1.WebCreate();
var i,j,a,z,count:integer;
begin
showmessage(inttostr(allcount));
Form1.ScrollBox1.Width:=screen.Width;
Form1.ScrollBox1.Height:=screen.Height-Scrollbox1.Top;
Form1.toppos:=20;
showmessage(inttostr(Screen.Width));
//расчет штук в строке
count:=Floor(Screen.Width/(Form1.widthweb+Form1.interval));
showmessage(inttostr(count));
//расчёт сколько строк нужно нарисовать
a:=floor(allcount/count);
//задание размеров массивов
SetLength(Form1.web,Form1.allcount-1);
SetLength(Form1.panel,Form1.allcount-1);
for j := 0 to a do begin
for i :=j*count to ((j*count)+count-1) do
begin
Form1.panel[i]:=TPanel.Create(self);
Form1.panel[i].Parent:=Form1.scrollbox1;
Form1.web[i]:=TWebBrowser.Create(Form1.panel[i]);
TWinControl(Form1.web[i]).Parent := Form1.panel[i];
if i=j*count then begin
Form1.panel[i].Left:=74 ;
end
else begin
Form1.panel[i].Left:=Form1.panel[i-1].Left+Form1.widthweb+Form1.interval;
end;
Form1.panel[i].Top:=Form1.toppos;
Form1.web[i].Left:=0;
Form1.web[i].Top:=0;
//Form1.web[i].Navigate('google.com');
Form1.web[i].Silent:=true;
Form1.panel[i].Width:=Form1.widthweb;
Form1.web[i].Width:=Form1.widthweb;
Form1.panel[i].Height:=Form1.heightweb;
Form1.web[i].Height:=Form1.heightweb;
//уборка лишних компонентов
if i>Form1.allcount-1 then begin
Form1.web[i].Free;
Form1.panel[i].free;
end;
end;
Form1.toppos:=Form1.toppos+Form1.heightweb+Form1.interval;
end;
end; |
|
#2
|
||||
|
||||
|
Вы устанавливаете размер массива в точное значение, а создаете компоненты "до усеру" в цикле, а потом пытаетесь удалить лишние. А куда эти лишние создались?
Переделайте цикл так, чтоб лишние компоненты не создавались. Например, сделайте проверку на количество до создания и при необходимости прерывайте цикл командой break. |
|
#3
|
|||
|
|||
|
Я бы сказал по друому.
Там промашка с размерами массива и циклом создания точно есть. А вообще, ссылки на созданные компоненты кроме как для уничтожения таковых нужны? Может им просто Owner'а указать и пусть уничтожением занимается форма когда сама будет уничтожена? Это во первых. А во вторых, даже если ссылки нужны. Ты создаешь таблицу компонентов NxM, так почему бы и массив не объявить двухмерный и не заниматься ерундой? Ну и так, как вишенка на торте. В процедуре setLength указваается КОЛ-ВО элементов, а не индекс последнего. Индексация динамических массивов всегда начинается с 0. Т.е. если тебе надо создать массив из 20 элементов, то и в SetLength надо передавать 20, а индексы у них будут от 0 до 19. |