/** * @file llstatgraph.h * @brief Simpler compact stat graph with tooltip * * $LicenseInfo:firstyear=2002&license=viewerlgpl$ * Second Life Viewer Source Code * Copyright (C) 2010, Linden Research, Inc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; * version 2.1 of the License only. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * * Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA * $/LicenseInfo$ */ #ifndef LL_LLSTATGRAPH_H #define LL_LLSTATGRAPH_H #include "llview.h" #include "llframetimer.h" #include "v4color.h" #include "lltrace.h" class LLStatGraph : public LLView { public: struct ThresholdParams : public LLInitParam::Block { Mandatory value; Optional color; ThresholdParams() : value("value"), color("color", LLColor4::white) {} }; struct Thresholds : public LLInitParam::Block { Multiple threshold; Thresholds() : threshold("threshold") {} }; struct StatParams : public LLInitParam::ChoiceBlock { Alternative count_stat_float; Alternative count_stat_int; Alternative measurement_stat_float; Alternative measurement_stat_int; }; struct Params : public LLInitParam::Block { Mandatory stat; Optional label, units; Optional precision; Optional min, max; Optional per_sec; Optional value; Optional thresholds; Params() : stat("stat"), label("label"), units("units"), precision("precision", 0), min("min", 0.f), max("max", 125.f), per_sec("per_sec", true), value("value", 0.f), thresholds("thresholds") { Thresholds _thresholds; _thresholds.threshold.add(ThresholdParams().value(0.f).color(LLColor4::green)) .add(ThresholdParams().value(0.33f).color(LLColor4::yellow)) .add(ThresholdParams().value(0.5f).color(LLColor4::red)) .add(ThresholdParams().value(0.75f).color(LLColor4::red)); thresholds = _thresholds; } }; LLStatGraph(const Params&); void setMin(const F32 min); void setMax(const F32 max); virtual void draw(); /*virtual*/ void setValue(const LLSD& value); private: LLTrace::count_common_float_t* mNewStatFloatp; LLTrace::count_common_int_t* mNewStatIntp; BOOL mPerSec; F32 mValue; F32 mMin; F32 mMax; LLFrameTimer mUpdateTimer; std::string mLabel; std::string mUnits; S32 mPrecision; // Num of digits of precision after dot struct Threshold { Threshold(F32 value, const LLUIColor& color) : mValue(value), mColor(color) {} F32 mValue; LLUIColor mColor; bool operator <(const Threshold& other) { return mValue < other.mValue; } }; typedef std::vector threshold_vec_t; threshold_vec_t mThresholds; //S32 mNumThresholds; //F32 mThresholds[4]; //LLColor4 mThresholdColors[4]; }; #endif // LL_LLSTATGRAPH_H