Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   Pintar fila completa en un DBgrid segun un dato (https://www.clubdelphi.com/foros/showthread.php?t=68474)

pablopessoa 16-06-2010 00:32:44

Pintar fila completa en un DBgrid segun un dato
 
Saludos!

tengo un dbgrid al que quiero que se le pinte la fila segun un valor de un campo de su datasource.
Por ejemplo:
si el campo "habilitado" del datasource es True se pinta de verde clarito.
Mirando en los post del foro lo pude hacer con el siguiente codigo :
Código Delphi [-]
procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
  DataCol: Integer; Column: TColumn; State: TGridDrawState);
begin
       if Column.Field.Dataset.FieldbyName('habilitado').AsBoolean then
       If (gdFocused in State) then
         dbgrid1.canvas.brush.color := clGreen
       else
         dbgrid1.canvas.brush.color := clMoneyGreen;

     dbgrid1.DefaultDrawColumnCell(rect,DataCol,Column,State);
end;

cuando se dibuja la grilla efectivamente muestra la fila en verde clarito para las filas que cumplen con la condicion.
El problema es que cuando selecciono una fila, solo me pinta de verde oscuro la primer columna, no pinta toda la fila.
Como puedo hacer para que pinte toda la fila de verde oscuro cuando selecciono la fila?
Muchas gracias!!

afunez2007 16-06-2010 00:47:08

Umm me parece que suena a un tipico caso de la propiedad RowSelect=False
Cuando la pones en true y seleccionas una fila esta se selecciona toda.

Ves si es por alli el asunto

Saludos

pablopessoa 16-06-2010 01:35:10

Gracias por responder!!
te comento, la propiedad dgRowSelect esta en True y la propiedad DefaultDrawing esta en falso.

osmuar_exp 16-06-2010 02:05:43

begin / end
 
Hola, creo que te falta un begin / end en esta parte:

Código Delphi [-]
if Column.Field.Dataset.FieldbyName('habilitado').AsBoolean then
If (gdFocused in State) then

lo demás creo que está bien...

pablopessoa 16-06-2010 02:14:35

Hola!
Mira, lo modifique de esta manera para que las que no cumplen con la condicion las pinte de rojo, agregando los begin y end como decias:
Código Delphi [-]
 if Column.Field.Dataset.FieldbyName('habilitado').AsBoolean then
       begin
          If (gdFocused in State) then
              dbgrid1.canvas.brush.color := clGreen
          else
              dbgrid1.canvas.brush.color := clMoneyGreen;
       end
       else
       begin
           If (gdFocused in State) then
              dbgrid1.canvas.brush.color := clRed
          else
              dbgrid1.canvas.brush.color := clOlive;
       end;
     dbgrid1.DefaultDrawColumnCell(rect,DataCol,Column,State);

Pero sigue pintando solo la primer columna de la fila seleccionada.
puede ser que sea esta sentencia la que lo provoca?
Código Delphi [-]
dbgrid1.DefaultDrawColumnCell(rect,DataCol,Column,State);
osea, al pasar DataCol y column no estoy provocando que pinte solo la primer columna?
Gracias a todos por responder e interesarse! :D

roman 16-06-2010 06:48:41

A ver, no estoy seguro, pero no es lo mismo Focused que Selected. Prueba cambiando la condición a

Código Delphi [-]
if (gdSelected in State) then

// Saludos

jafera 16-06-2010 09:40:48

Yo tuve el mismo problema y lo solucioné así:

Código Delphi [-]
 
procedure TF_Camions.JvDBGrid2DrawColumnCell(Sender: TObject;
  const Rect: TRect; DataCol: Integer; Column: TColumn;
  State: TGridDrawState);
begin
        If F_ModulDades.Camions_AuxACTUAL.Value = 'N' then
        begin
                JVDBGrid2.Canvas.Brush.Color := clRed;
                JVDBGrid2.DefaultDrawColumnCell(rect,DataCol,Column,State);
        end;
end;

Cada vez que entro en el grid, me pinta la fila en rojo si el valor vale 'N'

Espero te sirva

Josep

Neftali [Germán.Estévez] 16-06-2010 10:01:13

Coincido con Román, creo que en el primer código que pusiste debería bastar con cambiar gdFocused por gdSelected.

El hecho de que lo haga con la primera columna es porque tienes el dgRowSelect a True y en ese caso la columna que toma el foco (por decirlo así) es la primera. Si pones esa propiedad a False, te pasará lo mismo, pero siempre con la columna cuya celda tenga el foco.

pablopessoa 16-06-2010 19:47:10

Muchisimas Gracias a todos!!
Primero probe la solucion de Roman ya que era la que me producia menor cambio en el codigo y salio de diez!!
De todos modos jafera te agradezco mucho tu aporte. Que al final no haya utilizado tu solucion no le resta merito a tu intencion.
Saludos!

BlueSteel 25-11-2010 17:57:18

Hola Amigos

Revisando este hilo para sacar un truquito y funciono super....

ahora tengo otra consulta... como se condiciona para pintar las filas de forma intermedia de todo el DbGrid? algo así como pintar las impares... o las pares???

Bueno, esto no esta sujeto a condicion del dato que tiene la Tabla...

Salu2:p:D

Neftali [Germán.Estévez] 25-11-2010 18:12:11

En mi caso utilizo una comprobación como esta:

Código Delphi [-]
          ....
          // FILAS ALTERNADAS....
          num := DataLink.DataSource.DataSet.RecNo;
          if ((num mod 2) = 0) then begin
            Self.Canvas.Brush.Color := Config.App.ColorAlternativo;
          end;

ecfisa 25-11-2010 21:02:14

Hola.

Aprovechando la propiedad RecNo al igual que Neftali, yo he utilizado esto:

Código Delphi [-]
   if Odd(DBGrid1.DataSource.DataSet.RecNo) then

Es una alternativa más ...


Saludos. :)

Neftali [Germán.Estévez] 26-11-2010 11:21:35

Cita:

Empezado por ecfisa (Mensaje 383294)
Es una alternativa más ...

Bueno, creo que es la misma, aunque la tuya es más elegante ;);)
La función Odd debe hacer algo así:

Código Delphi [-]
if ((num mod 2) = 0) then begin

ecfisa 26-11-2010 16:35:38

Hola Neftali.

Hacen prácticamente lo mismo, aunque evaluan condiciones diferentes.
Código Delphi [-]
  if ((num mod 2) = 0) then
es verdadera si num es par y
Código Delphi [-]
  if Odd(num) then
es verdadera si num es impar.

Pero para pintar las filas alternando dos colores cualquiera funciona perfectamente.


Saludos. :)

Neftali [Germán.Estévez] 26-11-2010 17:27:11

Cita:

Empezado por ecfisa (Mensaje 383383)
...para pintar las filas alternando dos colores cualquiera funciona perfectamente.

Sí, a eso me refería. :)

BlueSteel 26-11-2010 17:40:59

Cita:

Empezado por Neftali (Mensaje 383268)
En mi caso utilizo una comprobación como esta:

Código Delphi [-] .... // FILAS ALTERNADAS.... num := DataLink.DataSource.DataSet.RecNo; if ((num mod 2) = 0) then begin Self.Canvas.Brush.Color := Config.App.ColorAlternativo; end;


Hola Neftali

Estube provando con esto... y no me ha funcionado...

tengo lo siguiente
1.- Ejecuto el codigo en onDrawColumnCell
2.- Cree la variable Num de tipo Int
3.- Cambie DataLink por el nombre del DBGrid
4.- Cambie Config.App.ColorAlternativo por clMoneyGreen


En difinitiva... no me da el efecto.... el codigo que uso es asi:

Código Delphi [-]
     
num := DBGrid2.DataSource.DataSet.RecNo;
// num := Datos.AQ_AbonosVendidos.RecNo;    Si pruebo cualquiera de estas lineas el valor que entrega es el correcto
if ((num mod 2) = 0) then Self.Canvas.Brush.Color := clMoneyGreen;

igual.. voy a seguir intentando..

Salu2:p:D

Neftali [Germán.Estévez] 26-11-2010 18:20:31

1 Archivos Adjunto(s)
Revisa el ejemplo que te paso. Nos hemos dejado de indicarle que vuelva a pintar la fila. :o


BlueSteel 26-11-2010 22:46:56

Gracias Neftali

revise el ejemplo.. realice todo igual.... salvo 3 cosas:

cambiar el nombre del DBGrid... y de donde se obtienen los colores.

lo demás esta igual, pero no se por que no me pinta las filas.

si compilo tu ejemplo funciona bien.. pero quizas sea un bug de esos...

lo raro es que si quiero pintar las celdas que cumplan una condición si lo hace bien (en otro dbgrid)...

este es el codigo que utilizo...

Código Delphi [-]
procedure TTarjetas.DBGrid2DrawDataCell(Sender: TObject; const Rect: TRect;
  Field: TField; State: TGridDrawState);
var
  num : Integer;
begin
     num := Datos.AQ_AbonosVendidos.RecNo;
//     num := DBGrid2.DataSource.DataSet.RecNo;
     if ((num mod 2) = 0) then begin
        DBGrid2.Canvas.Brush.Color := clMoneyGreen;
        end
     else begin
          DBGrid2.Canvas.Brush.Color := clWindow;
     end;

    DBGrid2.DefaultDrawDataCell(Rect, Field, State);
end;

la proxima semana seguiré probando

Salu2:p:D y que tengan un buen fin de semana

Neftali [Germán.Estévez] 29-11-2010 13:31:11

¿Sobre qué Base de Datos trabajas y con qué componentes estás probando?
Hay componentes que no implementan el Recno y puede ser que te esté devolviendo -1; En ese caso el pintado no funcionaría.
Esta propiedad está pensada para que sea redefinido por los derivados de TDataSet, si los componentes ue usas no la han redefinido no funcionará este código.

roman 29-11-2010 17:09:56

Hay una forma de pintar alternadamente las filas sin depender del número de registro que consiste en calcular la fila a partir de la posición de la celda que se está dibujando (Rect.Top) y la altura de las filas.

No la he encontrado pero creo que es algo como esto:

Código Delphi [-]
type
  TExDBGrid = class(TDBGrid);

procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
  DataCol: Integer; Column: TColumn; State: TGridDrawState);
begin
  if Odd(Rect.Top div (TExDBGrid(DBGrid1).DefaultRowHeight + Integer(dgRowLines in DBGrid1.Options))) then
    DBGrid1.Canvas.Brush.Color := clMoneyGreen;

  DBGrid1.DefaultDrawColumnCell(Rect, DataCol, Column, State);
end;

procedure TForm1.MyTable1AfterScroll(DataSet: TDataSet);
begin
  DBGrid1.Refresh;
end;

Creo recordar que era algo más sencillo pues aquí hay que manejar el evento AfterScroll del DataSet que se esté usando. Pero por ahí va la idea.

// Saludos


La franja horaria es GMT +2. Ahora son las 07:52:44.

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