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/fontrenderer.h>
|
||||||
#include <driver/framebuffer.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)
|
CFBWindow::CFBWindow(const int _x, const int _y, const int _dx, const int _dy)
|
||||||
{
|
{
|
||||||
x = _x ;
|
x = _x ;
|
||||||
@@ -44,35 +37,28 @@ CFBWindow::CFBWindow(const int _x, const int _y, const int _dx, const int _dy)
|
|||||||
dx = _dx;
|
dx = _dx;
|
||||||
dy = _dy;
|
dy = _dy;
|
||||||
|
|
||||||
private_data = (void *) new CPrivateData;
|
frameBuffer = CFrameBuffer::getInstance();
|
||||||
((CPrivateData *)private_data)->frameBuffer = CFrameBuffer::getInstance();
|
Background = new fb_pixel_t [_dx * _dy];
|
||||||
((CPrivateData *)private_data)->Background = new fb_pixel_t [_dx * _dy];
|
if (Background != NULL)
|
||||||
if (((CPrivateData *)private_data)->Background != NULL)
|
frameBuffer->SaveScreen(_x, _y, _dx, _dy, Background);
|
||||||
((CPrivateData *)private_data)->frameBuffer->SaveScreen(_x, _y, _dx, _dy, (fb_pixel_t *)((CPrivateData *)private_data)->Background);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CFBWindow::~CFBWindow(void)
|
CFBWindow::~CFBWindow(void)
|
||||||
{
|
{
|
||||||
if (private_data != NULL)
|
if (Background != NULL)
|
||||||
{
|
frameBuffer->RestoreScreen(x, y, dx, dy, Background);
|
||||||
if (((CPrivateData *)private_data)->Background != NULL)
|
delete[] Background;
|
||||||
((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;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CFBWindow::paintBoxRel(const int _x, const int _y, const int _dx, const int _dy, const color_t _col, int radius, int type)
|
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)
|
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;
|
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
|
* abstract fb_window class - d-box2 linux project
|
||||||
*
|
*
|
||||||
* (C) 2003 by thegoodguy <thegoodguy@berlios.de>
|
* (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
|
class CFBWindow
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
typedef unsigned int color_t;
|
typedef unsigned int color_t;
|
||||||
typedef void * font_t;
|
typedef void * font_t;
|
||||||
typedef void * private_data_t;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
private_data_t private_data;
|
CFrameBuffer * frameBuffer;
|
||||||
|
fb_pixel_t * Background;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
int x, y; /* upper left corner */
|
int x, y; /* upper left corner */
|
||||||
|
Reference in New Issue
Block a user