]> git.lyx.org Git - lyx.git/blobdiff - src/insets/render_graphic.C
* BufferParams:
[lyx.git] / src / insets / render_graphic.C
index 72639def888fc6cd809a3552e895cb2c1c3f9e2e..513b602d181edb1f71eb93852ac3996e32cf52f8 100644 (file)
 
 #include "gettext.h"
 #include "LColor.h"
+#include "lyx_main.h"
 #include "lyxrc.h"
 #include "metricsinfo.h"
 
-#include "frontends/font_metrics.h"
+#include "frontends/FontMetrics.h"
 #include "frontends/Painter.h"
 
 #include "graphics/GraphicsImage.h"
 
 #include "support/filetools.h"
 
-namespace graphics = lyx::graphics;
+#include <boost/bind.hpp>
 
-using lyx::support::AbsolutePath;
-using lyx::support::OnlyFilename;
+
+namespace lyx {
+
+using support::onlyFilename;
 
 using std::string;
 using std::auto_ptr;
 
 
-RenderGraphic::RenderGraphic()
-       : checksum_(0)
-{}
+RenderGraphic::RenderGraphic(InsetBase const * inset)
+{
+       loader_.connect(boost::bind(&LyX::updateInset,
+                                   boost::cref(LyX::cref()), inset));
+}
 
 
-RenderGraphic::RenderGraphic(RenderGraphic const & other)
+RenderGraphic::RenderGraphic(RenderGraphic const & other,
+                            InsetBase const * inset)
        : RenderBase(other),
          loader_(other.loader_),
-         params_(other.params_),
-         checksum_(0)
-{}
+         params_(other.params_)
+{
+       loader_.connect(boost::bind(&LyX::updateInset,
+                                   boost::cref(LyX::cref()), inset));
+}
 
 
-auto_ptr<RenderBase> RenderGraphic::clone() const
+auto_ptr<RenderBase> RenderGraphic::clone(InsetBase const * inset) const
 {
-       return auto_ptr<RenderBase>(new RenderGraphic(*this));
+       return auto_ptr<RenderBase>(new RenderGraphic(*this, inset));
 }
 
 
@@ -59,28 +67,11 @@ void RenderGraphic::update(graphics::Params const & params)
        params_ = params;
 
        if (!params_.filename.empty()) {
-               BOOST_ASSERT(AbsolutePath(params_.filename));
                loader_.reset(params_.filename, params_);
        }
 }
 
 
-bool RenderGraphic::hasFileChanged() const
-{
-       unsigned long const new_checksum = loader_.checksum();
-       bool const file_has_changed = checksum_ != new_checksum;
-       if (file_has_changed)
-               checksum_ = new_checksum;
-       return file_has_changed;
-}
-
-
-boost::signals::connection RenderGraphic::connect(slot_type const & slot) const
-{
-       return loader_.connect(slot);
-}
-
-
 namespace {
 
 bool displayGraphic(graphics::Params const & params)
@@ -88,39 +79,54 @@ bool displayGraphic(graphics::Params const & params)
        return params.display != graphics::NoDisplay &&
                lyxrc.display_graphics != graphics::NoDisplay;
 }
-       
 
-string const statusMessage(graphics::Params const & params,
+
+docstring const statusMessage(graphics::Params const & params,
                           graphics::ImageStatus status)
 {
+       docstring ret;
+
        if (!displayGraphic(params))
-               return _("Not shown.");
-
-       switch (status) {
-       case graphics::WaitingToLoad:
-               return _("Not shown.");
-       case graphics::Loading:
-               return _("Loading...");
-       case graphics::Converting:
-               return _("Converting to loadable format...");
-       case graphics::Loaded:
-               return _("Loaded into memory. Generating pixmap...");
-       case graphics::ScalingEtc:
-               return _("Scaling etc...");
-       case graphics::Ready:
-               return _("Ready to display");
-       case graphics::ErrorNoFile:
-               return _("No file found!");
-       case graphics::ErrorConverting:
-               return _("Error converting to loadable format");
-       case graphics::ErrorLoading:
-               return _("Error loading file into memory");
-       case graphics::ErrorGeneratingPixmap:
-               return _("Error generating the pixmap");
-       case graphics::ErrorUnknown:
-               return _("No image");
+               ret = _("Not shown.");
+       else {
+               switch (status) {
+               case graphics::WaitingToLoad:
+                       ret = _("Not shown.");
+                       break;
+               case graphics::Loading:
+                       ret = _("Loading...");
+                       break;
+               case graphics::Converting:
+                       ret = _("Converting to loadable format...");
+                       break;
+               case graphics::Loaded:
+                       ret = _("Loaded into memory. Generating pixmap...");
+                       break;
+               case graphics::ScalingEtc:
+                       ret = _("Scaling etc...");
+                       break;
+               case graphics::Ready:
+                       ret = _("Ready to display");
+                       break;
+               case graphics::ErrorNoFile:
+                       ret = _("No file found!");
+                       break;
+               case graphics::ErrorConverting:
+                       ret = _("Error converting to loadable format");
+                       break;
+               case graphics::ErrorLoading:
+                       ret = _("Error loading file into memory");
+                       break;
+               case graphics::ErrorGeneratingPixmap:
+                       ret = _("Error generating the pixmap");
+                       break;
+               case graphics::ErrorUnknown:
+                       ret = _("No image");
+                       break;
+               }
        }
-       return string();
+
+       return ret;
 }
 
 
@@ -134,7 +140,7 @@ bool readyToDisplay(graphics::Loader const & loader)
 } // namespace anon
 
 
-void RenderGraphic::metrics(MetricsInfo & mi, Dimension & dim) const
+bool RenderGraphic::metrics(MetricsInfo & mi, Dimension & dim) const
 {
        bool image_ready = displayGraphic(params_) && readyToDisplay(loader_);
 
@@ -150,23 +156,28 @@ void RenderGraphic::metrics(MetricsInfo & mi, Dimension & dim) const
                LyXFont msgFont(mi.base.font);
                msgFont.setFamily(LyXFont::SANS_FAMILY);
 
-               string const justname = OnlyFilename(params_.filename);
+               // FIXME UNICODE
+               docstring const justname = 
+                       from_utf8(onlyFilename(params_.filename.absFilename()));
                if (!justname.empty()) {
                        msgFont.setSize(LyXFont::SIZE_FOOTNOTE);
-                       font_width = font_metrics::width(justname, msgFont);
+                       font_width = theFontMetrics(msgFont)
+                               .width(justname);
                }
 
-               string const msg = statusMessage(params_, loader_.status());
+               docstring const msg = statusMessage(params_, loader_.status());
                if (!msg.empty()) {
                        msgFont.setSize(LyXFont::SIZE_TINY);
                        font_width = std::max(font_width,
-                                             font_metrics::width(msg, msgFont));
+                               theFontMetrics(msgFont).width(msg));
                }
 
                dim.wid = std::max(50, font_width + 15);
        }
 
+       bool const changed = dim_ != dim;
        dim_ = dim;
+       return changed;
 }
 
 
@@ -199,17 +210,17 @@ void RenderGraphic::draw(PainterInfo & pi, int x, int y) const
                // Print the file name.
                LyXFont msgFont = pi.base.font;
                msgFont.setFamily(LyXFont::SANS_FAMILY);
-               string const justname = OnlyFilename(params_.filename);
+               string const justname = onlyFilename(params_.filename.absFilename());
 
                if (!justname.empty()) {
                        msgFont.setSize(LyXFont::SIZE_FOOTNOTE);
                        pi.pain.text(x + InsetOld::TEXT_TO_INSET_OFFSET + 6,
-                                  y - font_metrics::maxAscent(msgFont) - 4,
-                                  justname, msgFont);
+                                  y - theFontMetrics(msgFont).maxAscent() - 4,
+                                  from_utf8(justname), msgFont);
                }
 
                // Print the message.
-               string const msg = statusMessage(params_, loader_.status());
+               docstring const msg = statusMessage(params_, loader_.status());
                if (!msg.empty()) {
                        msgFont.setSize(LyXFont::SIZE_TINY);
                        pi.pain.text(x + InsetOld::TEXT_TO_INSET_OFFSET + 6,
@@ -217,3 +228,6 @@ void RenderGraphic::draw(PainterInfo & pi, int x, int y) const
                }
        }
 }
+
+
+} // namespace lyx