1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
|
//
// Copyright (C) 2015 Greg Landrum
//
// @@ All Rights Reserved @@
// This file is part of the RDKit.
// The contents are covered by the terms of the BSD license
// which is included in the file license.txt, found at the root
// of the RDKit source tree.
//
// derived from Dave Cosgrove's MolDraw2D
//
// This is a concrete class derived from MolDraw2D that uses RDKit to draw a
// molecule into a cairo drawing context
#include <RDGeneral/export.h>
#ifndef MOLDRAW2DCAIRO_H
#define MOLDRAW2DCAIRO_H
#include <cairo.h>
#include <GraphMol/MolDraw2D/MolDraw2D.h>
// ****************************************************************************
namespace RDKit {
class RDKIT_MOLDRAW2D_EXPORT MolDraw2DCairo : public MolDraw2D {
public:
// does not take ownership of the drawing context
MolDraw2DCairo(int width, int height, cairo_t *cr, int panelWidth = -1,
int panelHeight = -1, bool noFreetype = false)
: MolDraw2D(width, height, panelWidth, panelHeight), dp_cr(cr) {
cairo_reference(dp_cr);
df_noFreetype = noFreetype;
initTextDrawer(noFreetype);
}
MolDraw2DCairo(int width, int height, int panelWidth = -1,
int panelHeight = -1, bool noFreetype = false)
: MolDraw2D(width, height, panelWidth, panelHeight), dp_cr(nullptr) {
if (width > 0 && height > 0) {
initDrawing();
needs_init_ = false;
}
initTextDrawer(noFreetype);
df_noFreetype = noFreetype;
}
MolDraw2DCairo(const MolDraw2DCairo &) = delete;
MolDraw2DCairo(MolDraw2DCairo &&) = delete;
MolDraw2DCairo &operator=(const MolDraw2DCairo &) = delete;
MolDraw2DCairo &operator=(MolDraw2DCairo &&) = delete;
~MolDraw2DCairo() {
if (dp_cr) {
if (cairo_get_reference_count(dp_cr) > 0) {
cairo_destroy(dp_cr);
}
dp_cr = nullptr;
}
}
void setColour(const DrawColour &col) override;
// not sure if this goes here or if we should do a dtor since initDrawing() is
// called in the ctor,
// but we'll start here
void finishDrawing();
void drawLine(const Point2D &cds1, const Point2D &cds2,
bool rawCoords = false) override;
// void drawString( const std::string &str, const Point2D &cds );
void drawPolygon(const std::vector<Point2D> &cds,
bool rawCoords = false) override;
void clearDrawing() override;
void drawWavyLine(const Point2D &cds1, const Point2D &cds2,
const DrawColour &col1, const DrawColour &col2,
unsigned int nSegments = 16, double vertOffset = 0.05,
bool rawCoords = false) override;
// returns the PNG data in a string
std::string getDrawingText() const;
// writes the PNG data to a file
void writeDrawingText(const std::string &fName) const;
#if defined(WIN32) && !defined(RDK_BUILD_FREETYPE_SUPPORT)
bool supportsAnnotations() const override { return false; }
#endif
private:
cairo_t *dp_cr = nullptr;
bool df_noFreetype = false;
void updateMetadata(const ROMol &mol, int confId) override;
void updateMetadata(const ChemicalReaction &rxn) override;
void initDrawing() override;
void initTextDrawer(bool noFreetype) override;
std::string addMetadataToPNG(const std::string &png) const;
void updateMetadata(const ROMol &mol) const;
void updateMetadata(const ChemicalReaction &rxn) const;
};
} // namespace RDKit
#endif // MOLDRAW2DCAIRO_H
|