mirror of
https://github.com/tuxbox-neutrino/neutrino.git
synced 2025-08-29 16:31:11 +02:00
CComponentsInfoBox: paint text with innstance of CComponentsText
This should be a stable state for painting info boxes in gui parts. This fix also an automaticaly correction of font size changes while runtime.
This commit is contained in:
@@ -245,6 +245,7 @@ class CComponentsText : public CComponentsItem
|
|||||||
virtual inline void setText(const char* ctext, const int mode = ~CTextBox::AUTO_WIDTH, Font* font_text = NULL){ct_text = ctext; ct_text_mode = mode, ct_font = font_text;};
|
virtual inline void setText(const char* ctext, const int mode = ~CTextBox::AUTO_WIDTH, Font* font_text = NULL){ct_text = ctext; ct_text_mode = mode, ct_font = font_text;};
|
||||||
virtual inline void setText(const std::string& stext, const int mode = ~CTextBox::AUTO_WIDTH, Font* font_text = NULL){ct_text = stext.c_str(); ct_text_mode = mode, ct_font = font_text;};
|
virtual inline void setText(const std::string& stext, const int mode = ~CTextBox::AUTO_WIDTH, Font* font_text = NULL){ct_text = stext.c_str(); ct_text_mode = mode, ct_font = font_text;};
|
||||||
virtual void setText(neutrino_locale_t locale_text, const int mode = ~CTextBox::AUTO_WIDTH, Font* font_text = NULL);
|
virtual void setText(neutrino_locale_t locale_text, const int mode = ~CTextBox::AUTO_WIDTH, Font* font_text = NULL);
|
||||||
|
virtual void removeLineBreaks(std::string& str);
|
||||||
};
|
};
|
||||||
|
|
||||||
#define INFO_BOX_Y_OFFSET 2
|
#define INFO_BOX_Y_OFFSET 2
|
||||||
@@ -252,7 +253,7 @@ class CComponentsInfoBox : public CComponentsText
|
|||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
int x_text, x_offset;
|
int x_text, x_offset;
|
||||||
|
CComponentsText * cctext;
|
||||||
CComponentsPicture * pic;
|
CComponentsPicture * pic;
|
||||||
std::string pic_default_name;
|
std::string pic_default_name;
|
||||||
|
|
||||||
@@ -274,7 +275,6 @@ class CComponentsInfoBox : public CComponentsText
|
|||||||
inline void setPicture(const std::string& picture_name){pic_name = picture_name;};
|
inline void setPicture(const std::string& picture_name){pic_name = picture_name;};
|
||||||
|
|
||||||
void paint(bool do_save_bg = CC_SAVE_SCREEN_YES);
|
void paint(bool do_save_bg = CC_SAVE_SCREEN_YES);
|
||||||
void removeLineBreaks(std::string& str);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@@ -305,8 +305,12 @@ void CComponentsText::initCCText()
|
|||||||
height = max(height, ct_font->getHeight());
|
height = max(height, ct_font->getHeight());
|
||||||
|
|
||||||
//text box dimensions
|
//text box dimensions
|
||||||
if (ct_box == NULL)
|
if (ct_box){
|
||||||
ct_box = new CBox();
|
//ensure that we have a new instance
|
||||||
|
delete ct_box;
|
||||||
|
ct_box = NULL;
|
||||||
|
}
|
||||||
|
ct_box = new CBox();
|
||||||
ct_box->iX = x+fr_thickness;
|
ct_box->iX = x+fr_thickness;
|
||||||
ct_box->iY = y+fr_thickness;
|
ct_box->iY = y+fr_thickness;
|
||||||
ct_box->iWidth = width-2*fr_thickness;
|
ct_box->iWidth = width-2*fr_thickness;
|
||||||
@@ -322,9 +326,7 @@ void CComponentsText::initCCText()
|
|||||||
ct_textbox->setWindowPos(ct_box);
|
ct_textbox->setWindowPos(ct_box);
|
||||||
ct_textbox->setTextBorderWidth(0);
|
ct_textbox->setTextBorderWidth(0);
|
||||||
ct_textbox->enableBackgroundPaint(false);
|
ct_textbox->enableBackgroundPaint(false);
|
||||||
//ct_textbox->setBackGroundColor(COL_RED);
|
|
||||||
ct_textbox->setBackGroundRadius(corner_rad-fr_thickness, corner_type);
|
ct_textbox->setBackGroundRadius(corner_rad-fr_thickness, corner_type);
|
||||||
//ct_textbox->movePosition(ct_box->iX, ct_box->iY);
|
|
||||||
ct_textbox->setTextColor(ct_col_text);
|
ct_textbox->setTextColor(ct_col_text);
|
||||||
ct_textbox->setWindowMaxDimensions(ct_box->iWidth, ct_box->iHeight);
|
ct_textbox->setWindowMaxDimensions(ct_box->iWidth, ct_box->iHeight);
|
||||||
ct_textbox->setWindowMinDimensions(ct_box->iWidth, ct_box->iHeight);
|
ct_textbox->setWindowMinDimensions(ct_box->iWidth, ct_box->iHeight);
|
||||||
@@ -373,6 +375,16 @@ void CComponentsText::hide(bool no_restore)
|
|||||||
hideContainer(no_restore);
|
hideContainer(no_restore);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//small helper to remove excessiv linbreaks
|
||||||
|
void CComponentsText::removeLineBreaks(std::string& str)
|
||||||
|
{
|
||||||
|
std::string::size_type spos = str.find_first_of("\r\n");
|
||||||
|
while (spos != std::string::npos) {
|
||||||
|
str.replace(spos, 1, " ");
|
||||||
|
spos = str.find_first_of("\r\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//-------------------------------------------------------------------------------------------------------
|
//-------------------------------------------------------------------------------------------------------
|
||||||
//sub class CComponentsInfoBox from CComponentsItem
|
//sub class CComponentsInfoBox from CComponentsItem
|
||||||
CComponentsInfoBox::CComponentsInfoBox()
|
CComponentsInfoBox::CComponentsInfoBox()
|
||||||
@@ -410,6 +422,7 @@ CComponentsInfoBox::~CComponentsInfoBox()
|
|||||||
clearSavedScreen();
|
clearSavedScreen();
|
||||||
clearCCText();
|
clearCCText();
|
||||||
delete pic;
|
delete pic;
|
||||||
|
delete cctext;
|
||||||
clear();
|
clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -420,6 +433,7 @@ void CComponentsInfoBox::initVarInfobox()
|
|||||||
|
|
||||||
//CComponentsInfoBox
|
//CComponentsInfoBox
|
||||||
pic = NULL;
|
pic = NULL;
|
||||||
|
cctext = NULL;
|
||||||
pic_name = "";
|
pic_name = "";
|
||||||
x_offset = 10;
|
x_offset = 10;
|
||||||
x_text = x+fr_thickness+x_offset;;
|
x_text = x+fr_thickness+x_offset;;
|
||||||
@@ -444,41 +458,11 @@ void CComponentsInfoBox::paintPicture()
|
|||||||
pic->paint(CC_SAVE_SCREEN_NO);
|
pic->paint(CC_SAVE_SCREEN_NO);
|
||||||
}
|
}
|
||||||
|
|
||||||
// void CComponentsInfoBox::paintText()
|
|
||||||
// {
|
|
||||||
// if (ct_box == NULL)
|
|
||||||
// ct_box = new CBox();
|
|
||||||
//
|
|
||||||
// ct_box->iX = x_text;
|
|
||||||
// ct_box->iY = y+fr_thickness;
|
|
||||||
//
|
|
||||||
// //text width and height
|
|
||||||
// ct_box->iWidth = width-2*fr_thickness-(x_text-x);
|
|
||||||
// ct_box->iHeight = height-2*fr_thickness;
|
|
||||||
//
|
|
||||||
// //init textbox
|
|
||||||
// if (ct_textbox == NULL) {
|
|
||||||
// ct_textbox = new CTextBox(ct_text, ct_font, ct_text_mode, ct_box, col_body);
|
|
||||||
// ct_textbox->setTextBorderWidth(0);
|
|
||||||
// ct_textbox->enableBackgroundPaint(false);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// //set properties
|
|
||||||
// ct_textbox->setTextFont(ct_font);
|
|
||||||
// ct_textbox->setWindowPos(ct_box);
|
|
||||||
// ct_textbox->setTextColor(ct_col_text);
|
|
||||||
//
|
|
||||||
// //set text
|
|
||||||
// string new_text = static_cast <string> (ct_text);
|
|
||||||
// if (ct_textbox->setText(&new_text))
|
|
||||||
// ct_textbox->paint();
|
|
||||||
// }
|
|
||||||
|
|
||||||
void CComponentsInfoBox::paint(bool do_save_bg)
|
void CComponentsInfoBox::paint(bool do_save_bg)
|
||||||
{
|
{
|
||||||
paintInit(do_save_bg);
|
paintInit(do_save_bg);
|
||||||
paintPicture();
|
paintPicture();
|
||||||
|
|
||||||
//define text x position
|
//define text x position
|
||||||
x_text = x+fr_thickness+x_offset;
|
x_text = x+fr_thickness+x_offset;
|
||||||
|
|
||||||
@@ -487,24 +471,17 @@ void CComponentsInfoBox::paint(bool do_save_bg)
|
|||||||
int pic_w = pic->getWidth();
|
int pic_w = pic->getWidth();
|
||||||
x_text += pic_w+x_offset;
|
x_text += pic_w+x_offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ct_text)
|
|
||||||
paintText(CC_SAVE_SCREEN_NO);
|
|
||||||
ct_text = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CComponentsInfoBox::removeLineBreaks(std::string& str)
|
//set text and paint text lines
|
||||||
{
|
if (ct_text){
|
||||||
std::string::size_type spos = str.find_first_of("\r\n");
|
if (cctext == NULL)
|
||||||
while (spos != std::string::npos) {
|
cctext = new CComponentsText();
|
||||||
str.replace(spos, 1, " ");
|
cctext->setText(ct_text, ct_text_mode, ct_font);
|
||||||
spos = str.find_first_of("\r\n");
|
cctext->setDimensionsAll(x_text, y+fr_thickness, width-(x_text-x+x_offset+fr_thickness), height-2*fr_thickness);
|
||||||
|
cctext->paint(CC_SAVE_SCREEN_NO);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//-------------------------------------------------------------------------------------------------------
|
//-------------------------------------------------------------------------------------------------------
|
||||||
//sub class CComponentsShapeSquare from CComponentsItem
|
//sub class CComponentsShapeSquare from CComponentsItem
|
||||||
CComponentsShapeSquare::CComponentsShapeSquare(const int x_pos, const int y_pos, const int w, const int h, bool has_shadow, fb_pixel_t color_frame, fb_pixel_t color_body, fb_pixel_t color_shadow)
|
CComponentsShapeSquare::CComponentsShapeSquare(const int x_pos, const int y_pos, const int w, const int h, bool has_shadow, fb_pixel_t color_frame, fb_pixel_t color_body, fb_pixel_t color_shadow)
|
||||||
|
Reference in New Issue
Block a user