![]() |
Comunicacion entre BPL
Una pregunta Basica.
Estoy experimentando con los archivos BPL, cargandolos con LoadPackage. Mi pregunta es si puede haber comunicacion entre el MainForm y el BplForm. Ejemplo: MainForm carga al BplForm, y luego el BplForm llama una funcion del MainForm. MainForm carga al BplForm, y el MainForm modifica elementos del BplForm (Labels, Input, etc) Gracias |
Creo que sólo tienes dos opciones o crear herencia de formularios de manera de que la clase del formulario sea común tanto a la aplicación como al bpl (no sé me ocurre claramente como) o que crees una función en tu bpl que tenga como parámetro un TForm y manejar los controles mediante FindComponent
|
Puedes crear un BPL intermedio, para que te sirva de comunicación entre tu formulario principal y tu BPL cargado con LoadPackages, es decir, cargado de forma dinámica.
El punto clave es que tu BPL intermedio, deberá ser cargado de manera estática en tu formulario principal y en tu BPL lo debes de cargar utilizando el archivo DCP que se genera, igual de forma estática. Con esto puedes tener acceso a este BPL desde tu formulario principal y hacerle cambios a las variables o a los objetos que contenga, estos cambios se verán reflejados desde tu BPL dinámico. De igual forma, si haces cambios al BPL intermedio desde tu BPL dinámico, estos cambios los podrás ver desde tu formulario principal. Yo por ejemplo, estoy utilizando un DataModule en mi BPL intermedio... MiPrograma.exe <----> DataModule.bpl <------> UnModulo.bpl |
Si quieres ejemplos de lo que te han dicho en mi web hay varios ejemplos y código sobre el tema:
Acceder a las propiedades de un componente vía RTTI Modificar propiedades de controles en ejecución utilizando RTTI DLL’s, BPL’s, Carga dinámica/Estática y “Packages en Runtime” Sistema de PlugIns en Delphi – Parte 1 Sistema de PlugIns en Delphi – Parte 2 Sistema de Plug-ins utilizando packages dinámicos |
Gracias Neftali.
Con esto pude solucionar el ejemplo 2 MainForm carga al BplForm, y el MainForm modifica elementos del BplForm (Labels, Input, etc)
Ahora, me interesa lo que dice ContraVeneno. ¿ContraVeneno tienes algun ejemplo? ¿Tu dices que en vez que cargue el archivo Package1.dcp en vez del Package1.bpl? |
Cita:
![]() Tu PlugIn Base corresponde al package PlugBasic.bpl, que hace de "package intermedio"; Se carga de forma estática y el resto de packages que se cargan con LoadPackage (dinámicamente) derivan de el. De esta forma cuando cargas el Plugin3 (que deriva de plugBasic) puedes acceder a él con los métodos genericos de PLugBase. |
Es exactamente lo que comenta maese Neftalí... yo no podría explicarlo mejor. :D:D
|
Muchas gracias a los 2.
Lo he logrado utilizar el PlugBase Ahora, el problema que tengo es capturar el evento onClose, y onHide Este es el codigo
Muchas gracias nuevamente por la ayuda |
1 Archivos Adjunto(s)
Se puede hacer lo que quieres, pero tal y como lo tienes hecho hay algunos problemas:
(1) Los parámetros del evento OnHide, no coinciden con los de la rutina que estás colocando; Creo que te has hecho un lío con el OnClose.
(2) Esta línea también tiene "cosas raras": Piensa que estás asignando el evento FormHide, no de ningun objeto, sino que pones directamente la referencia a una clase (TEnvPro....), además de lo comentado de que nocoinciden los parámetros. (3) Si colocas el evento en el Initialization tendrás que acer referencia al evento como:
Te paso un ejemplo con algunos cambios. ![]() |
Muchas gracias Neftali...
La verdad es que estoy medio confundido. He estado programando bastanbte tiempo en Extjs y PHP, y uno se acostumbra a clases y a programar de una manera mas flexible. Siempre cuando empiezo un proyecto me gusta trabajar por modulos, ya que es mas facil detectar los problemas. Ahora, este es el esquema de lo que estoy haciendo. ![]() No se si sera el correcto desde tu punto de vista. 1.- El programa parte con la carga del unit Main.pas 2.- Luego que verifico que la version este ok, cargo el BPL Base, como tu lo recomendaste. 3.- El BPL Base tiene unas variables para verificar si estoy logueado o no. Si NO estoy logueado, llamo al Bpl login. Una vez que el BPL login me responde true o false. Retorno, la respuesta al Main, y comienzo a cargar los otros BPL a travez del BPL Base. |
Hola Adonias.
Es tema que planteas es difícil. Los packages no son la "panacea" y no creo que la solución sea utilizar packages para todo. Como ya has visto, trabajar con packages no es sencillo y además conlleva una complicaión adicional a la hora de programar. Lo primero que hay que diferenciar a la hora de trabajar con packages es si estamos hablando de carga estática o dinámica. (1) Carga estática. Trabajar con carga estática, creo que es más una decisión de diseño. En este caso la complicación no es tanta y podemos programar de una forma "más normal". Seguramente la división por packages en este caso, está más enfocada a aplicaciones grandes o muy grandes, que requieren una organización conceptual en bloques o por temas de dicisión conceptual. (2) Carga dinámica. En este caso ya es un cambio radical y no debemos tomarlo a la ligera. La carga dinámica de packages tienes ventajas y algunas de las características que consigues utilizándola, no podrías obtenerlas de otra manera; Características como el trabajo con de Plugins o Addins, modilaridad total, independencia,... El problema es que el "precio a pagar" también es alto, pues debes trabajar utilizando RTTI; Esto no es lo más sencillo ni lo más óptimo (como ya se ha comentado aquí). Lo que quiero decir con esto, es que es una decisión importante y no se debe tomar a la ligera. Se debe tener en cuenta que los packages "no son la mejor opción siempre", hay que pensar si para lo que vamos a realizar nos viene bien utilizar esta opción, o si para las necesidades que tiene nuestro proyecto nos va bien utilizar packages. |
Cita:
// Saludos |
Cita:
Quería decir que si trabajas con packages dinámicos, deberás utilizar RTTI. Y que como esto (trabajar con RTTI) no es óptimo, sólo se debe trabajar con packages dinámicos cuando realmente lo necesites. |
No, no. Es que lo que yo digo es que trabajar con paquetes dinámicos no hace obligatorio el uso de RTTI. Y tú mismo has dado ejemplos de que no es así.
Lo único que se requiere es estructurar bien los paquetes de manera que haya un lenguaje común entre la aplicación principal y los paquetes. Dicho lenguaje puede establecerse mediante clases abstractas o bien interfaces. // Saludos |
Cita:
Si bien se puede trabajar sin RTTI con carga dinámica de packages, creo que para hacer cosas potentes o para conseguir una buena integración con la aplicación principal tienes antes o después echar mano de ella. NOTA: No he trabajado con la opción de los Interfaces. |
Cita:
// Saludos |
Cita:
Comunicación entre BPL (este) Componentes en librerías DLL (el otro) En el otro hilo ya hemos explicado que si utilizamos packages (BPL's) con carga dinámica (LoadPackages) no podemos hacer referencia a los elementos que haya contenidos en el Package, utilizando la unit en el USES, porque eso implicaría la referencia estática a ese package. A esa restricción me refiero cuando digo que no podemos incluir las units en el USES, como cuando trabajamos "normalmente" (sin carga dinámica de packages) y que el trabajo se hace más complejo cuando estamos trabajando de esta forma. |
Sí, sí. También estoy al tanto del otroh hilo :).
Pero, me parece que tú mismo has dado el ejemplo de como hacer eso: 1. Defines la estructura de un plugin. Ésta puede ser una clase abstracta o una interfaz. 2. La unidad que define la estructura del plugin se carga estáticamente, tanto por la aplicación principal como por los plugins. Es decir, mediante la inclusión en USES de dicha unidad. 3. Los pluginslos cargas dinámicamente. Pero como serán clases derivadas de una clase abstracta (o implementarán una interfaz) que sí conocen, entonces no necesitan hacer uso de RTTI. Edito: De hecho, ¿que no es lo que expones en el mensaje #6? El paquete base hace de intermediario e interfaz común entre la aplicación principal y los paquetes, de manera que evitas el uso de RTTI. // Saludos |
Cita:
de los plugins (plugin2, plugin3,...). A esas me refería. Cita:
Pero sí es cierto, que al menos para lo que muestra ese ejemplo básico, no la necesitarías. |
Cita:
Aunque un sistema de plugins puede no dar el ancho para todo, pienso que sí puede resolver muchos problemas de modularidad, más allá de sólo aplicaciones básicas. Y me refiero a hacerlo sin usar RTTI. Por otra parte, no hay porque restringirse a una sola jerarquía de plugins. Dependiendo de la aplicación, si ésta es muy compleja, puede trabajarse con distintas categorías; por ejemplo, una para acceso a base de datos, otra para improtación/expórtación de datos, etc. // Saludos |
La franja horaria es GMT +2. Ahora son las 15:53:23. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi