powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Delphi [игнор отключен] [закрыт для гостей] / формы и фрэймы из dll
25 сообщений из 54, страница 1 из 3
формы и фрэймы из dll
    #38857690
crause
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Для приложения нужен плагин в виде dll, в нем будет TForm и TFrame.

Меня ждало эпичное разочарование как вы уже могли догадаться.

В начале начал считать себя полным дураком когда TFrame не хотел отрисовываться и когда выдавал "not Assign TFont"
Пошел гуглить и я был разачораван еще больше, решения нет в природе.

Потом решил использовать TForm вместо фрэйма, и тут блин меня ждет опять разочарования.
Код: pascal
1.
2.
3.
Form := TForm1.Create(AOwner);
  Form.ParentWindow := TWinControl(AOwner).Handle;
  Form.Show;


Форма рисуется в окне но управление могут получить только кнопки, edit и memo в ступоре.

Есть пара вопросов:
bpl-ки не предлогать

1. Есть ли у кого нибудь рабочее решения по Созданию и отображению TFrame из dll ????
2. Как исправить ситуацию с TForm, что бы форма получала управление???
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857694
Фотография softwarer
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
crause1. Есть ли у кого нибудь рабочее решения
Поверить первому впечатлению в третьей строке и сменить работу на адекватную.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857710
crause
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Меня моя работа вполне устраивает.

Такая грабля только в Embarcadero-продуктах или в том же Visual Studio тоже самое?
Или Windows виноват?
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857737
Фотография X-Cite
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
crause,
Form.ParentWindow := TWinControl(AOwner).Handle;
т.е. внутри формы должна быть другая форма?
или твоя форма должна просто открыться что-то сделать и закрыться.

Если вариант 1, то ответ здесь 16027901
Если вариант два, то не назначай Parent.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857785
crause
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Да именно первый вариант.

Такая грабля только в Embarcadero-продуктах или в том же Visual Studio тоже самое?
Или Windows виноват?

Как строить модульное приложение на Delphi? Что бы в качестве плагинов были dll и можно было на главной форме рисовать формы и фрэймы?
Как это делают корпаративные клиенты Embarcadero? Или они все в одно приложение пихают и когда нужно что то новое добавить компилят весь проект заново?

Спасибо за внимание!!!
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857814
asviridenkov
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
crauseКак это делают корпаративные клиенты Embarcadero? Или они все в одно приложение пихают и когда нужно что то новое добавить компилят весь проект заново?


До решения этой задачи нужно пройти долгий мучительный путь, длиной не в один год.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857830
crause
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Я же не прошу код или библиотеку.
Смысл и теорию. Если знаете поделились бы идеей.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857832
Фотография DarkMaster
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
crause,

1) Сходи на сайт TotalCommander - там есть статейка (старая правда), как организовать плагин в виде формы с RichEdit`ом для Тотала. Пример работоспособный.
2) Фреймы в ДЛЛ - без правки исходников VCL - забудь - ничего путного не получится.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857835
crause
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
DarkMastercrause,

1) Сходи на сайт TotalCommander - там есть статейка (старая правда), как организовать плагин в виде формы с RichEdit`ом для Тотала. Пример работоспособный.
2) Фреймы в ДЛЛ - без правки исходников VCL - забудь - ничего путного не получится.

Фрэймы откинул сразу после чтения гугла.

Такая грабля только в Embarcadero-продуктах или в том же Visual Studio тоже самое?
Или Windows виноват?
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857840
fd00ch
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
crauseИли Windows виноват?Билл Гейтс
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857842
Фотография X-Cite
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
crauseДа именно первый вариант.

Такая грабля только в Embarcadero-продуктах или в том же Visual Studio тоже самое?
Или Windows виноват?

Как строить модульное приложение на Delphi? Что бы в качестве плагинов были dll и можно было на главной форме рисовать формы и фрэймы?
Как это делают корпаративные клиенты Embarcadero? Или они все в одно приложение пихают и когда нужно что то новое добавить компилят весь проект заново?

Спасибо за внимание!!!
Я ж тебе ссылку показал на сообщение для первого варианта.
йодновременное присутствие WS_CHILD и WS_CAPTION в стиле класса окна (что получится при Panent=someParentForm и BorderStyle<>bsNone) не позволяют такому окну нормально активироваться по клику юзера (кэпшен серый, в эдиты нельзя войти) - это багофича винды
для нормальной активации приходится делать фокусируемому дочернему окну
SendMessage(ChildFormThat Got Focus.Handle, WM_NCACTIVATE , 1 , 0);
а его брату-соседу, потерявшему фокус -
SendMessage(ChildFormThat Lost Focus.Handle, WM_NCACTIVATE , 0 , 0);
багофича винды.

Я реализовывал плагинную систему через псевдо MDI.
1 Dll(Bpl) - 1 форма.
окна обычные, но ведут себя как MDI. Переопределив класс TForm и некоторые методы по расположению и поведению окон. Все формы плагина унаследуются только от нее.

Вот тебе для размышления поведения VCL.
На кнопку вешаешь.
Код: pascal
1.
2.
3.
4.
5.
6.
7.
procedure TForm3.Button1Click(Sender: TObject);
var
  a: TForm;
begin
  a := TForm.Create(Self);
  a.Show;
end;


И дочерняя форма всегда поверх главной. При том Parent у нее nil.
А вот ее запрет за выход за границы основной формы разворачивание и прочее (аля MDI) уже реализовываешь сам.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857846
Фотография softwarer
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
asviridenkovДо решения этой задачи нужно пройти долгий мучительный путь, длиной не в один год.
Неверно. Есть два пути. Либо иметь мозги и за тридцать секунд поставить одну галку, либо мозгов не иметь, и тогда "долгий мучительный путь" будет вечным, до тех пор, пока не найдётся начальник либо сменщик с мозгами. Далее см. пункт 1.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857850
чччД
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
crauseДа именно первый вариант.

Такая грабля только в Embarcadero-продуктах или в том же Visual Studio тоже самое?
Или Windows виноват?

Как строить модульное приложение на Delphi? Что бы в качестве плагинов были dll и можно было на главной форме рисовать формы и фрэймы?
Как это делают корпаративные клиенты Embarcadero? Или они все в одно приложение пихают и когда нужно что то новое добавить компилят весь проект заново?

Спасибо за внимание!!!
Все по-разному.
Я модули расширения в базе данных храню: залил новые модули, вот они сразу у всех клиентов и доступны. И доступ к модулям легко разграничить.
В модулях всего одна экспортируемая функция, которая возвращают экземпляр класса, реализующего набор интерфейсов.
Один из интерфейсов - содержит свойства, описывающие модуль (название, тип модуля и т.п.). Другие интерфейсы описывают группы свойство и методов, соответствующие конкретному типу модуля. Например, есть модули, которые встраиваются в визуальный интерфейс(появляются дополнительные пункты меню, панельки, закладки и т.п.) . А есть модули вообще невидимые, выполняющие какие-то специальные задачи - например, регистрирующие бизнес - события (утверждение документов, удаление справочников и т.п.).
Реализовать легко, расширять легко. Только надо быть осторожными: например, можно умудриться выгрузить модуль при живой ссылке на интерфейс. Ну, такиеопасные вещи нужно собрать в общую библиотеку и тщательно отладить их.
...
...
Для расширения функциональности вместо .dll еще можно использовать скриптовые языки.

Кому что в голову взбредет, короче.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857854
чччД
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
DarkMaster...
2) Фреймы в ДЛЛ - без правки исходников VCL - забудь - ничего путного не получится.

crause...
Фрэймы откинул сразу после чтения гугла.
...

Какие-то чудовищные заявления.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857858
Dimitry Sibiryakov
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
crauseТакая грабля только в Embarcadero-продуктах или в том же Visual Studio тоже
самое?
Только в Embarcadero. Переходи на Visual Studio и будет тебе счастье.
Posted via ActualForum NNTP Server 1.5
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857864
Фотография softwarer
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
чччДВ модулях всего одна экспортируемая функция, которая возвращают экземпляр класса, реализующего набор интерфейсов. Один из интерфейсов - содержит свойства, описывающие модуль (название, тип модуля и т.п.).
Имхо тут гораздо лучше обратный дизайн. Модуль вообще ничего не экспортирует; вместо этого он обращается к ядру и регистрирует свои фичи (для этого достаточно прописать такие вызовы в initialization). Как следствие, процесс становится проще, менее связанным и гораздо удобнее с точки зрения внесения изменений.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857871
чччД
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
softwarer...
Имхо тут гораздо лучше обратный дизайн. Модуль вообще ничего не экспортирует; вместо этого он обращается к ядру и регистрирует свои фичи (для этого достаточно прописать такие вызовы в initialization). Как следствие, процесс становится проще, менее связанным и гораздо удобнее с точки зрения внесения изменений.

Может, в этом и есть смысл. Вопрос особенностей технической реализации. Мы особо не заморачивались выбором.
Может, из-за того, что слишком быстро все заработало, и мы больше ядро не трогали, а все силы на прикладной функционал модулей бросили.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857901
stanilar
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
crauseЕсть ли у кого нибудь рабочее решения по Созданию и отображению TFrame из dll ?

Если посмотреть дерево наследования, то можно заметить, что TFrame не сильно отличается от TForm. И, насколько я еще помню VCL, ничто не мешает расположить одну форму в другой.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38857926
Соколинский Борис
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
crauseТакая грабля только в Embarcadero-продуктах или в том же Visual Studio тоже самое?
Или Windows виноват? Больше всех виноват Borland, который придумал пакеты и строго настрого запретил ими пользоваться.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38858145
AntonioPermskiy
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
crauseЯ же не прошу код или библиотеку.
Смысл и теорию. Если знаете поделились бы идеей.

crause,

Добрый день,

Делал такую штуку: приложение не создает форму, ее создает dll. Приложение работает с dll, хранящейся в БД. При запуске приложение соединяется с БД, вытягивает dll, если версия dll в БД не совпадает с текущей версией dll, вытянутой на предыдущих запусках приложения.

Главная форма приложения создается в dll. На ней, кстати, есть frame-ы.

Идея такой реализации очевидна: приложение стоит у многих пользователей. Чтобы изменить интерфейс меняем dll в одном месте(БД), все приложения ее подхватывают. Futuron от Dom.ru, если кто знаком, судя по отсутствию хинтов в приложении, так и работает.

Основной совет - передавать в dll Application и Screen.

Код(кусочно):

Приложение:

Код: pascal
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
type
  RInitArgs = packed record
    iApplication: TApplication;
    iScreen: TScreen;

    oForm: TForm; // идея возвращать форму, не нашла продолжения
  end;

  RCloseArgs = packed record
    //урезал в рамках примера
  end;

  TInit = function(var aInitArgs: RInitArgs): Boolean; stdcall;
  TClose = function(var aCloseArgs: RCloseArgs): Boolean; stdcall;

var
  lFilePath: String;

  lHandle: THandle;
  lInit: TInit;
  lClose: TClose;

  lInitArgs: RInitArgs;
  lCloseArgs: RCloseArgs;

  lConnectError: String;
begin
// ...код загрузки dll, означивание lFilePath...
  try
      Application.Initialize;
      Application.MainFormOnTaskbar := True;

      lHandle := LoadLibrary(PChar(lFilePath));
      if lHandle = 0 then
        RaiseExceptionFormat(rsLoadLibraryError, [lFilePath, GetLastError]);

      lInit := GetProcAddress(lHandle, cEntryInit);
      if not assigned(lInit) then
        RaiseExceptionFormat(rsLibraryEntryNotFound, [lFilePath, cEntryInit]);

      lClose := GetProcAddress(lHandle, cEntryClose);
      if not assigned(lClose) then
        RaiseExceptionFormat(rsLibraryEntryNotFound, [lFilePath, cEntryClose]);

      lInitArgs.iApplication := Application;
      lInitArgs.iScreen := Screen;

      if not lInit(lInitArgs) then
        RaiseException(rsInitError);
      try
        Application.Run;
      finally
        lClose(lCloseArgs);
      end;
    except
      on E: Exception do
        begin
          ShowMessage(rsAppRunError);
        end;
    end;
end.



DLL:

Код: pascal
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
function Init(var aInitArgs: RInitArgs): Boolean; stdcall;
var
  lCloseArgs: RCloseArgs;
begin
  Result := False;
  try
    gApplication := Application;
    gScreen := Screen;

    Application := aInitArgs.iApplication;
    Screen := aInitArgs.iScreen;

    Application.ShowHint := True;
    Application.CreateForm(TMainForm, gForm);
    Application.CreateForm(TResourceForm, ResourceForm); // все ImageList-ы на TResourceForm
    aInitArgs.oForm := gForm;

    gForm.Initialize;

    Result := True;
  except
    on E: Exception do
      begin
        Result := False;

        Close(lCloseArgs);
      end;
  end;
end;

function Close(var aCloseArgs: RCloseArgs): Boolean; stdcall;
begin
   if gForm <> nil then
     begin
       gForm.Finalize();
       gForm.Free;
       gForm := nil;
     end;

  Application := gApplication;
  Screen := gScreen;
end;

exports
  Init,
  Close;

begin
end.



Форма в dll(демонстрация frame, TPageNavigatorFrame в свою очередь также содержит frame-ы):

Код: pascal
1.
2.
3.
4.
5.
6.
7.
8.
9.
TMainForm = class(TForm)
  PageNavigatorFrameMain: TPageNavigatorFrame;
  procedure FormCreate(Sender: TObject);
  procedure FormDestroy(Sender: TObject);
private
public
  procedure Initialize();
  procedure Finalize();
end;




Проблема Cannot assign TFont с хинтами(а еще со скроллом одного из компонент) остается. Пока решение нашлось только в билде и приложения и библиотеки с опцией Link with runtime packages. При этом достаточно одного пакета vcl. Рядом с приложением после такого билда необходимо будет положить файлы rtlXXX.bpl и vclXXX.bpl. XXX - зависит от версии Delphi. Точные названия файлов также можно будет узнать, запустив приложение на машине без установленного Delphi - при запуске будут сообщения об отсутствии данных файлов.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38858191
Фотография DarkMaster
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Соколинский БорисcrauseТакая грабля только в Embarcadero-продуктах или в том же Visual Studio тоже самое?
Или Windows виноват? Больше всех виноват Borland, который придумал пакеты и строго настрого запретил ими пользоваться.

BPL - всем удобны за исключением одной маленькой штуки - они должны компилироваться одной версией во избежание. Поддержка от сторонних плагинописателей становится проблематичной.

В принципе у GunSmoker`a есть хороший набор статей о написании плагинов - для ТС - самое то.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38858226
RWolf
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
crauseПотом решил использовать TForm вместо фрэйма, и тут блин меня ждет опять разочарования.
Код: pascal
1.
2.
3.
Form := TForm1.Create(AOwner);
  Form.ParentWindow := TWinControl(AOwner).Handle;
  Form.Show;


Форма рисуется в окне но управление могут получить только кнопки, edit и memo в ступоре.

Есть пара вопросов:
bpl-ки не предлогать

1. Есть ли у кого нибудь рабочее решения по Созданию и отображению TFrame из dll ????
2. Как исправить ситуацию с TForm, что бы форма получала управление???

Я делаю так:
Код: pascal
1.
2.
3.
4.
5.
    frm := TConfigForm.CreateParented(ParentHandle);
    frm.Left := 0;
    frm.Top := 0;
    frm.Show;
    Application.InsertComponent(frm);


Тоже не идеальный вариант (не работает перебор контролов клавишей Tab), но хотя бы использовать можно.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38858245
Фотография softwarer
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
DarkMasterBPL - всем удобны за исключением одной маленькой штуки - они должны компилироваться одной версией во избежание. Поддержка от сторонних плагинописателей становится проблематичной.
Поддержка от сторонних плагинописателей нужна в 0.01% проектов; остальные играют роль неуловимого Джо. Тем не менее, проблематичной она не становится, поскольку есть два пути её сделать, один простой, другой правильный.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38858264
crause
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
В принципе у GunSmoker`a есть хороший набор статей о написании плагинов - для ТС - самое то Замечательный набор статей, но там описывается прнцип работы. Если не ошибаюсь там строчки не было как frame или form нарисовать на из dll

RWolf , еще и Tab не работает. Спасибо что подсказади, потом бы мучался.

AntonioPermskiy , у вас Tab работает в окнах и фрэймах?

Знатоки!!! Я думаю проблему с табами можно решить каким то сообщением для окна или параметром. Подсказку в студию пожалуйста.
...
Рейтинг: 0 / 0
формы и фрэймы из dll
    #38858270
Фотография DarkMaster
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
softwarerDarkMasterBPL - всем удобны за исключением одной маленькой штуки - они должны компилироваться одной версией во избежание. Поддержка от сторонних плагинописателей становится проблематичной.
Поддержка от сторонних плагинописателей нужна в 0.01% проектов; остальные играют роль неуловимого Джо. Тем не менее, проблематичной она не становится, поскольку есть два пути её сделать, один простой, другой правильный.

Может сэр приведет правильный пример кода?
...
Рейтинг: 0 / 0
25 сообщений из 54, страница 1 из 3
Форумы / Delphi [игнор отключен] [закрыт для гостей] / формы и фрэймы из dll
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]