diff options
| author | louis <louis.braun@gmx.de> | 2013-09-18 10:46:16 +0200 | 
|---|---|---|
| committer | louis <louis.braun@gmx.de> | 2013-09-18 10:46:16 +0200 | 
| commit | 150767e987edd810053fbf44d8e840eb30930c6b (patch) | |
| tree | ad46fd1c0e346aff4ea1565a2623123e660babf5 | |
| parent | 8cac48f1606c6a48226141dd94a59101dd10b1e0 (diff) | |
| download | skin-nopacity-150767e987edd810053fbf44d8e840eb30930c6b.tar.gz skin-nopacity-150767e987edd810053fbf44d8e840eb30930c6b.tar.bz2 | |
improved function to float text around poster in textwindow
| -rw-r--r-- | HISTORY | 1 | ||||
| -rw-r--r-- | helpers.c | 31 | ||||
| -rw-r--r-- | textwindow.c | 119 | ||||
| -rw-r--r-- | textwindow.h | 4 | 
4 files changed, 91 insertions, 64 deletions
| @@ -283,3 +283,4 @@ Version 0.1.4    series in a folder two or three directories above the actual recording    folders. If a manual poster is found, all tvscraper information is ignored.  - changed narrow recordings menu style +- improved function to float text around poster in textwindow @@ -108,4 +108,35 @@ static std::string CutText(std::string text, int width, const cFont *font) {          }      }      return cuttedText; +} + +class splitstring : public std::string { +    std::vector<std::string> flds; +public: +    splitstring(const char *s) : std::string(s) { }; +    std::vector<std::string>& split(char delim, int rep=0); +}; + +// split: receives a char delimiter; returns a vector of strings +// By default ignores repeated delimiters, unless argument rep == 1. +std::vector<std::string>& splitstring::split(char delim, int rep) { +    if (!flds.empty()) flds.clear();  // empty vector if necessary +    std::string work = data(); +    std::string buf = ""; +    int i = 0; +    while (i < work.length()) { +        if (work[i] != delim) +            buf += work[i]; +        else if (rep == 1) { +            flds.push_back(buf); +            buf = ""; +        } else if (buf.length() > 0) { +            flds.push_back(buf); +            buf = ""; +        } +        i++; +    } +    if (!buf.empty()) +        flds.push_back(buf); +    return flds;  }
\ No newline at end of file diff --git a/textwindow.c b/textwindow.c index 0277f29..9a65ac8 100644 --- a/textwindow.c +++ b/textwindow.c @@ -223,23 +223,22 @@ void cNopacityTextWindow::SetEvent(const cEvent *event) {          widthTextHeader -= config.epgImageWidth;      }      //Title -    y = DrawTextWrapper(event->Title(), widthTextHeader, y, border, fontHeader, Theme.Color(clrMenuFontDetailViewHeaderTitle)); +    y = DrawTextWrapper(event->Title(), widthTextHeader, y, border, fontHeader, Theme.Color(clrMenuFontDetailViewHeaderTitle), height);      //Short Text -    y = DrawTextWrapper(event->ShortText(), widthTextHeader, y, border, font, Theme.Color(clrMenuFontDetailViewHeader)); +    y = DrawTextWrapper(event->ShortText(), widthTextHeader, y, border, font, Theme.Color(clrMenuFontDetailViewHeader), height);      y += fontHeader->Height();      //Description -    int maxHeight = height - y;      if (hasPoster && (y < (border + posterHeight))) {          int heightNarrow = border + posterHeight - y;          DrawTextWrapperFloat(event->Description(),                                widthTextHeader, widthText, y, heightNarrow, -                             border, font, Theme.Color(clrMenuFontDetailViewText), maxHeight); +                             border, font, Theme.Color(clrMenuFontDetailViewText), height);      } else if (epgImageFound && (y < (border + config.epgImageHeight))) {          y = border + config.epgImageHeight; -        DrawTextWrapper(event->Description(), widthText, y, border, font, Theme.Color(clrMenuFontDetailViewText), maxHeight); +        DrawTextWrapper(event->Description(), widthText, y, border, font, Theme.Color(clrMenuFontDetailViewText), height);      } else { -        DrawTextWrapper(event->Description(), widthText, y, border, font, Theme.Color(clrMenuFontDetailViewText), maxHeight); +        DrawTextWrapper(event->Description(), widthText, y, border, font, Theme.Color(clrMenuFontDetailViewText), height);      }  } @@ -282,99 +281,95 @@ void cNopacityTextWindow::SetRecording(const cRecording *recording) {      else              recTitle = recording->Name();      //Title -    y = DrawTextWrapper(*recTitle, widthTextHeader, y, border, fontHeader, Theme.Color(clrMenuFontDetailViewHeaderTitle)); +    y = DrawTextWrapper(*recTitle, widthTextHeader, y, border, fontHeader, Theme.Color(clrMenuFontDetailViewHeaderTitle), height);      //Short Text      if (!isempty(info->ShortText())) { -        y = DrawTextWrapper(info->ShortText(), widthTextHeader, y, border, font, Theme.Color(clrMenuFontDetailViewHeader)); +        y = DrawTextWrapper(info->ShortText(), widthTextHeader, y, border, font, Theme.Color(clrMenuFontDetailViewHeader), height);      }      y += fontHeader->Height();      //Description -    int maxHeight = height - y;      if ((hasPoster || hasManualPoster) && (y < (border + posterHeight))) {          int heightNarrow = border + posterHeight - y;          DrawTextWrapperFloat(recording->Info()->Description(),                               widthTextHeader, widthText, y, heightNarrow, -                             border, font, Theme.Color(clrMenuFontDetailViewText), maxHeight); +                             border, font, Theme.Color(clrMenuFontDetailViewText), height);      } else if (recImageFound && (y < (border + config.epgImageHeight))) {          y = border + config.epgImageHeight; -        DrawTextWrapper(recording->Info()->Description(), widthText, y, border, font, Theme.Color(clrMenuFontDetailViewText), maxHeight); +        DrawTextWrapper(recording->Info()->Description(), widthText, y, border, font, Theme.Color(clrMenuFontDetailViewText), height);      } else { -        DrawTextWrapper(recording->Info()->Description(), widthText, y, border, font, Theme.Color(clrMenuFontDetailViewText), maxHeight); +        DrawTextWrapper(recording->Info()->Description(), widthText, y, border, font, Theme.Color(clrMenuFontDetailViewText), height);      }  }  int cNopacityTextWindow::DrawTextWrapper(const char *text, int width, int top, int x,                                            const cFont *font, tColor color, int maxHeight) {      cTextWrapper wrapper; +    int lineHeight = font->Height();      wrapper.Set(text, font, width); -    int height = 2*font->Height();      int y = top;      for (int i=0; i < wrapper.Lines(); i++) { -        if (maxHeight && (height > maxHeight)) { +        if (y + 2*lineHeight > maxHeight) {              pixmap->DrawText(cPoint(x, y), "...", color, clrTransparent, font); +            y += 2*lineHeight;              break;          }          pixmap->DrawText(cPoint(x, y), wrapper.GetLine(i), color, clrTransparent, font); -        y += font->Height(); -        height += font->Height(); +        y += lineHeight;      }      return y;  } -int cNopacityTextWindow::DrawTextWrapperFloat(const char *text, int widthSmall, int widthFull,  +void cNopacityTextWindow::DrawTextWrapperFloat(const char *text, int widthSmall, int widthFull,                                                 int top, int heightNarrow, int x, const cFont *font,                                                 tColor color, int maxHeight) { +     +    if (!text) +        return;      int lineHeight = font->Height();      int numLinesNarrow = heightNarrow / lineHeight + 1; -    cTextWrapper test; -    test.Set(text, font, widthSmall); -    std::stringstream sstrTextTall; -    std::stringstream sstrTextFull; -    bool drawFull = false; -    int numEmptyLinesAtEnd = 0; -    for (int line = 0; line < test.Lines(); line++) { -        bool lineWrap = false; -        if (font->Width(test.GetLine(line)) < (widthSmall - 100)) { -            lineWrap = true; -        } -        if (line < numLinesNarrow) { -            sstrTextTall << test.GetLine(line); -            if (lineWrap) { -                sstrTextTall << "\n"; -            } else -                sstrTextTall << " "; -        } else { -            drawFull = true; -            sstrTextFull << test.GetLine(line); -            if (lineWrap) -                sstrTextFull << "\n"; -            else -                sstrTextFull << " "; -        } -    } -    cTextWrapper wrapperNarrow; -    wrapperNarrow.Set(sstrTextTall.str().c_str(), font, widthSmall); -    int height = 2*font->Height(); +    splitstring s(text); +    std::vector<std::string> flds = s.split('\n', 1); +    if (flds.size() < 1) +        return;      int y = top; -    for (int i=0; i < wrapperNarrow.Lines(); i++) { -        pixmap->DrawText(cPoint(x, y), wrapperNarrow.GetLine(i), color, clrTransparent, font); -        y += lineHeight; -        height += lineHeight; -    } -    if (drawFull) { -        cTextWrapper wrapper; -        wrapper.Set(sstrTextFull.str().c_str(), font, widthFull); -        for (int i=0; i < wrapper.Lines(); i++) { -            if (maxHeight && (height > maxHeight)) { -                pixmap->DrawText(cPoint(x, y), "...", color, clrTransparent, font); -                break; -            } -            pixmap->DrawText(cPoint(x, y), wrapper.GetLine(i), color, clrTransparent, font); +    int linesDrawn = 0; +    bool drawNarrow = true; +    for (int i=0; i<flds.size(); i++) { +        if (!flds[i].size()) { +            //empty line +            linesDrawn++;              y += lineHeight; -            height += lineHeight; +        } else { +            cTextWrapper wrapper; +            if (drawNarrow) { +                wrapper.Set((flds[i].c_str()), font, widthSmall); +                int newLines = wrapper.Lines(); +                //check if wrapper fits completely into narrow area +                if (linesDrawn + newLines < numLinesNarrow) { +                    y = DrawTextWrapper(flds[i].c_str(), widthSmall, y, x, font, color, maxHeight); +                    linesDrawn += newLines; +                } else { +                    //this wrapper has to be splitted +                    std::stringstream sstrTextTall; +                    std::stringstream sstrTextFull; +                    for (int line = 0; line < wrapper.Lines(); line++) { +                        if (line + linesDrawn < numLinesNarrow) { +                            sstrTextTall << wrapper.GetLine(line) << " "; +                        } else { +                            sstrTextFull << wrapper.GetLine(line) << " "; +                        } +                    } +                    y = DrawTextWrapper(sstrTextTall.str().c_str(), widthSmall, y, x, font, color, maxHeight); +                    y = DrawTextWrapper(sstrTextFull.str().c_str(), widthFull, y, x, font, color, maxHeight); +                    drawNarrow = false; +                } +            } else { +                if (y > maxHeight) +                    break; +                y = DrawTextWrapper(flds[i].c_str(), widthFull, y, x, font, color, maxHeight); +            }          }      } -    return y;  }  void cNopacityTextWindow::DrawPoster(int border) { diff --git a/textwindow.h b/textwindow.h index 9629c11..2be9142 100644 --- a/textwindow.h +++ b/textwindow.h @@ -27,8 +27,8 @@ private:      void CreatePixmapFullScreen(void);      void DrawText(int border, int left);      void DrawPoster(int border); -    int DrawTextWrapper(const char *text, int width, int top, int x, const cFont *font, tColor color, int maxHeight = 0); -    int DrawTextWrapperFloat(const char *text, int widthSmall, int widthFull, int top, int heightNarrow, int x, const cFont *font, tColor color, int maxHeight); +    int DrawTextWrapper(const char *text, int width, int top, int x, const cFont *font, tColor color, int maxHeight); +    void DrawTextWrapperFloat(const char *text, int widthSmall, int widthFull, int top, int heightNarrow, int x, const cFont *font, tColor color, int maxHeight);      void DoSleep(int duration);      virtual void Action(void);      void ScaleVideoWindow(void); | 
