From 29e3a03b63e2821889f9124d4d977c8cb9119d1d Mon Sep 17 00:00:00 2001 From: Angus Leeming Date: Mon, 5 Apr 2004 11:59:14 +0000 Subject: [PATCH] Squash bug 1372: Misleading graphics label when deactivating lyx view. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@8601 a592a061-630c-0410-9148-cb99ea01b6c8 --- src/insets/ChangeLog | 7 +++++++ src/insets/insetgraphics.C | 1 - src/insets/render_graphic.C | 37 ++++++++++++++++++++++++------------- 3 files changed, 31 insertions(+), 14 deletions(-) diff --git a/src/insets/ChangeLog b/src/insets/ChangeLog index b80fc0a0eb..a2c81c2ae6 100644 --- a/src/insets/ChangeLog +++ b/src/insets/ChangeLog @@ -1,3 +1,10 @@ +2004-05-04 Angus Leeming + + * insetgraphics.C: remove unused header file "lyxrc.h". + + * render_graphic.C: squash bug 1372: Misleading graphics label when + deactivating lyx view. + 2004-05-04 Angus Leeming * insetbibitem.C: diff --git a/src/insets/insetgraphics.C b/src/insets/insetgraphics.C index 53a8a7f817..730ddc4202 100644 --- a/src/insets/insetgraphics.C +++ b/src/insets/insetgraphics.C @@ -64,7 +64,6 @@ TODO #include "LaTeXFeatures.h" #include "lyx_main.h" #include "lyxlex.h" -#include "lyxrc.h" #include "metricsinfo.h" #include "outputparams.h" diff --git a/src/insets/render_graphic.C b/src/insets/render_graphic.C index 1da739124f..72639def88 100644 --- a/src/insets/render_graphic.C +++ b/src/insets/render_graphic.C @@ -16,6 +16,7 @@ #include "gettext.h" #include "LColor.h" +#include "lyxrc.h" #include "metricsinfo.h" #include "frontends/font_metrics.h" @@ -82,8 +83,19 @@ boost::signals::connection RenderGraphic::connect(slot_type const & slot) const namespace { -string const statusMessage(graphics::ImageStatus status) +bool displayGraphic(graphics::Params const & params) { + return params.display != graphics::NoDisplay && + lyxrc.display_graphics != graphics::NoDisplay; +} + + +string const statusMessage(graphics::Params const & params, + graphics::ImageStatus status) +{ + if (!displayGraphic(params)) + return _("Not shown."); + switch (status) { case graphics::WaitingToLoad: return _("Not shown."); @@ -92,7 +104,7 @@ string const statusMessage(graphics::ImageStatus status) case graphics::Converting: return _("Converting to loadable format..."); case graphics::Loaded: - return _("Loaded into memory. Must now generate pixmap."); + return _("Loaded into memory. Generating pixmap..."); case graphics::ScalingEtc: return _("Scaling etc..."); case graphics::Ready: @@ -124,7 +136,7 @@ bool readyToDisplay(graphics::Loader const & loader) void RenderGraphic::metrics(MetricsInfo & mi, Dimension & dim) const { - bool image_ready = readyToDisplay(loader_); + bool image_ready = displayGraphic(params_) && readyToDisplay(loader_); dim.asc = image_ready ? loader_.image()->getHeight() : 50; dim.des = 0; @@ -144,7 +156,7 @@ void RenderGraphic::metrics(MetricsInfo & mi, Dimension & dim) const font_width = font_metrics::width(justname, msgFont); } - string const msg = statusMessage(loader_.status()); + string const msg = statusMessage(params_, loader_.status()); if (!msg.empty()) { msgFont.setSize(LyXFont::SIZE_TINY); font_width = std::max(font_width, @@ -160,18 +172,17 @@ void RenderGraphic::metrics(MetricsInfo & mi, Dimension & dim) const void RenderGraphic::draw(PainterInfo & pi, int x, int y) const { - if (params_.display != graphics::NoDisplay && - loader_.status() == graphics::WaitingToLoad) - loader_.startLoading(); - - if (params_.display != graphics::NoDisplay && - !loader_.monitoring()) - loader_.startMonitoring(); + if (displayGraphic(params_)) { + if (loader_.status() == graphics::WaitingToLoad) + loader_.startLoading(); + if (!loader_.monitoring()) + loader_.startMonitoring(); + } // This will draw the graphics. If the graphics has not been // loaded yet, we draw just a rectangle. - if (readyToDisplay(loader_)) { + if (displayGraphic(params_) && readyToDisplay(loader_)) { pi.pain.image(x + InsetOld::TEXT_TO_INSET_OFFSET, y - dim_.asc, dim_.wid - 2 * InsetOld::TEXT_TO_INSET_OFFSET, @@ -198,7 +209,7 @@ void RenderGraphic::draw(PainterInfo & pi, int x, int y) const } // Print the message. - string const msg = statusMessage(loader_.status()); + string const msg = statusMessage(params_, loader_.status()); if (!msg.empty()) { msgFont.setSize(LyXFont::SIZE_TINY); pi.pain.text(x + InsetOld::TEXT_TO_INSET_OFFSET + 6,