summaryrefslogtreecommitdiffstats
path: root/src/live_effects/lpe-perp_bisector.h
blob: 4d09f88604e329a76db223bd30ddd519f7dc099f (plain)
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
// SPDX-License-Identifier: GPL-2.0-or-later
#ifndef INKSCAPE_LPE_PERP_BISECTOR_H
#define INKSCAPE_LPE_PERP_BISECTOR_H

/** \file
 * LPE <perp_bisector> implementation, see lpe-perp_bisector.cpp.
 */
/*
 * Authors:
 *   Maximilian Albert
 *   Johan Engelen
 *
 * Copyright (C) Johan Engelen 2007 <j.b.c.engelen@utwente.nl>
 * Copyright (C) Maximilin Albert 2008 <maximilian.albert@gmail.com>
 *
 * Released under GNU GPL v2+, read the file 'COPYING' for more information.
 */

#include "live_effects/effect.h"
#include "live_effects/parameter/parameter.h"
#include "live_effects/parameter/point.h"

namespace Inkscape {
namespace LivePathEffect {

namespace PB {
  // we need a separate namespace to avoid clashes with LPETangentToCurve
  class KnotHolderEntityEnd;
  class KnotHolderEntityLeftEnd;
  class KnotHolderEntityRightEnd;
  void bisector_end_set(SPItem *item, Geom::Point const &p, guint state, bool left = true);
}

class LPEPerpBisector : public Effect {
public:
    LPEPerpBisector(LivePathEffectObject *lpeobject);
    ~LPEPerpBisector() override;

    virtual EffectType effectType () { return PERP_BISECTOR; }

    void doOnApply (SPLPEItem const* lpeitem) override;

    Geom::Piecewise<Geom::D2<Geom::SBasis> >
      doEffect_pwd2 (Geom::Piecewise<Geom::D2<Geom::SBasis> > const & pwd2_in) override;

    /* the knotholder entity functions must be declared friends */
    friend class PB::KnotHolderEntityEnd;
    friend class PB::KnotHolderEntityLeftEnd;
    friend class PB::KnotHolderEntityRightEnd;
    friend void PB::bisector_end_set(SPItem *item, Geom::Point const &p, guint state, bool left);
    void addKnotHolderEntities(KnotHolder *knotholder, SPDesktop *desktop, SPItem *item);

private:
    ScalarParam length_left;
    ScalarParam length_right;

    Geom::Point A; // start of path
    Geom::Point B; // end of path
    Geom::Point M; // midpoint
    Geom::Point C; // left end of bisector
    Geom::Point D; // right end of bisector
    Geom::Point perp_dir;

    LPEPerpBisector(const LPEPerpBisector&) = delete;
    LPEPerpBisector& operator=(const LPEPerpBisector&) = delete;
};

} //namespace LivePathEffect
} //namespace Inkscape

#endif