Accueil > Forum > > > > Récupérer couleur / police dans une cellule de DBGrid
Récupérer couleur / police dans une cellule de DBGrid
jeudi 27 novembre 2008 à 11:29:46 |
Récupérer couleur / police dans une cellule de DBGrid

BernieNoel68
|
Bonjour a tous! J'ai un petit problème pour récupérer la couleur et la police d'une cellule dans un DBGrid. Je m'explique : pour rendre l'affichage plus agréable dans mon DBGrid je modifie la couleur et la police en fonction de la valeur d'un champ (via OnDrawColumnCell) ------------------------------------------------------------------------- procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect; DataCol: Integer; Column: TColumn; State: TGridDrawState);
begin
If TDBGrid(Sender).DataSource.DataSet.FieldByName('MonChamp').AsInteger=1Then begin
TDBGrid(Sender).Canvas.Brush.Color := clRed;
TDBGrid(Sender).Canvas.Font.Color := clWhite;
end else begin
TDBGrid(Sender).Canvas.Brush.Color := clWhite;
TDBGrid(Sender).Canvas.Font.Color := clBlack;
end;
TDBGrid(Sender).DefaultDrawColumnCell(rect,datacol,column,state);
end;
-------------------------------------------------------------------------
Jusque là pas de problème tout fonctionne!
Pour un export, je souhaite récupérer la valeur des champs (de ce coté la pas de problème, j'arrive a exporter le contenu de mon DBGrid) mais je souhaiterais récupérer également la couleur des cellules et la police!
J'ai essayé pas mal de truc, mais je n'arrive pas!
Avez vous une idée?
Merci d'avance!
|
|
vendredi 28 novembre 2008 à 00:23:46 |
Re : Récupérer couleur / police dans une cellule de DBGrid

beckerich
|
salut, comment parcours-tu les enregistrements pour l'export : par un ? while not Dataset.Eof do begin fonction d'export du record; Next; end; dans ce cas, tu dois faire les mêmes test que dans l'évènement DBGrid1DrawColumnCell
pour spécifier la couleur de la cellule et de la police.
Luc.
|
|
vendredi 28 novembre 2008 à 08:37:29 |
Re : Récupérer couleur / police dans une cellule de DBGrid

BernieNoel68
|
Merci de ta reponse! En effet ca aurait été la solution logique, mais ca ne va pas dans mon cas malheureusement. Le but est de faire une fonction générique d'export pour un DBGrid : procedure TForm1.ExportDBGrid( aGrid: TDBGrid ); begin
while not aGrid.DataSource.Dataset.Eof do begin //fonction d'export du record; Next; end;
end;
Donc je ne connait pas les critères de coloration du DBGrid et c'est bien là le problème! Il faudrait que je puisse les retrouver dynamiquement. Si queluqu'un a une idée je suis preneur!
|
|
vendredi 28 novembre 2008 à 12:01:41 |
Re : Récupérer couleur / police dans une cellule de DBGrid

cantador
|
bonjour, une idée comme ça.. pourquoi ne pas boucler sur les records du dbgrid lui même ?
cantador
|
|
vendredi 28 novembre 2008 à 12:07:49 |
Re : Récupérer couleur / police dans une cellule de DBGrid

beckerich
|
je suis entrain de bosser la dessus, cantador:
procedure TFM_DOCFOU.ACT_OOExecute(Sender: TObject); procedure TestCells; var sl: TStringList; i_row, i_col: integer; f_colenter: TNotifyEvent; begin i_row := 0; i_col := 0; sl := TStringList.Create; try DGD_TRFDOC.DataSource.DataSet.First; f_colenter := DGD_TRFDOC.OnColEnter; DGD_TRFDOC.OnColEnter := DGD_TRFDOCColEnter; try while not DGD_TRFDOC.DataSource.DataSet.Eof do begin for i_col := 0 to DGD_TRFDOC.Columns.Count - 1 do begin DGD_TRFDOC.SelectedIndex := i_col; sl.Add(format('ligne %d colonne %d texte %s', [i_row, i_col, DGD_TRFDOC.SelectedField.AsString])); // je ne trouve pas de propriété ou de méthode renvoyant la cellule active, on trouve bien la colonne (selectedindex) mais pas la cellule end; DGD_TRFDOC.DataSource.DataSet.Next; Inc(i_row); i_col := 0; end; finally DGD_TRFDOC.OnColEnter := f_colenter; end; sl.SaveToFile('toto.txt'); finally sl.Free; end; end; begin SCB_TRI.ItemIndex := 3; SCB_TRIClick(Self); with DTB_TRFDOC do begin TestCells; end; end;
|
|
vendredi 28 novembre 2008 à 12:27:17 |
Re : Récupérer couleur / police dans une cellule de DBGrid

beckerich
|
j'ai regardé l'implémentation de TCustomGrid dans l'unité Grids. Il n'y a pas de notion de cellule active dans les propriétés privées ou protégées. Il faudrait réécrire un composant en y ajoutant cette notion, mais bonjour le boulot, et puis la routine de BernieNoel68 ne serait plus indépendante...
j'abandonne, Luc.
|
|
vendredi 28 novembre 2008 à 13:32:16 |
Re : Récupérer couleur / police dans une cellule de DBGrid

cantador
|
et pourquoi pas un transtypage : TStringGrid(DBgrid1).Cells[ACol, ARow]
cantador
|
|
vendredi 28 novembre 2008 à 13:45:37 |
Re : Récupérer couleur / police dans une cellule de DBGrid

beckerich
|
property Cells [ACol, ARow: Integer]: string;
renvoie une chaîne de caractères et non pas une référence à une cellule 
luc
|
|
vendredi 28 novembre 2008 à 14:11:16 |
Re : Récupérer couleur / police dans une cellule de DBGrid

cantador
|
hé oui..le TDBGrid est trop pauvre en ce domaine... avec Le TcxGrid on a en revanche : procedure TFAffaire.cxGrid1DBTableView1 CustomDrawCell( Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); begin et procedure TFAffaire.cxGrid1DBTableView1 StylesGetContentStyle( Sender: TcxCustomGridTableView; ARecord: TcxCustomGridRecord; AItem: TcxCustomGridTableItem; out AStyle: TcxStyle); begin cantador 
|
|
Cette discussion est classée dans : récupérer, couleur, sender, police, tdbgrid
Répondre à ce message
Sujets en rapport avec ce message
Fenêtre pour police, couleur ... [ par Ramses__987 ]
Slt,Est-ce que qqn sait comment ouvrir la fenêtre de word, pour choisir la police, la couleur etc ... ? Mci d'avance, ++
Couleur moyenne d'une image [ par Paic_citron ]
Voila, j'aimerais récupérer la couleur moyenne d'une image, dans le but de réaliser un logiciel de Mozaik Art, c'est comme le Ascii Art, mais à la pla
dbgrid,couleur.... [ par exyacc ]
salut, j'utilise ce code pour changer la couleur de selection d'un dbgrid. procedure TForm1.RxDBGrid3DrawColumnCell(Sender:TObject;const Rect:TRect;D
Couleur de la police d'une ligne d'un ListView [ par rguef ]
Bonjour, Je cherche à changer la couleur de police d'une ligne dans un ListView ? Est-ce possible ?WezzaR
Récupérer la couleur d'une cellule stringGrid? [ par ataeallah ]
Bonjour,Comment récupérer la couleur d'une cellule dans une stringGrid (Par exemple la premier cellule de la deuxième ligne)?Merci d'avance.ABDA@+
Couleur separation colonne TDBGrid [ par patdimby ]
Bonjour a tousJe me demande comment peut on modifier la couleur de la ligne quisepare deux colonnes(champs) d'un TDBGrid.Merci de me repondre.
couleur et police d'un menu [ par may2008 ]
Bonjour, j'aimerais svoir s'il ya une possibilté de modifier couleur et police d'un menu créer en delphi 6Merci.
Changer l'apparence des noms des fichiers (couleur du texte) [ par smailyyy ]
Bonjour à tous ! Y a une application qui sert à changer la couleur des noms des fichier ou des dossiers (le nom du fichier en couleur). svp je veux bi
Livres en rapport
|
Derniers Blogs
UNE JOLIE-HORLOGE ET PAS QU'UN PEU !UNE JOLIE-HORLOGE ET PAS QU'UN PEU ! par neodante
Pour les possesseurs d'iPhone, ça y est Bijin Tokei - qui se traduit littéralement en Français par " Jolie Horloge " - est arrivé et GRATUITEMENT s'il vous plaît ! Après la version Tokyo, Hokkaido, night club, racing, Gal, "pour les mademoiselles'", . voi...
Cliquez pour lire la suite de l'article par neodante TECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICESTECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICES par ROMELARD Fabrice
Animé par: Gaetan Bouveret et Julien Chomarat Business Connectivity Services (BCS) est dans SharePoint 2010 la version 2 de Business Data Catalog (BDC dans SharePoint 2007). Il s'agit de la solution permettant de visualiser des données provenan...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice [DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE[DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE par orion
Comme de nombreux geek, je suis un grand amateur de série TV et je rate régulièrement des épisodes de mes séries préférés. Une solution s'offre à vous avec ce merveilleux site : Tv Gorge - www.tvgorge.com Moteur de recherche à l'appui, vous pouvez ...
Cliquez pour lire la suite de l'article par orion TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010 par ROMELARD Fabrice
Animé par: Vincent Bellet et Baptiste Giraudier La BI dans SharePoint 2010, Les nouveaux services d'application dans SP2010 et SQL Server Reporting services 2008 R2. La BI dans SharePoint est généralisée pour tous afin de permettre à tous les coll...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
DB-MAIN (9.1.0)DB-MAIN (9.1.0)DB-MAIN is a data-modeling and data-architecture tool. It is designed to help developers and anal... Cliquez pour télécharger DB-MAIN Xilisoft DPG Convertisseur (5.1.37.0120)XILISOFT DPG CONVERTISSEUR (5.1.37.0120)Xilisoft DPG Convertisseur offre aux fans de Nintendo DS une bonne solution leur permettant de dé... Cliquez pour télécharger Xilisoft DPG Convertisseur GraphicsGale (2.01.01)GRAPHICSGALE (2.01.01)GraphicsGale est un logiciel de PixelArt avec de nombreuse fonctionnalités permettant de réalisé ... Cliquez pour télécharger GraphicsGale Architecte 3D (Platinum 2010)ARCHITECTE 3D (PLATINUM 2010)Architecte 3D Platinium vous permet de concevoir facilement les plans votre future maison, de l'é... Cliquez pour télécharger Architecte 3D TeamViewer 5 (TeamViewer 5)TEAMVIEWER 5 (TEAMVIEWER 5)Dépanner un ami,expliquer une manipulation devient un jeu d'enfant.
Prise en main d'un autre ord... Cliquez pour télécharger TeamViewer 5
|