PHP Delphi CSS HTML JavaScript Perl API ASP MySQL XML С++ VBasic WEB разработка *NIX CouchDB Hack Python
Главная Статьи Delphi Создание компонентов в Run-Time
Главная
 Главная  Контакты
 
Программинг
Статьи Книги ЧаВО
 
xBOOKi
Fresh Books Операционки Сети
 
Поиск
-------
 
Counters
Яндекс цитирования
Rambler's Top100
-------
 
CryptDisk.4h
Программа которая позволяет создать виртуальный шифрованный логический диск.

cryptdisk.4hack.com

-------
 
 

Создание компонентов в Run-Time.

Итак, рассмотрим на первый взгляд сложный вопрос о создании компонентов в Run_time (то есть во время работы программы). Но на самом деле этот вопрос довольно просто решается.

Давайте вместе попробуем написать код, чтобы при нажатии на кнопку на  форме появлялось текстовое поле с каким-нибудь текстом. Для этого надо проделать следующие действия: объявить переменную необходимого вам типа компонента, в нашем случае TEdit, затем необходимо описать процедуру Create для нашей переменной, задать обязательное свойство Parent (то есть где появится наш компонент), ну и установить необязательные параметры типа высоты, ширины и т.д. Лучше разбираться на конкретном примере, так что смотрите какой у меня получился код:

procedure TForm1.Button1Click(Sender: TObject);
var x:TEdit; // объявляем переменную типа TEdit
begin
x:=TEdit.create(self);// создаем экземпляр компонента
x.parent:=form1;// текстовое поле появится на форме 
x.left:=10;
x.top:=10;
x.Width:=250;
x.Text:='Привет компонент появился сам!!!';
end;

Как вы видите все очень просто. Поупражняйтесь с различными параметрами. 

Процессы создания визуальных и невизуальных компонентов несколько отличаются (последний попроще будет). Поскольку Edit мы уже создали (а это как раз визуальный компонент), теперь будем создавать невизуальный компонент, например FontDialog. Поставьте на форму еще кнопку. Обработчик события OnClick может выглядеть так:

procedure TForm1.Button2Click(Sender: TObject);
var y:TFontDialog; // объявляем переменную типа TFontDialog
begin
y:=TFontdialog.Create(self);
y.Execute; //только для демонстрации. Показать что работает.
end;

Вы свободно можете изменять любые свойства компонента, созданного во время работы приложения. 

Теперь мы попробуем вместе проделать такую вещь: мы отсортируем находящиеся в Memo данные. Для этого поставьте на форму Memo и напишите в ней 4 строки, например:

Memo4
Memo1
Memo3
Memo2

Поскольку само Memo сортировать данные не умеет, то нам придется во время работы программы создать какую-нибудь переменную абстрактного класса TStringList (этот класс сортировать умеет), затем присвоить этому классу строки из Memo, отсортировать их и присвоить их обратно Memo. Поставим еще одну кнопку на форму, которая будет запускать процесс. Код получится примерно таким:

procedure TForm1.Button3Click(Sender: TObject);
var t:TStringList;
begin
t:=TStringList.Create; //создаем
t.AddStrings(memo1.lines); //присваиваем переменной t строки из Memo
t.Sort; // сортируем
memo1.Clear;
memo1.Lines.AddStrings(t); // присваиваем memo уже отсортированные строки
end;

Теперь рассмотрим еще один вопрос, касающийся создания компонентов в Run-time. Допустим вам надо создать 20 полей для ввода текста (Edit) и еще десять меток (Label), не будете же вы 20 раз писать одно и тоже для каждого edit'a. В этой ситуации есть очень элегантный выход: воспользоваться массивом компонентов. В общем виде объявление массива компонентов может выглядеть так: имя_переменной:array[нижний_индекс..верхний_индекс] of тип_компонента. Теперь поупражняемся в этом. Создайте новое приложение. На форму поместите только кнопку. Обработчик события OnClick которой у меня получился таким:

procedure TForm1.Button1Click(Sender: TObject);
var a:array[1..20] of TEdit; // массив элементов Edit
      b:array[1..10] of TLabel; //массив меток
      i,j:integer;
begin
 for i:=1 to 20 do begin
 a[i]:=TEdit.create(self);
 a[i].parent:=form1;
 a[i].left:=10;
 a[i].text:='элемент # '+inttostr(i);
 a[i].top:=i*20;
end;
for j:=1 to 10 do begin
 b[j]:=TLabel.create(self);
 b[j].parent:=form1;
 b[j].left:=200;
 b[j].Caption:='элемент # '+inttostr(j);
 b[j].top:=j*30;
end;
end;

Ну как?! Иногда воспользоваться массивом компонентов очень даже удобно, потому что в массиве обращение к его элементам происходит по индексу, а в обычной ситуации обращение происходит по имени компонента, что не всегда удобно. 

Дополнительная информация

Автор: Михаил Христосенко.

Если у вас возникнут какие-нибудь вопросы, предложения и пожелания, а также ваши отзывы шлите по почте: kikoz@kemtel.ru

Заходите на мой сайт http://mihandelphi.narod.ru/ там вы найдете множество программ (моих и не только), компонентов, статей и еще множество полезностей для Дельфера.





Свежее
Резервное копирование rsync-ом
DNS Amplification (DNS усиление)
Алгоритм Шинглов — поиск нечетких дубликатов текста
Metasploit Framework. Обзор
Использование CouchDB
-------



 
Copyright © 2003-2009   Frikazoid.
Rambler's Top100