FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Clases e Interfaces
Hola a todos.
Antes de lanzar esta pregunta he buscado en los foros sin encontrar nada al respecto. Espero que alguien me sepa contestar. Ahí va: Estoy creando varios controles cada cual de una clase diferente. Estos controles deben almacenarse en un array y para arreglar el tema de las diferencias de clase, he creado un interfaz con un metodo y la he implementado en todos ellos. De esta manera declaro el array del tipo de la interfaz y así puedo acceder al procedimiento comun a todos descrito en la interfaz , pero que cada clase implementa a su modo. array[1].HazAlgo; Según el objeto que contenga en cada caso hará una cosa u otra. Mi problema es que estos objetos los tengo que enviar a otro procedimiento que recibe como parámetro un objeto TObject (admite cualquier objeto) y necesito conocer si dicho objeto implementa una determinada interfaz para que haga o no algo. He probado con getInterface pero no acabo de ver como funciona. En fin, gracias de antemano. Salu22222 |
#2
|
|||
|
|||
Hola Virata:
Prueba de esta forma:
No lo he probado, pero creo que es así. Por cierto que la función Supports (o mejor dicho las funciones porque hay distintas variantes) están definidas en la unidad SysUtils. Espero que te sirva. Saludos. P.D.: No me había dado cuenta de que era tu primer mensaje. Bienvenido al Club.
__________________
Guía de Estilo del Foro Última edición por Jan fecha: 05-09-2004 a las 15:27:19. |
#3
|
||||
|
||||
También podes valerte directamente del método QueryInterface de la interfaz IUnknown, que supongo, será lo que la funcion Supports hace.
Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#4
|
||||
|
||||
Cita:
// Saludos |
#5
|
||||
|
||||
claro... seria algo como:
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#6
|
||||
|
||||
Sí bueno, pero resultó más directo lo de Supports ¿no?
Por otro lado puedes tener objetos que no desciendan de TInterfacedObject pero que sí implemente la interfaz. // Saludos |
#7
|
||||
|
||||
Cita:
Al menos, he captado tu interes.. espero que ocurra lo mismo con quien inició el hilo.. Saludos.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#8
|
|||
|
|||
Efectivamente jachguate, tienes todo mi interes.
A ver si tengo un rato y paso a probar los procedimientos que me habeis indicado. Muchisimas gracias. Salu22222 |
#9
|
|||
|
|||
Hola de nuevo.
Os voy a poner el codigo de prueba que estoy realizando. Esta es la interface: Código:
unit MyInterface; interface type IMyInterface = interface ['{6E93F07C-AD0C-494B-85BC-A960AF01EF0A}'] procedure HacerAlgo(); end; implementation end. Código:
unit MyClass; interface uses QExtCtrls,Dialogs,MyInterface; type TMyClass=Class(TTimer,IMyInterface) procedure HacerAlgo(); end; implementation procedure TMyClass.HacerAlgo(); begin showmessage('Estoy haciendo algo'); end; end. Código:
unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls,ExtCtrls,MyClass,MyInterface ; type TForm1 = class(TForm) Button1: TButton; Timer1: TTimer; procedure Button1Click(Sender: TObject); procedure Miprocedimiento(Objeto:TObject); private { Private declarations } public { Public declarations } end; var Form1: TForm1; implementation {$R *.dfm} procedure TForm1.Button1Click(Sender: TObject); var MiClase:TMyClass; begin MiClase:=TMyClass.create(self); MiProcedimiento(MiClase); MiClase.Free; end; procedure TForm1.Miprocedimiento(Objeto:TObject); begin if Supports(Objeto,IMyInterface) then (Objeto as IMyInterface).HacerAlgo(); end; end. En el caso de declarar Objeto como TObject, se produce el siguiente error de compilación:"Operator not aplicable to this operand type" en la línea "(Objeto as IMyInterface).HacerAlgo();" y es por la sentencia as Puedo hacer typecast a Objeto para que sea TMyClass, pero el problema es que no todos los objetos que recibirá será TMyClass. No se como puedo arreglarlo. Gracias de nuevo. Salu22222 |
#10
|
|||
|
|||
Hola de nuevo.
Releyendo vuestros mensajes se me ha ocurrido hacer lo siguiente: Código:
procedure TForm1.Miprocedimiento(Objeto:IInterface); begin if Supports(Objeto,IMyInterface) then (Objeto as IMyInterface).HacerAlgo() else showmessage('este no tiene la interface'); end; También lo puedo hacer con IUnknown y funciona igualmente. Gracias Salu22222 |
#11
|
||||
|
||||
Cita:
Si aún deseas usar TObject en lugar de IInterface como tipo de datos del parámetro lo puedes hacer con Supports que acepta un tercer parámetro en el que se recibe una interfaz en caso de soportarse:
// Saludos |
#12
|
|||
|
|||
Ciertamente este último uso de Support me parece más limpio y funciona correctamente en el caso de que un objeto implemente un tipo determinado de interface.
Gracias por todo. Salu22222 |
#13
|
|||
|
|||
Ciertamente, es mas elegante. Ya dije que no lo había comprobado, estaba poniéndolo de memoria. Perdonad por el tiempo perdido.
__________________
Guía de Estilo del Foro |
#14
|
||||
|
||||
Cita:
Va un 'regaño' amistoso para el amigo Virata: al ver que no funcionaba el Supports tal como se escribió originalmente lo mínimo era consultar la ayuda acerca de la función en donde te hubieras dado cuenta de inmediato del uso correcto. // Saludos |
#15
|
|||
|
|||
Acepto el regaño de buen grado .Las prisas nunca son buenas consejeras. Gracias de nuevo y perdonad las molestias.
Salu22222 |
|
|
|