#include "lyxrc.h"
#include "metricsinfo.h"
-#include "frontends/font_metrics.h"
+#include "frontends/FontMetrics.h"
#include "frontends/Painter.h"
#include "graphics/GraphicsImage.h"
#include <boost/bind.hpp>
-namespace graphics = lyx::graphics;
-using lyx::support::AbsolutePath;
-using lyx::support::OnlyFilename;
+namespace lyx {
+
+using support::onlyFilename;
using std::string;
using std::auto_ptr;
params_ = params;
if (!params_.filename.empty()) {
- BOOST_ASSERT(AbsolutePath(params_.filename));
loader_.reset(params_.filename, params_);
}
}
}
-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;
}
} // 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_);
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;
}
// 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,
}
}
}
+
+
+} // namespace lyx