FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Sumar edits e ir actualizando
Bueno amigos! Se que se podria hacer de manera mas sencilla, pero se me ocurrio hacerlo asi y queria compartir con uds el problema jaa.
Tengo en un form el pago de un cliente. coloque entonces los siguientes edits(en la imagen): Y la idea era que en el campo total dentro de "efectivo" se sumen los pesos que representan los dolares mas los pesos entregados por el cliente. A esto se le sumarian los cheque ingresados(hasta cuatro), esto se mostraria en el campo total haber, y el campo nueva deuda estaria la deuda de la base de datos al entrar al form y se le resta el haber. Pero el caso es que quise hacerlo con eventos, y me lie jaja. Es decir si el usuario va cambiando los ars o dls cambia el total al igual que al agregar un cheque. Y el algoritmo termino siendo mas complejo de lo que parecia iba a ser. Me acorde del foro aja y quiero compartirlo Última edición por giulichajari fecha: 21-11-2014 a las 23:52:18. Razón: me olvide la imagen |
#2
|
||||
|
||||
Yo para trabajar con importes monetarios uso el tipo currency. Podes hacer algo como esto:
Luego quedaria a gusto tuyo el como tratar las excepciones, no se si realizas alguna validacion en otro evento, ahi se asume que "esta todo bien" El CurrToStrF es para decirle a Delphi que ademas de convertir a string un valor monetario, que le de formato. En el ejemplo que puse yo trunca el valor mostrando solamente 2 decimales y le agrega el signo de la moneda configurada ($, U$S, etc) Tranquilamente podes usar tambien CurrToStr o mandarle otros parametros (revisa los posibles valores ademas del ffCurrency) Eso lo podes poner en el OnExit de los edit, o en el OnChange. Saludos! |
#3
|
||||
|
||||
En realidad la forma que a la larga termina siendo la mas sencilla y clara es que encapsules todo ese comportamiento en una clase
Por ejemplo, algo super sencillo
E implementar los getter y setter asi
Aca el secreto esta en utilizar propiedades para obtener y acceder a los valores, en el atributo FDirty (Sucio) y el metodo Recalcular (todo esto es de un ejemplo que lei del viejo maestro Ian Marteens) De esta manera nos aseguramos que cuando obtenemos un valor, este esta "actualizado" porque la clase sabe calcular el total. Imaginate si tenes que aplicar tasas de interes, impuestos, descuentos.. etc. Asi te quedaria todo el calculo del total en el metodo Recalcular (en un solo lugar) y podrias consultar y setear valores libremente sabiendo que siempre estaran ajustados dependiendo de los valores que setees. Luego siguiendo la logica de lo que queres hacer, en el OnExit de los edit podrias validar que el importe efectivo es valido (por ejemplo) y mandarselo a la clase. La clase setea el valor y FDirty pasaria a True, por lo tanto la proxima lectura de algun valor llama a Recalcular y los montos son actualizados. Entonces el OnExit de los edit quedaria
Donde refrescar seria un proceso de tu form que se encarga de asignar a cada edit el valor correspondiente de la instancia de la clase Pago Última edición por AgustinOrtu fecha: 22-11-2014 a las 00:51:58. |
#4
|
|||
|
|||
Gracias
Bueno gracias por responder.
Un problema que tenia antes de publicar el mensaje con el evento onchange, es que el valor se sumaba mal, por ejemplo, si escribo 1 y luego 2 me queda 12 que se suma al 1 anterior. Osea la funcion recalcular deberia restar lo anterior. Y ademas el evento onexit no es suficiente porque el usuario puede retornar al edit. Pero lo voy a intentar. |
#5
|
||||
|
||||
1 + 2 te dio 12 porque sumaste sirings, el String '1' concatenado con el String '2' = '12'
Tenés que convertirlo a moneda para que te de 3 con la función StrToCurr |
#6
|
|||
|
|||
El usuario se para en el edit ARS y escribe 1. entonces el total ARS es 1, pero si luego escribe 2, se forma el 12 que se suma al 1 en total ARS y da 12+1=13 cuando deberia ser 12, osea cada vez que cambia se vuelve a sumar, es como que se deberia sumar la "diferencia".
|
#7
|
||||
|
||||
Eso es porque en el total ARS no tenes que sumarle lo que acaba de escribir, asignale el valor del edit
De esa manera asignas siempre el valor ingresado Estas haciendo algo como esto?
Sin el codigo que estas usando no se que podrias estar haciendo mal |
#8
|
|||
|
|||
Aparenta funcionar
Muchas gracias por tu ayuda, lo probe y funciona |
#9
|
||||
|
||||
Hola giulichajari.
También podes encapsular las acciones del código que mostras arriba en un método, para luego asignarlo a los eventos OnChange de los Edits involucrados. Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#10
|
|||
|
|||
Cita:
Y que significa ? Tuve que poner la propiedad Text por default en 0(cero) para no tener errores al sumar, porque el vacio es null. Como puedo resolver esto? |
#11
|
||||
|
||||
Hola giulichajari.
Revisa el demo que te adjunto. Le agregué el cálculo del subtotal, que se me había pasado en el código anterior. Cita:
Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 24-11-2014 a las 21:42:58. |
#12
|
|||
|
|||
Cita:
Edit2 es el total haber. |
#13
|
||||
|
||||
Hola giulichajari.
Cita:
Cita:
(*) "DeudaAnterior" sería el valor obtenido de la base de datos. Lo que ahora no me termina de cerrar es que cálculo deseas obtener en el Edit "Subtotal". Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#14
|
|||
|
|||
Subtotal
El subtotal son los pesos correspondientes a los dolares, y el total son los pesos mas los pesos representados por los dolares, es decir el cliente puede pagar en pesos mas dolares. Entonces se calculan los dolares en pesos en el subtotal mas lo que entregue en pesos y ese es el total en efectivo.
Luego al sumar los cheques es el monto total del haber. Muchas gracias. |
#15
|
|||
|
|||
Cita:
|
#16
|
|||
|
|||
Y para guardar
Ahora como hago para guardar el contenido de un eddit, el de haber por ej en el campo deuda de la tabla de clientes que es Decimal si el edit es currency?
|
#17
|
||||
|
||||
No no, ojo, lo que tenés en el texto del edit siempre es un String.
Para guardar ese valor podes usar sentencias sql, usando insert o update, y pasando como parámetro el valor del edit. Deberías convertirlo a currency con StrToCurr Si tenés dudas con esto solamente avisa por acá, que ahora estoy desde el móvil y me da pereza escribir código |
#18
|
|||
|
|||
Cita:
|
#19
|
||||
|
||||
Hola giulichajari.
Si el contenido de la propiedad Text del TEdit que mencionas, tiene un formato como por ejemplo '$ 90.780,33', podrías hacer:
Ejemplo de uso:
Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#20
|
|||
|
|||
Pues me da el problema de que al sacar el punto (.) me graba mal el dato, porque si debe 1.000,00 y pongo 100,00 quedan 900,00, y en la bd graba 9000. Este problema se debe a que usa el punto para los miles y el punto para los decimales, tendria que ser el punto para una cosa y la coma para la otra, me parece
|
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
sumar edits | Kamael | OOP | 17 | 12-03-2015 19:18:55 |
Actualizando AdoQuery | Nathan | Conexión con bases de datos | 3 | 05-05-2006 20:07:19 |
Actualizando un campo... | StartKill | Firebird e Interbase | 5 | 05-03-2004 20:50:54 |
Actualizando los TImage | Magneto | Varios | 4 | 05-12-2003 07:40:55 |
Actualizando Firebird | hgiacobone | Conexión con bases de datos | 5 | 09-06-2003 22:35:02 |
|