mirror of
https://github.com/tuxbox-neutrino/neutrino.git
synced 2025-08-29 08:21:12 +02:00
driver/fb_window.cpp: remove private_data, move its members to class;
fix delete -> delete[]
This commit is contained in:
@@ -30,13 +30,6 @@
|
||||
#include <driver/fontrenderer.h>
|
||||
#include <driver/framebuffer.h>
|
||||
|
||||
class CPrivateData
|
||||
{
|
||||
public:
|
||||
CFrameBuffer * frameBuffer;
|
||||
fb_pixel_t * Background;
|
||||
};
|
||||
|
||||
CFBWindow::CFBWindow(const int _x, const int _y, const int _dx, const int _dy)
|
||||
{
|
||||
x = _x ;
|
||||
@@ -44,35 +37,28 @@ CFBWindow::CFBWindow(const int _x, const int _y, const int _dx, const int _dy)
|
||||
dx = _dx;
|
||||
dy = _dy;
|
||||
|
||||
private_data = (void *) new CPrivateData;
|
||||
((CPrivateData *)private_data)->frameBuffer = CFrameBuffer::getInstance();
|
||||
((CPrivateData *)private_data)->Background = new fb_pixel_t [_dx * _dy];
|
||||
if (((CPrivateData *)private_data)->Background != NULL)
|
||||
((CPrivateData *)private_data)->frameBuffer->SaveScreen(_x, _y, _dx, _dy, (fb_pixel_t *)((CPrivateData *)private_data)->Background);
|
||||
frameBuffer = CFrameBuffer::getInstance();
|
||||
Background = new fb_pixel_t [_dx * _dy];
|
||||
if (Background != NULL)
|
||||
frameBuffer->SaveScreen(_x, _y, _dx, _dy, Background);
|
||||
|
||||
}
|
||||
|
||||
CFBWindow::~CFBWindow(void)
|
||||
{
|
||||
if (private_data != NULL)
|
||||
{
|
||||
if (((CPrivateData *)private_data)->Background != NULL)
|
||||
((CPrivateData *)private_data)->frameBuffer->RestoreScreen(x, y, dx, dy, (fb_pixel_t *)((CPrivateData *)private_data)->Background);
|
||||
|
||||
delete ((CPrivateData *)private_data)->Background;
|
||||
delete ((CPrivateData *)private_data);
|
||||
private_data = NULL;
|
||||
}
|
||||
if (Background != NULL)
|
||||
frameBuffer->RestoreScreen(x, y, dx, dy, Background);
|
||||
delete[] Background;
|
||||
}
|
||||
|
||||
void CFBWindow::paintBoxRel(const int _x, const int _y, const int _dx, const int _dy, const color_t _col, int radius, int type)
|
||||
{
|
||||
((CPrivateData *)private_data)->frameBuffer->paintBoxRel(x + _x, y + _y, _dx, _dy, _col, radius, type);
|
||||
frameBuffer->paintBoxRel(x + _x, y + _y, _dx, _dy, _col, radius, type);
|
||||
}
|
||||
|
||||
bool CFBWindow::paintIcon(const char * const _filename, const int _x, const int _y, const int _h, const color_t _offset)
|
||||
{
|
||||
((CPrivateData *)private_data)->frameBuffer->paintIcon(_filename, x + _x, y + _y, _h, _offset);
|
||||
frameBuffer->paintIcon(_filename, x + _x, y + _y, _h, _offset);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@@ -1,8 +1,4 @@
|
||||
#ifndef __fb_window_h__
|
||||
#define __fb_window_h__
|
||||
/*
|
||||
* $Header: /cvs/tuxbox/apps/tuxbox/neutrino/src/driver/fb_window.h,v 1.3 2004/03/13 12:45:41 thegoodguy Exp $
|
||||
*
|
||||
* abstract fb_window class - d-box2 linux project
|
||||
*
|
||||
* (C) 2003 by thegoodguy <thegoodguy@berlios.de>
|
||||
@@ -23,15 +19,21 @@
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef __fb_window_h__
|
||||
#define __fb_window_h__
|
||||
|
||||
#include <driver/fontrenderer.h>
|
||||
#include <driver/framebuffer.h>
|
||||
|
||||
class CFBWindow
|
||||
{
|
||||
public:
|
||||
typedef unsigned int color_t;
|
||||
typedef void * font_t;
|
||||
typedef void * private_data_t;
|
||||
|
||||
private:
|
||||
private_data_t private_data;
|
||||
CFrameBuffer * frameBuffer;
|
||||
fb_pixel_t * Background;
|
||||
|
||||
public:
|
||||
int x, y; /* upper left corner */
|
||||
|
Reference in New Issue
Block a user