/*************************************************************************** * Copyright (C) 2006 by Massimiliano Torromeo * * massimiliano.torromeo@gmail.com * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * * (at your option) any later version. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ #include "textdialog.h" using namespace std; TextDialog::TextDialog(GMenu2X *gmenu2x, const string &title, const string &description, const string &icon, vector *text) { this->gmenu2x = gmenu2x; this->text = text; this->title = title; this->description = description; this->icon = icon; preProcess(); } void TextDialog::preProcess() { uint i=0; string row; while (isize()) { //clean this row row = trim(text->at(i)); //check if this row is not too long if (gmenu2x->font->getTextWidth(row)>(int)gmenu2x->resX-15) { vector words; split(words, row, " "); uint numWords = words.size(); //find the maximum number of rows that can be printed on screen while (gmenu2x->font->getTextWidth(row)>(int)gmenu2x->resX-15 && numWords>0) { numWords--; row = ""; for (uint x=0; x0) { //replace with the shorter version text->at(i) = row; //build the remaining text in another row row = ""; for (uint x=numWords; xinsert(text->begin()+i+1, row); } } i++; } } void TextDialog::drawText(vector *text, uint firstRow, uint rowsPerPage) { gmenu2x->s->setClipRect(0,41,gmenu2x->resX-10,gmenu2x->resY-60); for (uint i=firstRow; isize(); i++) { int rowY; if (text->at(i)=="----") { //draw a line rowY = 42+(int)((i-firstRow+0.5)*gmenu2x->font->getHeight()); gmenu2x->s->hline(5,rowY,gmenu2x->resX-16,255,255,255,130); gmenu2x->s->hline(5,rowY+1,gmenu2x->resX-16,0,0,0,130); } else { rowY = 42+(i-firstRow)*gmenu2x->font->getHeight(); gmenu2x->font->write(gmenu2x->s, text->at(i), 5, rowY); } } gmenu2x->s->clearClipRect(); gmenu2x->drawScrollBar(rowsPerPage,text->size(),firstRow,42,gmenu2x->resY-65); } void TextDialog::exec() { bool close = false; Surface bg(gmenu2x->bg); //link icon if (!fileExists(icon)) gmenu2x->drawTitleIcon("icons/ebook.png",true,&bg); else gmenu2x->drawTitleIcon(icon,false,&bg); gmenu2x->writeTitle(title,&bg); gmenu2x->writeSubTitle(description,&bg); gmenu2x->drawButton(&bg, "x", gmenu2x->tr["Exit"], gmenu2x->drawButton(&bg, "down", gmenu2x->tr["Scroll"], gmenu2x->drawButton(&bg, "up", "", 5)-10)); uint firstRow = 0, rowsPerPage = (gmenu2x->resY-60)/gmenu2x->font->getHeight(); while (!close) { bg.blit(gmenu2x->s,0,0); drawText(text, firstRow, rowsPerPage); gmenu2x->s->flip(); gmenu2x->input.update(); if ( gmenu2x->input[ACTION_UP ] && firstRow>0 ) firstRow--; if ( gmenu2x->input[ACTION_DOWN] && firstRow+rowsPerPagesize() ) firstRow++; if ( gmenu2x->input[ACTION_L ] ) { if (firstRow>=rowsPerPage-1) firstRow-= rowsPerPage-1; else firstRow = 0; } if ( gmenu2x->input[ACTION_R ] ) { if (firstRow+rowsPerPage*2-1size()) firstRow+= rowsPerPage-1; else firstRow = max(0,text->size()-rowsPerPage); } if ( gmenu2x->input[ACTION_START] || gmenu2x->input[ACTION_X] ) close = true; } }