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

Вниз

Подчиненные окна   Найти похожие ветки 

 
Heretic ©   (2004-06-23 17:12) [0]

У меня есть главное окно FormStyle=fsMDIForm и есть подчиненная ему форма FormStyle=fsMDIChild. При запуске открываются сразу оба окна, а мне надо, чтобы подчиненное окно открывалось только по какому-либо событию (нажатие кнопки например). Для этого я убрал из окна проекта строку "Application.CreateForm(TForm2,Form2);" А в событии "OnClick" пишу "Form2:=TForm2.Create(Self);". В событии Form2.OnClose пишу "Form2.Free". Вроде все начинает работать, но! Теперь я не могу открыть форму Form2 модально. А мне необходимо выполнить по событию "OnClick" определенные действия, передать управление в Form2, затем по закрытию Form2 продолжить выполнение действий "OnClick".


 
ламер ©   (2004-06-23 17:26) [1]

э-э-э... насколько я понимаю, MDI-child формы не могут быть модальными. именно потому что они MDI-child.


 
Heretic ©   (2004-06-23 17:35) [2]

А как же тогда?
Мне необходимо:

Procedure TForm1.OnClick....
begin
<че-то делаем>
Form2=TForm2.Create(Self)
<че-то делаем>
end;

Другими словами необходимо в первой форме выполнить определенные операции, запустить Form2, выполнить действия в Form2 (настройка параметров), продолжить выполнение операций в Form1 c учетом выполненных действий из Form2.


 
TUser ©   (2004-06-23 18:21) [3]

Если она модальная - так ли важно ей быть к тому же MdiChild? Все равно, другие формы приложения не активны, пока эта шоу модал.


 
ламер ©   (2004-06-23 18:28) [4]

> Heretic ©   (23.06.04 17:35) [2]
> А как же тогда?

Form2.FormStyle := fsNormal;


 
Heretic ©   (2004-06-23 19:15) [5]

Это все замечательно, но мне желательно, чтобы окно Form2, находилось в окне Form1. Не хотел описывать ситуацию полностью...
Ситуация:

Назначение программы - работа с БД
Есть главное окно (Form0) с менюшкой.
Одно подменю вызывает дочернее окно "Факультеты" (Form2), где находится база данных по факультетам.
Другое подменю вызывает дочернее окно "Кафедры" (Form1), где находится база данных по кафедрам, причем БД "Кафедры" содержит ключ из БД "Факультеты" (Типа к какому факультету относится кафедра).
И для выбора ключа факультета в БД "Кафедры" я хочу открывать окно с БД "Факультеты" для выбора.

Помогите, а?


 
Alexey Leonchik   (2004-06-30 06:15) [6]

1. Убрать форму из автоматически загружаемых: Project Options -> вкладка Forms

2. Обрабатываем любое событие, например щелчок по меню:
////////////////
// Общий журнал
procedure TfMain.mnuMainJurClick(Sender: TObject);
begin
   if not Assigned(fJurnal) then // если не создана
   begin
    fJurnal := TfJurnal.Create(self); // создание формы
       fJurnal.Show;
   end
   else // если создана
       MessageDlg(LISHNEE_OKNO, mtInformation, [mbOk], 0);
end;

А заодно запрещаем открывать два одинаковых окна.

3. В форме (журнала в моем случае - fJurnal) в событии OnClose
// освобождение экземпляра формы при ее закрытии
Action := caFree;

4. В форме (журнала в моем случае - fJurnal) в событии OnDestroy
// сброс значения переменной при уничтожении формы
fJurnal := Nil;


 
ЮЮ ©   (2004-06-30 06:28) [7]

>И для выбора ключа факультета в БД "Кафедры" я хочу открывать окно с БД "Факультеты" для выбора

А не лучше просто использовать DBLookupCombo на форме "Кафедры", чеи "открывать окно с БД "Факультеты" для выбора", тем более, что поведение при работе с окном "Факультеты" будет разным, а визуально они отличаться не будут, что вряд ли пойдет на пользу юзверю


 
Defunct ©   (2004-06-30 08:39) [8]

2 Heretic: Запускаем MS-Access, классический пример MDI приложения. Нет никаких модальных MDI Child, модальные окна выполнены в виде диалогов.


 
Ozone ©   (2004-06-30 09:25) [9]

Visible := false у MDIChild



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

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

Наверх




Память: 0.49 MB
Время: 0.038 c
3-1087192084
Tariel
2004-06-14 09:48
2004.07.11
InterBase - Сколько раз выполняется вложенный запрос в where


1-1087977761
Lion
2004-06-23 12:02
2004.07.11
регистрация


1-1088582894
Alex_2004
2004-06-30 12:08
2004.07.11
MS Word


1-1088075753
DimonNew
2004-06-24 15:15
2004.07.11
Конец страницы Excel


1-1088449248
Godness
2004-06-28 23:00
2004.07.11
Объеденить ячейки в Excel e