I have a C++/CLI System::Windows::Forms::UserControl derived control which should only redraw (a small portion of) itself as new data is fed into it. For some reason though, the OnPaint mechanism is being called even when there’s nothing to cause it external to the app.
Here’s a snippet:
void Spectrogram::OnPaint(System::Windows::Forms::PaintEventArgs ^e)
{
// Overidden to stop the background being painted(?)
}
void Spectrogram::AddNewFFTData( float* data, int fataWidth )
{
Graphics^ gfx = CreateGraphics();
//now do some drawing
gfx->Dispose();
}
So I call the add data method to add some new data which should in theory write over the previous entry (which clears some highlighting) and write the new entry.
Back in the day I used to develop MFC/OpenGL apps and one of the first things I’d do would be to override the OnEraseBackground method. As far as I can see though, there’s no obvious way of stopping it being erased. What have I missed?
You may be looking for Control.OnPaintBackground(). I’ve had to override that to do nothing for a custom control I wrote to bring a legacy MFC control into a Winforms project. Otherwise it would paint the background on top of the MFC control’s paint job.
Essentially, in the .cpp:
On the prototype:
What rectangle is being passed in to you via the event args? Is the entire control being invalidated, or just a portion of it?