Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 17-03-2014
deivi deivi is offline
Miembro
 
Registrado: feb 2004
Posts: 19
Poder: 0
deivi Va por buen camino
escribiendo en dbgrid

Quisiera ayuda en algo supuestamente fácil, pero que llevo días y no doy con la solución.
Tengo un formulario con un JvDBGrid y necesito saber en una columna en concreto, la longitud de la cadena que estoy escribiendo. No tengo ni idea de como capturar lo que estoy escribiendo en el momento para saber la longitud del campo y lo necesito para bloquear la edición si pasa de ciertos caracteres.
Gracias.
Responder Con Cita
  #2  
Antiguo 17-03-2014
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.734
Poder: 20
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
Suppngo que ese DBGrid depende de un DataSet.
Si asignas a un campo una longitud máxima, el DBGrid se encargará de todo.

Puedes establecer esta propiedad en el inspector de objetos.
Si no utilizas campos persistentes, deberás utilizar esta línea:
Código Delphi [-]
// Establece la longitud máxima para el código de artículo en 15 caracteres
DataSet.FieldByName('ARTICULO').Size := 15;
Responder Con Cita
  #3  
Antiguo 17-03-2014
deivi deivi is offline
Miembro
 
Registrado: feb 2004
Posts: 19
Poder: 0
deivi Va por buen camino
Lo he intentado, pero me dice que no puedo hacer eso en un dataset abierto, y como el campo no es persistente, no puedo asignarle el valor antes de abrir el dataset, por eso había pensado en capturar la longitud del campo que estoy escribiendo en el momento.
Responder Con Cita
  #4  
Antiguo 17-03-2014
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Cita:
Empezado por deivi Ver Mensaje
Lo he intentado, pero me dice que no puedo hacer eso en un dataset abierto, y como el campo no es persistente, no puedo asignarle el valor antes de abrir el dataset, por eso había pensado en capturar la longitud del campo que estoy escribiendo en el momento.
Hola deivi.

Por lejos creo que la opción mas simple es crear el campo persistente y configurar la propiedad Size desde el Field Editor o usando el código que te sugirió duilioisola, pero ignoro por que no podes hacerlo.

Sin embargo, podrías hacer:
Código Delphi [-]
const
  THE_COLUMNN   = 1; // Columna del campo en cuestión
  ALLOWED_CHARS = 2; // ( Cantidad de caracteres permitidos - 1 )

procedure TForm1.DBGrid1KeyPress(Sender: TObject; var Key: Char);
begin
  with TDBGrid(Sender) do
    if (EditorMode) and (SelectedIndex = THE_COLUMNN) then
      if (Length(TInPlaceEdit(Controls[0]).Text) > ALLOWED_CHARS) and (Key<>#8) then
        Key:= #0;
end;

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #5  
Antiguo 17-03-2014
deivi deivi is offline
Miembro
 
Registrado: feb 2004
Posts: 19
Poder: 0
deivi Va por buen camino
No consigo que eso me funcione bien. El campo que quiero modificar está en la columna 4, pero he probado poniendo distintos valoresd dentro de control[n] y no me saca nada.
Responder Con Cita
  #6  
Antiguo 17-03-2014
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola deivi.

Tál como dejé comentado en el código anterior, el índice de la columna está indicado por la constante THE_COLUMNN y no por el índice de la propiedad Controls que siempre será cero.

La cantidad de caracteres -1 que deseas permitir se regula por el valor asignado a la constante ALLOWED_CHARS.

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #7  
Antiguo 17-03-2014
deivi deivi is offline
Miembro
 
Registrado: feb 2004
Posts: 19
Poder: 0
deivi Va por buen camino
gracias, no puse el with TDBGrid(Sender) do y se me lió todo. Me ha funcionado perfectamente. La duda era TInPlaceEdit(Controls[0]).Text), pero poniendo el with ya no hay duda.
No tenía ni idea de que existía lo del TInPlaceEdit, pero creo que lo usaré más a menudo.
Lo de no usar campos persistentes es para tener más facilidad a la hora de crear campos en la base de datos o de modificar el tamaño de los campos. Así no tengo que volver a hacer cambios en los dataset y es más dinámico todo.
Muchas gracias.
Responder Con Cita
  #8  
Antiguo 17-03-2014
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola deivi.

De nada, inclusive podes aplicarlo a varias columnas con unas pocas modificaciones:
Código Delphi [-]
const
  // Cantidad de columnas que van a restringirse
  NCOLS = 3; 
  //Arreglo constante con la cantidad de caracteres permitidos para cada columna a restringir.
  ALLOWED_CHARS: array[1..NCOLS] of Integer = (2, 1, 4); 

type
  TIndex = 1..255;
  TIndexSet = set of TIndex;

var
  ColumnsSet: TIndexSet = [1, 2, 3]; // Índice de las columnas a restringir.

procedure TForm1.DBGrid1KeyPress(Sender: TObject; var Key: Char);
begin
  with TDBGrid(Sender) do
    if (EditorMode) and (SelectedIndex in ColumnsSet) then
      if (Length(TInPlaceEdit(Controls[0]).Text) > ALLOWED_CHARS[SelectedIndex]) and (Key<>#8) then
        Key:= #0;
end;
En el ejemplo se restringen las columnas uno, dos y tres a la cantidad de tres, dos y cinco caracteres respectivamente.

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Escribiendo en el Registro de Windows el-otro Varios 4 05-09-2013 04:49:03
Como filtrar datos escribiendo en un DBGrid? JairoC Varios 6 20-02-2012 01:01:55
¿Cómo ir filtrando los datos de un dbgrid mientras voy escribiendo en un edit? Master23 Varios 7 30-06-2010 22:01:45
Escribiendo en varias tablas maravert Tablas planas 1 20-10-2005 17:53:16
Escribiendo codigo en procedimientos JulioGO OOP 1 07-10-2004 23:49:06


La franja horaria es GMT +2. Ahora son las 13:24:36.


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
Copyright 1996-2007 Club Delphi