Главная страница
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.045 c
1-1088513145
tamagavk
2004-06-29 16:45
2004.07.11
Проблема с StatusBar


14-1087993301
Igorek
2004-06-23 16:21
2004.07.11
Пара вопросов бывалым разработчикам


14-1087893395
Alex*
2004-06-22 12:36
2004.07.11
Можно ли отследить блуждание по Интернету с удаленного компьютера


3-1087455401
vic1
2004-06-17 10:56
2004.07.11
Автосумма


14-1087578236
Art_Z
2004-06-18 21:03
2004.07.11
Пираты