lyx_mirror/src/frontends/qt2/QLImage.h

79 lines
1.9 KiB
C
Raw Normal View History

// -*- C++ -*-
/**
* \file QLImage.h
* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
* \author Angus Leeming
* \author John Levon
*
* Full author contact details are available in file CREDITS.
*/
#ifndef QLIMAGE_H
#define QLIMAGE_H
#include "graphics/GraphicsImage.h"
#include <qimage.h>
namespace lyx {
namespace graphics {
class QLImage : public Image {
public:
/// Access to this class is through this static method.
static ImagePtr newImage();
/// Return the list of loadable formats.
static FormatList loadableFormats();
~QLImage();
QImage const & qimage() const { return transformed_; }
private:
/// Create a copy
virtual Image * clone_impl() const;
/// Get the image width
virtual unsigned int getWidth_impl() const;
/// Get the image height
virtual unsigned int getHeight_impl() const;
// FIXME Is the image drawable ?
virtual bool isDrawable_impl() const { return true; }
/**
* Load the image file into memory.
* The process is asynchronous, so this method starts the loading.
* When finished, the Image::finishedLoading signal is emitted.
*/
virtual void load_impl(std::string const & filename);
/**
* Finishes the process of modifying transformed_, using
* \c params to decide on color, grayscale etc.
* \returns true if successful.
*/
virtual bool setPixmap_impl(Params const & params);
/// Clip the image using params.
virtual void clip_impl(Params const & params);
/// Rotate the image using params.
virtual void rotate_impl(Params const & params);
/// Scale the image using params.
virtual void scale_impl(Params const & params);
/// Access to the class is through newImage() and clone.
QLImage();
///
QLImage(QLImage const &);
/// The original loaded image.
QImage original_;
/// The transformed image for display.
QImage transformed_;
};
} // namespace graphics
} // namespace lyx
#endif // QLIMAGE_H