Imported existing code
This commit is contained in:
139
indra/newview/llconsole.h
Normal file
139
indra/newview/llconsole.h
Normal file
@@ -0,0 +1,139 @@
|
||||
/**
|
||||
* @file llconsole.h
|
||||
* @brief a simple console-style output device
|
||||
*
|
||||
* $LicenseInfo:firstyear=2001&license=viewergpl$
|
||||
*
|
||||
* Copyright (c) 2001-2009, Linden Research, Inc.
|
||||
*
|
||||
* Second Life Viewer Source Code
|
||||
* The source code in this file ("Source Code") is provided by Linden Lab
|
||||
* to you under the terms of the GNU General Public License, version 2.0
|
||||
* ("GPL"), unless you have obtained a separate licensing agreement
|
||||
* ("Other License"), formally executed by you and Linden Lab. Terms of
|
||||
* the GPL can be found in doc/GPL-license.txt in this distribution, or
|
||||
* online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
|
||||
*
|
||||
* There are special exceptions to the terms and conditions of the GPL as
|
||||
* it is applied to this Source Code. View the full text of the exception
|
||||
* in the file doc/FLOSS-exception.txt in this software distribution, or
|
||||
* online at
|
||||
* http://secondlifegrid.net/programs/open_source/licensing/flossexception
|
||||
*
|
||||
* By copying, modifying or distributing this software, you acknowledge
|
||||
* that you have read and understood your obligations described above,
|
||||
* and agree to abide by those obligations.
|
||||
*
|
||||
* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
|
||||
* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
|
||||
* COMPLETENESS OR PERFORMANCE.
|
||||
* $/LicenseInfo$
|
||||
*/
|
||||
|
||||
#ifndef LL_LLCONSOLE_H
|
||||
#define LL_LLCONSOLE_H
|
||||
|
||||
#include "llerrorcontrol.h" // For LLLineBuffer
|
||||
#include "llthread.h"
|
||||
#include "llview.h"
|
||||
#include "v4color.h"
|
||||
#include <deque>
|
||||
|
||||
class LLFontGL;
|
||||
class LLSD;
|
||||
|
||||
class LLConsole : public LLLineBuffer, public LLView
|
||||
{
|
||||
private:
|
||||
F32 mLinePersistTime; // Age at which to stop drawing.
|
||||
F32 mFadeTime; // Age at which to start fading
|
||||
LLFontGL* mFont;
|
||||
S32 mConsoleWidth;
|
||||
S32 mConsoleHeight;
|
||||
LLMutex mQueueMutex;
|
||||
LLTimer mTimer;
|
||||
|
||||
public:
|
||||
//A paragraph color segment defines the color of text in a line
|
||||
//of text that was received for console display. It has no
|
||||
//notion of line wraps, screen position, or the text it contains.
|
||||
//It is only the number of characters that are a color and the
|
||||
//color.
|
||||
struct ParagraphColorSegment
|
||||
{
|
||||
S32 mNumChars;
|
||||
LLColor4 mColor;
|
||||
};
|
||||
|
||||
//A line color segment is a chunk of text, the color associated
|
||||
//with it, and the X Position it was calculated to begin at
|
||||
//on the screen. X Positions are re-calculated if the
|
||||
//screen changes size.
|
||||
class LineColorSegment
|
||||
{
|
||||
public:
|
||||
LineColorSegment(LLWString text, LLColor4 color, F32 xpos) : mText(text), mColor(color), mXPosition(xpos) {}
|
||||
public:
|
||||
LLWString mText;
|
||||
LLColor4 mColor;
|
||||
F32 mXPosition;
|
||||
};
|
||||
|
||||
typedef std::list<LineColorSegment> line_color_segments_t;
|
||||
|
||||
typedef std::list<line_color_segments_t> lines_t;
|
||||
typedef std::list<ParagraphColorSegment> paragraph_color_segments_t;
|
||||
|
||||
//A paragraph is a processed element containing the entire text of the
|
||||
//message (used for recalculating positions on screen resize)
|
||||
//The time this message was added to the console output
|
||||
//The visual screen width of the longest line in this block
|
||||
//And a list of one or more lines which are used to display this message.
|
||||
class Paragraph
|
||||
{
|
||||
public:
|
||||
Paragraph (LLWString str, const LLColor4 &color, F32 add_time);
|
||||
void makeParagraphColorSegments ( const LLColor4 &color);
|
||||
void updateLines ( F32 screen_width, LLFontGL* font, bool force_resize=false );
|
||||
public:
|
||||
LLWString mParagraphText; //The entire text of the paragraph
|
||||
paragraph_color_segments_t mParagraphColorSegments;
|
||||
F32 mAddTime; //Time this paragraph was added to the display.
|
||||
F32 mMaxWidth; //Width of the widest line of text in this paragraph.
|
||||
lines_t mLines;
|
||||
|
||||
};
|
||||
|
||||
//The console contains a deque of paragraphs which represent the individual messages.
|
||||
typedef std::deque<Paragraph*> paragraph_t;
|
||||
paragraph_t mParagraphs;
|
||||
paragraph_t mNewParagraphs;
|
||||
|
||||
// Font size:
|
||||
// -1 = monospace, 0 means small, font size = 1 means big
|
||||
LLConsole(const std::string& name, const LLRect &rect,
|
||||
S32 font_size_index, F32 persist_time );
|
||||
~LLConsole();
|
||||
|
||||
// each line lasts this long after being added
|
||||
void setLinePersistTime(F32 seconds);
|
||||
|
||||
void reshape(S32 width, S32 height, BOOL called_from_parent = TRUE);
|
||||
|
||||
// -1 = monospace, 0 means small, font size = 1 means big
|
||||
void setFontSize(S32 size_index);
|
||||
|
||||
// From LLLineBuffer
|
||||
/*virtual*/ void clear();
|
||||
/*virtual*/ void addLine(const std::string& utf8line);
|
||||
|
||||
void addConsoleLine(const std::string& utf8line, const LLColor4 &color);
|
||||
void addConsoleLine(const LLWString& wline, const LLColor4 &color);
|
||||
|
||||
// Overrides
|
||||
/*virtual*/ void draw();
|
||||
};
|
||||
|
||||
extern LLConsole* gConsole;
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user