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
|
//
// Copyright (C) 2021-2023 David Cosgrove and other RDKit contributors
//
// @@ 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.
//
// Original author: David Cosgrove (CozChemIx Limited)
//
#include <GraphMol/RWMol.h>
#include <GraphMol/MolDraw2D/MolDraw2DDetails.h>
#include <GraphMol/MolDraw2D/DrawMolMCH.h>
namespace RDKit {
namespace MolDraw2D_detail {
// ****************************************************************************
DrawMolMCH::DrawMolMCH(
const ROMol &mol, const std::string &legend, int width, int height,
MolDrawOptions &drawOptions, DrawText &textDrawer,
const std::map<int, std::vector<DrawColour>> &highlight_atom_map,
const std::map<int, std::vector<DrawColour>> &highlight_bond_map,
const std::map<int, double> &highlight_radii,
const std::map<int, int> &highlight_linewidth_multipliers, int confId)
: DrawMol(mol, legend, width, height, drawOptions, textDrawer, nullptr,
nullptr, nullptr, nullptr, nullptr, &highlight_radii, confId),
mcHighlightAtomMap_(highlight_atom_map),
mcHighlightBondMap_(highlight_bond_map),
highlightLinewidthMultipliers_(highlight_linewidth_multipliers) {}
// ****************************************************************************
void DrawMolMCH::extractHighlights(double scale) {
DrawMol::extractHighlights(scale);
extractMCHighlights();
}
// ****************************************************************************
void DrawMolMCH::getAtomRadius(unsigned int atomIdx, double &xradius,
double &yradius) const {
xradius = drawOptions_.highlightRadius;
yradius = xradius;
if (highlightRadii_.find(atomIdx) != highlightRadii_.end()) {
xradius = highlightRadii_.find(atomIdx)->second;
yradius = xradius;
}
}
} // namespace MolDraw2D_detail
} // namespace RDKit
|