mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-11 11:08:41 +00:00
4bbd4a45e7
This is a kind of hack. This allows InsetMathHull to state that it needs some elbow room beyond its width, in order to fit the numbering and/or the left margin (with left alignment), which are outside of the inset itself. To this end, InsetMathHull::metrics() sets a value in MetricsInfo::extrawidth and this value is recorded later in the corresponding row element's `extra' field. The code could be reorganized to be simpler, in particular by computing metrics in tokenizeRow, or after tokenizeRow. However the choice here is to produce a simple patch, fit for 2.4.0. Fixes bug #12320.
164 lines
4.3 KiB
C++
164 lines
4.3 KiB
C++
// -*- C++ -*-
|
|
/**
|
|
* \file MetricsInfo.h
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* \author André Pönitz
|
|
* \author Stefan Schimanski
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#ifndef METRICSINFO_H
|
|
#define METRICSINFO_H
|
|
|
|
#include "Changes.h"
|
|
#include "ColorCode.h"
|
|
#include "FontInfo.h"
|
|
|
|
#include "support/strfwd.h"
|
|
#include "support/Changer.h"
|
|
|
|
#include "insets/Inset.h"
|
|
|
|
|
|
#include <string>
|
|
|
|
|
|
namespace lyx {
|
|
|
|
namespace frontend { class Painter; }
|
|
class BufferView;
|
|
class Length;
|
|
class MacroContext;
|
|
|
|
|
|
//
|
|
// This is the part common to MetricsInfo and PainterInfo
|
|
//
|
|
class MetricsBase {
|
|
public:
|
|
///
|
|
MetricsBase(BufferView * bv = 0, FontInfo font = FontInfo(),
|
|
int textwidth = 0);
|
|
|
|
/// the current view
|
|
BufferView * bv;
|
|
/// current font
|
|
FontInfo font;
|
|
/// name of current font - mathed specific
|
|
std::string fontname;
|
|
/// This is the width available in pixels
|
|
int textwidth;
|
|
/// count wether the current mathdata is nested in macro(s)
|
|
int macro_nesting;
|
|
|
|
/// Temporarily change a full font.
|
|
Changer changeFontSet(std::string const & name);
|
|
/// Temporarily change the font to math if needed.
|
|
Changer changeEnsureMath(Inset::mode_type mode = Inset::MATH_MODE);
|
|
// Temporarily change to the style suitable for use in fractions
|
|
Changer changeFrac();
|
|
// Temporarily change to the style suitable for use in arrays
|
|
// or to style suitable for smallmatrix when \c small is true.
|
|
Changer changeArray(bool small = false);
|
|
// Temporarily change the style to (script)script style
|
|
Changer changeScript();
|
|
///
|
|
int solidLineThickness() const { return solid_line_thickness_; }
|
|
///
|
|
int solidLineOffset() const { return solid_line_offset_; }
|
|
///
|
|
int dottedLineThickness() const { return dotted_line_thickness_; }
|
|
/** return the on-screen size of this length
|
|
*
|
|
* This version of the function uses the current inset width as
|
|
* width and the EM value of the current font.
|
|
*/
|
|
int inPixels(Length const & len) const;
|
|
|
|
private:
|
|
int solid_line_thickness_;
|
|
int solid_line_offset_;
|
|
int dotted_line_thickness_;
|
|
};
|
|
|
|
|
|
//
|
|
// This contains a MetricsBase and information that's only relevant during
|
|
// the first phase of the two-phase draw
|
|
//
|
|
class MetricsInfo {
|
|
public:
|
|
///
|
|
MetricsInfo();
|
|
///
|
|
MetricsInfo(BufferView * bv, FontInfo font, int textwidth,
|
|
MacroContext const & mc, bool vm, bool tight_insets);
|
|
|
|
///
|
|
MetricsBase base;
|
|
/// The context to resolve macros
|
|
MacroContext const & macrocontext;
|
|
/// Are we at the start of a paragraph (vertical mode)?
|
|
bool vmode;
|
|
/// if true, do not expand insets to max width artificially
|
|
bool tight_insets;
|
|
/// Extra width required by an inset, in addition to its dimension
|
|
int extrawidth;
|
|
};
|
|
|
|
|
|
//
|
|
// This contains a MetricsBase and information that's only relevant during
|
|
// the second phase of the two-phase draw
|
|
//
|
|
class PainterInfo {
|
|
public:
|
|
///
|
|
PainterInfo(BufferView * bv, frontend::Painter & pain);
|
|
///
|
|
void draw(int x, int y, char_type c);
|
|
///
|
|
void draw(int x, int y, docstring const & str);
|
|
/// Determines the background color based on the
|
|
/// selection state, the background color inherited from the parent inset
|
|
/// and the inset's own background color (if one is specified).
|
|
/// \param sel whether to take the selection state into account
|
|
ColorCode backgroundColor(Inset const * inset = nullptr, bool sel = true) const;
|
|
|
|
/// Determines the text color based on the intended color, the
|
|
/// change tracking state and the selection state.
|
|
/// \param color what the color should be by default
|
|
Color textColor(Color const & color) const;
|
|
|
|
///
|
|
MetricsBase base;
|
|
///
|
|
frontend::Painter & pain;
|
|
/// Whether the text at this point is right-to-left (for insets)
|
|
bool ltr_pos;
|
|
/// The change the parent is part of (change tracking)
|
|
Change change;
|
|
/// Whether the parent is selected as a whole
|
|
bool selected;
|
|
/// Whether the left/right margins are selected
|
|
bool selected_left, selected_right;
|
|
/// Whether the spell checker is enabled for the parent
|
|
bool do_spellcheck;
|
|
/// True when it can be assumed that the screen has been cleared
|
|
bool full_repaint;
|
|
/// Current background color
|
|
ColorCode background_color;
|
|
/// The left and right position of current line (inside margins).
|
|
/// Useful for drawing display math numbering
|
|
int leftx, rightx;
|
|
};
|
|
|
|
class TextMetricsInfo {};
|
|
|
|
} // namespace lyx
|
|
|
|
#endif
|