PDA

Pogčedajte punu verziju : [VB.NET][C#] Multicolor text u datagridview


Marcus
10. 05. 2009., 20:32
Treba mi pomoć da rešim menjanje boja odredjenog teksta unutar DataGridView ćeliji. Primer teksta:

123/56
23/544

Google me je bacio na more rešenja koja sam već probao i ne rade ono što ja želim - posebno ne kada je uključeno korišćenje Rectangle za iscrtavanje.

tesla
10. 05. 2009., 23:28
Primer teksta:

123/56
23/544



Da li je ti je ovo u jednoj ćeliji, ili su to dve posebne ćelije, ili je ovo pattern svaki drugi red, ili .... kako već?

Daj neki screenshot kako to treba da izgleda.

Edit: GridView ili DataGridView?

Marcus
10. 05. 2009., 23:44
U pitanju su dve ćelije recimo. Broj ćelija je neodredjen. Svaka ćelija sadrži po jedan red. Ovo u prethodnom obraćanju sam hteo da ilustrujem kako u jednoj ćeliji prva cifra može biti crvena a u drugoj druga cifra tj. zavisi od toga da li je cifra previše velika ili mala.Bitno mi je samo da je moguće u jednoj ćeliji odredjenu cifru predstaviti u drugoj boji.

Primer je recimo kolona Buildings (bez mini slike u ćeliji).

Poželjno je da bude dataGridView kontrola.


http://img413.imageshack.us/img413/8430/image1knf.jpg

miks
11. 05. 2009., 00:23
Ako bi mogao malo vise da objasnis problem koji imas kod postojecih resenja kao i koja resenja koristis.

Osnovno bi bilo da u cell paint dogadjaju odradis iscrtavanje, deo po deo stringa u zeljenim bojama. Pretpostavljam da to vec i radis, jedino jos mogu da predpostavim da imas mozda problema sa cell paddingom ili sa sirinom kolone (autosize prema sadrzaju).

tesla
11. 05. 2009., 02:21
Prvo, ova tema treba da stoji negde drugde, jer nema smisla da stoji pod Web Devoloping, kad je ovo Windows aplikacija. Molim moderatore ako mogu da je prebace gde treba.
Drugo, jedino do čega mogu da dođem je sledeće:
1. Napraviš data grid koji ti treba.
2. Iskopiraš taj grid.
3. U tom drugom iskopiranom gridu za širinu originalne kolone (u kojoj ti je ovo menjanje boja) npr. 100px, dodaš pored nje još jednu istu i dodeliš im po 50px.
4. Prvu od te dve kolone staviš aligment right, a za drugu kolonu left.
5. Na drugom gridu isključi header (ColumnHeadersVisible = False)
6. Stavi je iznad prvog grida da se poklopi tako da se vidi samo header prvog grida.
7. Na drugom gridu isključi border style cell-a (CellBorderStyle = None)
8. Sad ti ostaje da dinamički ( iz prve kolone oduzmeš desnu stranu (različita boja) i iz druge kolone oduzmeš levu stranu (različita boja) i da ih u tim prolazima i bojiš.

Ne poklapa se sa ovim primerom što si dao, ali će ti izgledati kao jedna ćelija centrirana po sredini.

Ove se u web formama odrađuje mnogo lakše sa template-ima.
Nadam se da je barem ideja jasna iako nisam pisao kod.

Vladimir Rodic
11. 05. 2009., 07:57
Prvo, ova tema treba da stoji negde drugde, jer nema smisla da stoji pod Web Devoloping, kad je ovo Windows aplikacija.

Pre ce biti da je ovo web aplikacija, neka browser igrica (kao Travian, Ikariam... ) pogledaj koliko treba za Town Hall da se izgradi (preko 3 sata ) to bi tesko tako sporo islo u windows aplikaciji. Tako da ne treba da se premesta tema.

Marcus
11. 05. 2009., 08:28
Ako bi mogao malo vise da objasnis problem koji imas kod postojecih resenja kao i koja resenja koristis.

Osnovno bi bilo da u cell paint dogadjaju odradis iscrtavanje, deo po deo stringa u zeljenim bojama. Pretpostavljam da to vec i radis, jedino jos mogu da predpostavim da imas mozda problema sa cell paddingom ili sa sirinom kolone (autosize prema sadrzaju).

Ovo mi se svidja kao ideja. Ne nisam se snašao s tim iscrtavanjem deo po deo. To bi mi odgovaralo ako bi moglo da se primeni kao funkcija u kojoj bi bacio odredjeni string, unutar funkcije nekako povadio vrednosti i odlučio koja vrednost ide u koju boju i to vratio nazad kao obojenu ćeliju. Ako imaš neki deo koda, to bi mi baš pomoglo. :please:

miks
11. 05. 2009., 20:27
Ovo je link (http://windowsclient.net/downloads/folders/applications/entry1338.aspx) za Outlook Clone, u sredini za prikaz liste mail-ova koristi se custom datagridview, u fajlu "Custom Controls\MessageList.cs" pronaci ce kako su celije iscrtane.

Za tvoj slucaj mozes da podelis string na delove koje ce se prikazati u razlicitim bojama, uradis "measure string" (ili kako se vec zove funkcija) i iscrtavas deo po deo, svaki sledeci deo na kraj prethodnog.

Marcus
11. 05. 2009., 21:19
@ miks
Upravo sam pogledao. Izgleda da je to ono pravo. Samo malo da promenim par linija :) Hvala

tesla
11. 05. 2009., 22:14
Hvala i u moje ime. Biću slobodan da ostavim deo koda koji je bitan za rešavanje ovog problema.

private void dataGridView1_CellPainting(object sender, DataGridViewCellPaintingEventArgs e)
{
if ((e.ColumnIndex == 1) && (e.RowIndex >= 0))
{
// Draw Merged Cell
Graphics g = e.Graphics;
bool selected = ((e.State & DataGridViewElementStates.Selected) == DataGridViewElementStates.Selected);
Color fcolor = (selected ? e.CellStyle.SelectionForeColor : e.CellStyle.ForeColor);
Color bcolor = (selected ? e.CellStyle.SelectionBackColor : e.CellStyle.BackColor);
Font font = e.CellStyle.Font;

if (!(this.messageBS[e.RowIndex] as MailMessage).Read)
{
font = new Font(font, FontStyle.Bold);
}

// Get size information
string from = (this.messageBS[e.RowIndex] as MailMessage).From;
string subject = (this.messageBS[e.RowIndex] as MailMessage).Subject;
Size size = TextRenderer.MeasureText(e.Graphics, from, font);

// Note that this always aligns top, right
// Also this should use the ClipBounds but that is not currently working
int x = e.CellBounds.Left + e.CellStyle.Padding.Left;
int y = e.CellBounds.Top + e.CellStyle.Padding.Top;
int width = e.CellBounds.Width - (e.CellStyle.Padding.Left + e.CellStyle.Padding.Right);
int height = size.Height + (e.CellStyle.Padding.Top + e.CellStyle.Padding.Bottom);

// Draw background
g.FillRectangle(new SolidBrush(bcolor), e.CellBounds);

// Draw first line
TextRenderer.DrawText(e.Graphics, from, font, new Rectangle(x, y, width, height), fcolor, TextFormatFlags.PreserveGraphicsClipping | TextFormatFlags.EndEllipsis);

// Use grey for second line if not selected
if (!selected)
{
fcolor = Color.Gray;
}

// Reset font and y location
font = e.CellStyle.Font;
y = y + height - 1;

TextRenderer.DrawText(e.Graphics, subject, font, new Rectangle(x, y, width, height), fcolor, TextFormatFlags.PreserveGraphicsClipping | TextFormatFlags.EndEllipsis);

// Let them know we handled it
e.Handled = true;
}
else if ((e.ColumnIndex == 0) && (e.RowIndex >= 0))
{
e.Paint(e.ClipBounds, e.PaintParts & ~DataGridViewPaintParts.Focus);
e.Handled = true;
}
}