![]() |
Bueno, mi pequeña aportación a los componentes. Son dos componentes "DB Aware".
El primero es muy sencillo, se trata de un "label" que cambia según el valor de un campo boolean (o cualquier tipo de campo con dos valores posibles). El segundo es una especie de "Grid" no editable, con filas y columnas donde cada registro es una celda y se puede mostrar un texto y una imagen por cada registro. También va una demo con los dos componentes. Tengo algún componente más para aportar, a medida que los vaya adaptando al formato del club los iré subiendo. Archivo Adjunto 968 |
Cita:
Cita:
Cita:
Respecto del archivo ".inc"... la verdad es que tengo esa costumbre y acaso tenga que quitármela. Pero, ahora mismo ningún componente (salvo error) incluye dicho archivo ni no hace uso del mismo de alguna manera. Además... ¿no podría pasar lo mismo si dichas "constantes" estuvieran en una unidad? No sé... no estoy seguro... acabo de despertarme, leñe. :) Cita:
Actualización: El formulario "acerca de..." no contiene ya el componente "Bevel". |
Cita:
Cita:
Cita:
Saludos! |
1 Archivos Adjunto(s)
Cita:
Aquí va lo anterior y lo nuevo junto: Archivo Adjunto 969 |
Hola,
Cita:
Pero, vamos, también es verdad que yo uso archivos "inc" por costumbre... y que a lo mejor no estoy haciendo uso de ellos correctamente, o uso "inc" donde debería usar unidades o al revés... |
Hola,
Acabo de actualizar CCD con los siguientes cambios: Cita:
Bueno. A ver si alguien se anima y prepara los iconos para los tres últimos componentes que se han añadido. :) |
1 Archivos Adjunto(s)
Cita:
Bueno, si usamos un recurso desde varias units distintas y este recurso estará dentro de un archivo incluído dentro de cada unit, entonces se incluriá para cada unit por separado sin reutilizarlo. Fíjate el ejemplo que te subo, busca tu nombre en los recursos de los dos ejemplos. Saludos! |
1 Archivos Adjunto(s)
Adjunto un ejemplo mas "visible".
Saludos! |
Hola,
Acabáramos. Ahora lo he visto claro. Pues inmediatamente me quito la costumbre de usar archivos "inc"... como si tal cosa. Es cierto que ha veces vienen muy bien (cuando propiamente se quiere que el contenido se "incluya" en un determinado lugar, en cuyo caso no pueden usarse unidades), pero, duplicar los recursos por duplicarlos... nanai. Así que haré los cambios oportunos en CCD. Y me temo que ciertos proyectos que tengo en marcha también. Muchas gracias Federico. Nunca te acostarás sin saber una cosa más, suele decirse, y hoy es cierto para mí gracias a ti. :) |
Hola,
Ya está subido CCD haciendo uso de la nueva unidad "URecursosCCD.pas" en lugar de "rsCCD.inc". :) Actualización: Ya he añadido iconos para los tres últimos componentes. Pero siempre pueden mejorarse... :) |
Dec e corregido los fallos que en principio encontre harora estoy atascado en el tema de que la clase de la que parte el componente, no tiene la propiedad Transparente, sabe si a una de las dos clases usadas (TcomponenControl o TWinControl), es posible hacer el fondo transparente, o hay alguna otra clase.
Emilio perdona abri otro hilo con este tema en el foro de OOP este es el enlace por si estimas oportuno eliminarlo http://www.clubdelphi.com/foros/show...346#post228346 |
Hola,
José, no sé yo si toqué algo en ese sentido, la verdad es que creo recordar que sí, empero, me parece que puedes derivar el componente de "TGraphicControl". De todos modos, podrías plantear la cuestión en los Foros de modo que pudieras obtener ayuda de más gente. Héctor, los iconos son estupendos. Ya están añadidos y CCD actualizado en consecuencia. :) http://web.madritel.es/personales2/a...on/ccd/ccd.zip |
Hola,
Acabo de añadir a CCD los componentes que el compañero Neftalí tiene publicados en su página Web. Ahora mismo se cuentan ya 24 componentes en el paquete. No es que quiera mencionar la cantidad, pero, me parece un número muy bueno teniendo en cuenta que empezamos ayer como quien dice a recopilar componentes. :) |
Cita:
Creo conveniente que este hilo se haga público por varias razones, ya se ha llegado al punto de la realidad, es decir, como todos sabéis infinidad de veces se proponen hacer proyectos y al final prácticamenente nunca cuaja nada, en este caso sí ha cuajado, en buena parte gracias a la coordinación de Dec, por supuesto sin menos preciar el resto de aportaciones, entiendo que todo proyecto requiere un lider, en este caso, sin saber cómo, tampoco importa, dec ha liderado el tema y lo ha hecho muy bien, el Club está en racha de creatividad en todos los sentidos. Pues lo dicho creo conveniente, hacer ya público tanto este hilo como los componentes que contarán también con un subdominio propio. http://componentes.clubdelphi.com (todavía no activo, en breve) Sin más dilación creo que si os parece bien, dec tú como coordinador podría s mover el hilo y luego hablamos ya sobre el tema del subdominio. |
Hola,
Bueno. En realidad no es que quisiera liderar nada, de hecho ya he dicho más arriba que a partir de N componentes el asunto superó mi capacidad de control. Los primeros componentes los he "editado" y adaptado "a mi manera", por decirlo así, pero, los últimos componentes no he podido, querido ni sabido hacerlo. En definitiva, que es necesario el concierto de todos los que han aportado componentes (porque quién mejor que ellos, que han escrito el código), de todos los que quieran aportar nuevos componentes, de todos los que quieran colaborar indicando errores y formas de corregirlos, de todos, digo, los que de alguna manera quieran echar una mano de la manera que sea. PD. Muevo este hilo a "OOP", entonces... :) |
Ya pude terminar los tres componentes en los que estaba trabajando :p, me ha costado, tengo que decir que gracias a Dec logre que el componmente perdiera peso, y mejorara, en este componente lo unico que me disgusta es un lijero prpadeo, en los otros dos me disgusta mas los iconos, pero bueno como siempre a la decición del personal, ya me direis. Todos con pequeñas demos a falta de compilar.
|
Hola,
Bueno trabajo José. En cuanto pueda voy a añadirlos a CCD. Noto, sin embargo, que usas variables globales para lo que podrían ser (si no me equivoco) miembros privados de un componente, o acaso propiedades del mismo, pero, en todo caso mantener dichas variables "dentro" del componente. Pero, vamos... fuera de esto (que voy a corregir si puedo) creo que podremos contar con tres nuevos componentes en CCD. :) |
Hola,
Ya están añadidos los componentes José. ¿Te fijaste en "CCDEditZoom"? Creo que funciona como se espera, excepto que no respeta la fuente original del Edit. Es decir, uno espera que la fuente sea la original, hasta que se pase el ratón por encima, y entonces se viera el efecto "Zoom", pero, la fuente del Edit cambia nada más ejecutarse el programa. Sigue haciendo el efecto Zoom, pero, pasa de "grande a más grande", en lugar de "normal a grande", no sé si me explico. :) http://web.madritel.es/personales2/a...on/ccd/ccd.zip |
Dec no se si te entendi, la idea es si pasas el raton por encima, solo hace que esl texto salga en negrita, mientras tengas el cursor del raton encima, desde que sales elimina la negrita, , en cambio cuando entras, si esta activo el zoom, cambia el tamaño del font, y multiplica por tres, el ancho y la font, el largo depende de si esta rellena el MaxWidth que limita el largo, al salir, devuelve al tamaño normal, pero en cuanto sales devuelve a los valores iniciales, no se si es que algo esta fallando, comentame si tal cosa y lo modifico, y de paso le añado un campo nuevo ValZoom y hacemos el zoom de l valor que le demos, que te parece. Que yo recuerde del FOnt, sólo he tocado, bold y size, pero no la fuente.
Te parece correcto como ha quedado el CCDLabelSopr, con lo unico que no he quedado del todo contento es con el ligero parpadeo. |
Hola,
Bueno. Respecto de "CCDLabelSopr" se me hace un poco raro su uso, no sé si me explico... a veces uno hace cambios en las propiedades pero no se ve el resultado... luego en tiempo de ejecución sí que se ven esos cambios... pero, resumiendo, creo que pueden lograrse efectos curiosos en un "label" y que puede venir bien en un momento dado. Respecto de "CCDEditZoom" el tema es este. Cuando uno sitúa un "CCDEditZoom" en el formulario, la fuente de este es la que por defecto es, o sea, digamos "Arial 10". Entonces uno esperaría (al menos así me ha pasado a mí) que en tiempo de ejecución, al pasar el ratón por el Edit su fuente pasara a ser "Arial 20" (por ejemplo). Pero el caso es que cuando ejecutas el programa el Edit que tenía "Arial 10" como fuente pasa a tener "Arial 20", por ejemplo, y cuando pasas el ratón por encima su fuente cambia a "Arial 30". Yo creo que en tiempo de ejecución el componente debería tener como fuente "Arial 10" y cuando pasaras el ratón por encima "Arial 20". No sé si ahora se entiende mejor. :) |
Oido Cocina, me meto con el componente y lo compruebo, aunque la verdad, en mi delphi 6 no he notado ese cambio, pero hare una rutina de comprobación ene el programa de ejemplo, en cuanto al Labelsopr, según mi idea inicial es su uso sobre imagenes, para que no exista la posibilidad de que no se lea el label por coincidir el color con parte de la imagen de fondo, por eso lo ideal es usar un color Vivo de borde con un color fuerte de texto central, de todas maneras, mirare el problema, del EditZoom y que te parece la idea del valzoom.
|
Cita:
|
Basti ya que estoy trabajando en el componente se añadira tambien.
|
Hola,
Una cosa más José. Existe el componente "CCDEditZoom" y el componente "CCDDBEditZoom", ahora bien, teniendo en cuenta que de ambos componentes se espera similar comportamiento, ¿por qué no heredas el segundo del primero? Y luego le añades lo necesario para que se comporte como "data aware". De este modo cuando te plantees cambios, como ahora, no será necesario que hagas cambios en ambos componentes, sino sólo en "CCDEditZoom". ¿No te parece? :) |
Hola,
Acabo de añadir a CCD el componente CCDZoomPanel, que es un componente basado en parte en código del compañero Domingo Seoane, en parte en el artículo Zoom de Zarco Gajic. Se trata de un panel "lupa" que amplía en una imagen lo que esté "debajo" del ratón en un momento dado. Seguro que habéis visto ya algún componente similar. :) http://web.madritel.es/personales2/a...on/ccd/ccd.zip PD. ¿Ves lo que hago Eduardo? :D |
Cita:
Muy bueno dec |
algunos componentes
1 Archivos Adjunto(s)
Hola compañeros de club, lo prometido es deuda jeje, aquí les dejo algunos componentes que hice, claro ayudandome de los que vienen en delphi, jeje, espero les sirve, me faltó documentar ya que no tuve tiempo, pero pienso, que son autodescriptivos:)
PD: Supongo que necesitaran varias mejoras, no serán buenos pero ahi va Saludos cordiales |
Cita:
Espero que os sean útiles. Todavía no me ha dado tiempo de "revisar e instalar" el engendro (pues acabo de llegar), pero en cuanto lo haga daré aquí mis opiniones y pareceres... |
Hola,
Cita:
|
Hola, dec!!
mirando por ahí he encontrado este hilo: http://www.clubdelphi.com/foros/show...hlight=hamachi en donde dec te interesa por la cosa de enviar archivos vía tcp, y por un chat. Así que ahí va la cosa: como algunos sabeis yo tengo un programa, en eterno desarrollo que es el ajedrezchat, que sirve para lo que de su propio nombre se puede deducir: chatear, y si se tercia jugar al ajedrez. El programa puede hacer de servidor de chat y logicamente de cliente, de manera que cualquiera puede ponerse de servidor (abriendo, si hiciera falta, el puerto correspondiente en su router) y aceptar tantos clientes como quiera. El caso es que para el chat de dicho programa uso dos com ponentes: el TicsChatServer y el TicsChatClient , que no encontrareis en ninguna parte porque los he hecho yo y nadie mas los tiene, (excepto jhonny). Son muy faciles de usar, pero aún asi tengo hech una demo sencilllita, que hice para jhonny cuando se los pase. Se llaman Tics* porque estan hecho usando la librería, perdón, la biblioteca de componentes ICS de fpiette, que me gusta bbastante mas que los INDY. Gueno, lo que quiero es saber si los veis interesantes para colección del club. Por otra parte seoane tenia un código por ahí para enviar archivos vía tcp usando threads, que es lo que le vendría de perlas a estos componentes. Ademas de una limpieza de su chapucero código, jeje. Así que me gustaria ponerlos, los componentes a vuestra disposición, y alguien se anima y los modifica o mejora o lo que sea, y sobre todo les añade algo como eso de seoane para que admita el envñio de archivos, pues me haría feliz, :) Eso es todo, si lo veis bien busco el código y los subo donde me diga dec. Un saludo! PD: si alguien se anima hacer una versión con freepascal que funcione bajo linux, sería la felicidad completa. Hasta he pensado en pagar (¿alguien se ofrece?) por ello. |
Cita:
Lo malo es que vengo de pelearme, por culpa de un trabajito que me surgió, con un programa de intercambio de ficheros bastante complejo y ahora mismo estoy bastante cansado del tema :( Aunque si al final me decido a hacer algo habría que decidir primero que librerías se usarían. ¿Winsock a pelo? ¿Indy? ¿Synapse? o alguna otra librería compatible con freepascal y linux. La elección es importante, ya que se convertirá en un requisito de instalación en los futuros componentes. |
Cita:
|
Cita:
Un saludo aclaratorio :) |
Bueno julian, y que características piensas que puedan tener esos componentes ???. Yo me imagino uno que haga de servidor, y que tenga un solo método "listen" que dispare un thread que se ponga a la escucha en un puerto para realizar la transferencia, el método listen devuelve el puerto por el que esta escuchando. El cliente por su parte tendrá solo método "send" que envío un fichero a un puerto especifico.
Por ejemplo para realizar una transferencia, el que actúe como servidor ejecutara el método listen y el numero de puerto que le devuelva se lo pasa al cliente, el cliente por su parte usara el método send. Lo que falta es saber como mandara el servidor la información del puerto al cliente, pues si se supone que es un accesorio de un chat, ya debe de existir una conexión entre los dos, así que se puede utilizar esa. :( Me da la sensación de que no me he explicado muy bien |
Hola,
A ver, ponersus de acuerdo. :) PD. Pero está bien, está bien. ;) |
Vamos a ver Julian, un primer esbozo podría ser esto:
Son dos clases descendientes de la clase TThread. Solo utilizo funciones del Winsock, nada de librerias. Y un ejemplo de como usarla seria el siguiente: - Uno de los usuarios del chat decide mandar un archivo a otro, así que le manda un mensaje pidiéndole permiso. - El otro crea una instancia del TFileReceive y le devuelve un mensaje con el numero de puerto y un código de seguridad (token) - Ahora el primero crea una instancia del TFileSender, usando el puerto y el token que acaba de recibir, y envía el archivo. Esto llevado a código: El receptor y el emisor solo se tienen que poner de acuerdo en el puerto y el token, si el emisor y el receptor ya mantienen una conexión de chat no sera difícil implementar un protocolo para hacer eso. Bueno, son las 3 AM y esto es todo lo que se me ocurre :p Espero que se me entienda. |
Jau!
tengo muy poco tiempo estos días, mas que poco ninguno,por eso no he podido poner esto antes: icsChatComponents Ahí van los componentes para tener un servidor y cliete chat, con el código fuente y una demo. Mi consejo es que, a quien le interese el tema, pruebe la demo antes que nada. Y despues que se ponga a mirar el código chapucerillo, jeje. Para probar la demo no hay mas que ejecutarla, y activar el servidor, y despues si activa el cliente se conecta al server. Despues puede ejecutar otra instancia del programa y conectarse al mismo server ( Con otro Nick para que no de error, claro!!) Gueno, ya me direis, un saludo! Lo olvidava: para instalar los componentres se necesitan los ICS de Fpiette. |
Hola,
Está muy bien Julián. La "demo" por lo menos funciona estupendamente. :) |
Cita:
Pues si, si miras el código encontraras unas cosas bastante retorcidas en los procesos de conexión y validación de clientes al servidor de chat, y sé que dicho código es en teoría, merecedor de un buen suspenso en un éxamen de programación en una universidad. Perooooooo... el hecho cierto y comprobado es que funciona, cmo tu dices, bien. ¿y como me atrevo a afirmar eso? Ahí vá: el desarrollo de ese código tuvo duras pruebas que superar. Era para el ajedrezchat, que se usaba, y se sigue usando, en los canales #delphi y #ajedrez del irc-hispano, y en esa epoca había 3 o 4 hijosdelagranputa que se dedicaban a sabotear y a putear a los usuarios de estos canales, y en concreto al ajedrezchat. De manera que yo sacaba una versión del programa, lo daba a probar, y automáticamente, ahí tenias a esos 4 cabrones conectandose por telnet y por ssh a cualquier ajedrezchat que se pusiera de server. Incluso se hacian programillas con un botón "Conectar un socket al ajedrezchat" el cual pulsaban rapida y repetidamente hasta que reventaban literalmente cualquier ajederzchat de servidor. Un infierno. Pero yo soy muy cabezón. Y el resultado será un código muy remendao, pero, despues de perder alguna batalla, gané la guerra. Con un par. No dudo que algún experto programador o hacrker o lo sea sea capaz, incluso fácilmente, de tumbarme un server de ajedrezchat. Pero aquellos cuatro hackercillos de pacotilla no pudieron, tuvieron que rendirse, humillados y derrotados, y agachar su vacía cabeza y retirarse avergonzados. Así que, algún experto podrá criticar, con gran razón, mi código, y yo se lo agradeceré (aún mas le agradecería que lo arreglara). Pero el hecho, el hecho cierto, es que funcionar, funciona, y muy bien. Y eso es lo que yo pretendía. Por cierto, que estuve probando con los INDY, antes que los ICS, pero toido lo que conseguía era tremendamente vulnerable a cualquier ataque, aunque fuera un pequeño 'flood'. Por eso tuve que volverme a los ICS. Un saludo! |
La franja horaria es GMT +2. Ahora son las 19:24:27. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi