30 #include "config_auto.h"
48 : priority_(priority),
55 : priority_(priority),
74 float max_total_priority)
const;
80 for (
int s = 0; s < num_splits_; ++s) {
89 for (
int s = 0; s < num_splits_; ++s) {
90 if (splits_[s].
UsesPoint(point))
return true;
96 for (
int s = 0; s < num_splits_; ++s) {
97 for (
int t = 0; t < other.num_splits_; ++t)
104 for (
int s = 0; s < num_splits_; ++s) {
106 for (
int t = 0; t < other.num_splits_; ++t) {
108 if (split1_box.
y_overlap(split2_box))
return true;
117 for (
int s = 0; s < num_splits_; ++s) {
126 bool IsHealthy(
const TBLOB& blob,
int min_points,
int min_area)
const;
148 void Print(
const char* label)
const;
151 #ifndef GRAPHICS_DISABLED
175 float FullPriority(
int xmin,
int xmax,
double overlap_knob,
176 int centered_maxwidth,
double center_knob,
177 double width_change_knob)
const;
181 static const int kMaxNumSplits = 3;
194 SPLIT splits_[kMaxNumSplits];
bool HasAnySplits() const
static void PrintSeams(const char *label, const GenericVector< SEAM * > &seams)
void start_seam_list(TWERD *word, GenericVector< SEAM * > *seam_array)
float FullPriority(int xmin, int xmax, double overlap_knob, int centered_maxwidth, double center_knob, double width_change_knob) const
TBOX bounding_box() const
void Print(const char *label) const
void set_priority(float priority)
void Mark(ScrollView *window) const
bool IsHealthy(const TBLOB &blob, int min_points, int min_area) const
bool PrepareToInsertSeam(const GenericVector< SEAM * > &seams, const GenericVector< TBLOB * > &blobs, int insert_index, bool modify)
void ApplySeam(bool italic_blob, TBLOB *blob, TBLOB *other_blob) const
SEAM(float priority, const TPOINT &location)
bool FindBlobWidth(const GenericVector< TBLOB * > &blobs, int index, bool modify)
bool CombineableWith(const SEAM &other, int max_x_dist, float max_total_priority) const
bool OverlappingSplits(const SEAM &other) const
void CombineWith(const SEAM &other)
bool ContainedByBlob(const TBLOB &blob) const
bool y_overlap(const TBOX &box) const
TBOX bounding_box() const
void UndoSeam(TBLOB *blob, TBLOB *other_blob) const
static void JoinPieces(const GenericVector< SEAM * > &seams, const GenericVector< TBLOB * > &blobs, int first, int last)
bool UsesPoint(const EDGEPT *point) const
bool SharesPosition(const SEAM &other) const
SEAM(float priority, const TPOINT &location, const SPLIT &split)
static void BreakPieces(const GenericVector< SEAM * > &seams, const GenericVector< TBLOB * > &blobs, int first, int last)