Zum Inhalt springen

Dialog verliert die Farbe


Babybaer

Empfohlene Beiträge

Hallo Leute,

ich habe ein Programm in MFC 7 geschrieben, in der ich den Hintergrund mit einer anderen Farbe hinterlege. Ganz sporadisch verliert aber das Fenster die Farbe. Das heißt ich kann es nicht nach vollziehen. Am Dlg ändert sich wärend der Farbänderung nichts. Es genügt manchmal ein neues Programm im Windows zu starten, damit der Effect auftritt. Vielleicht habt Ihr eine Idee.

Der Hintergrund wird im OnEraseBkgnd(CDC* pDC) erstellt.


BOOL CMyDlg::OnEraseBkgnd(CDC* pDC)
{
CRect rc;
GetClientRect(&rc);

CBrush brNew(BGTAB);
CBrush * brOldBrush = (CBrush*) pDC->SelectObject(&brNew);

pDC->PatBlt(0,0,rc.Width()-2,rc.Height()-2,PATCOPY);

pDC->SelectObject(brOldBrush);

return TRUE;
}
[/PHP]

Link zu diesem Kommentar
Auf anderen Seiten teilen

Hallo, wie geht´s Dir so?

Also für mich sieht´s so aus, daß Du zwar beim Löschen das ganze richtig machst, aber der Background-Brush hbrBackground bleibt erhalten, da vielleicht beim Blitten neuer Inhalte auf diesen zurückgegriffen wird. Vielleicht reicht es schon den Member auf das Handle vom neuen Brush zu setzen? Das sollte den gleichen Effekt haben. Deine Routine wird ja nur fürs Löschen mit einem neuen Brush auf die gleiche Art wie das vom System verwendet. Außerdem solltest Du anscheinend vorher UnrealizeObject() aufrufen, damit die Palette sicher gesetzt wird.

MSDN: If the hbrBackground member is NULL, your overridden version of OnEraseBkgnd should erase the background color. Your version should also align the origin of the intended brush with the CWnd coordinates by first calling UnrealizeObject for the brush, and then selecting the brush.
Link zu diesem Kommentar
Auf anderen Seiten teilen

Das war es leider nicht. Das liegt wohl auch daran, dass ich vergessen habe das CListCtrl zu erwähnen. Habe lange das Problem analysieren müssen bis ich darauf gekommen bin, das es ein BUG von MS ist. Leider funktioniert der Refesh des CListCtrl nicht wirklich, so das auch verschiedene Ctrl´s auf dem Window mit betroffen waren. Hier ist die Lösung.

schreib die Codezeile in OnPaint in die FensterDlg Klasse, und schon ist das Problem erledigt. Das glaube ich zumindest mal. Die Tests waren bis jetzt gut.

m_myListCtrl.RedrawWindow(NULL,NULL,RDW_FRAME | RDW_INVALIDATE | RDW_ERASE | RDW_UPDATENOW);

Link zu diesem Kommentar
Auf anderen Seiten teilen

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...