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:
2012-10-27 16:49:31 +02:00
parent 80ffab8999
commit ce00b0b4a0
2 changed files with 28 additions and 51 deletions

View File

@@ -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);
}; };

View File

@@ -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)