From 56b1d339a4176c07d4d995bd8912f1eccddc5539 Mon Sep 17 00:00:00 2001 From: Florian Jung Date: Wed, 11 May 2011 16:14:24 +0000 Subject: the distance between staves now gets automatically increased to avoid stave A's note be drawn over stave B (or vice versa) --- muse2/muse/midiedit/scoreedit.cpp | 45 +++++++++++++++++++++++++++++++++------ muse2/muse/midiedit/scoreedit.h | 3 +++ 2 files changed, 42 insertions(+), 6 deletions(-) diff --git a/muse2/muse/midiedit/scoreedit.cpp b/muse2/muse/midiedit/scoreedit.cpp index 65559efb..2bc87df8 100644 --- a/muse2/muse/midiedit/scoreedit.cpp +++ b/muse2/muse/midiedit/scoreedit.cpp @@ -104,6 +104,10 @@ QString IntToQStr(int i); #define STAFF_DISTANCE (10*YLEN) #define GRANDSTAFF_DISTANCE (8*YLEN) +#define NOTE_YDIST 20 +//NOTE_YDIST is the number of pixels which are between two notes +//which exceed their staves' y-boundaries, so that these boundaries +//must be expanded. QString create_random_string(int len=8) { @@ -858,8 +862,8 @@ void ScoreCanvas::add_staves(PartList* pl, bool all_in_one) } cleanup_staves(); - recalc_staff_pos(); song_changed(SC_EVENT_INSERTED); + recalc_staff_pos(); } @@ -996,8 +1000,8 @@ void ScoreCanvas::set_staffmode(list::iterator it, staff_mode_t mode) cerr << "ERROR: ILLEGAL FUNCTION CALL: invalid mode in set_staffmode" << endl; } - recalc_staff_pos(); song_changed(SC_EVENT_INSERTED); + recalc_staff_pos(); } void ScoreCanvas::remove_staff(list::iterator it) @@ -1022,8 +1026,8 @@ void ScoreCanvas::remove_staff(list::iterator it) } maybe_close_if_empty(); - recalc_staff_pos(); song_changed(SC_EVENT_INSERTED); + recalc_staff_pos(); } void ScoreCanvas::merge_staves(list::iterator dest, list::iterator src) @@ -1058,8 +1062,8 @@ void ScoreCanvas::merge_staves(list::iterator dest, list::iter remove_staff(src); - recalc_staff_pos(); song_changed(SC_EVENT_INSERTED); + recalc_staff_pos(); } void ScoreCanvas::move_staff_above(list::iterator dest, list::iterator src) @@ -1089,8 +1093,8 @@ void ScoreCanvas::move_staff_above(list::iterator dest, list:: staves.splice(dest, staves, src, src_end); - recalc_staff_pos(); song_changed(SC_EVENT_INSERTED); + recalc_staff_pos(); } void ScoreCanvas::move_staff_below(list::iterator dest, list::iterator src) @@ -1127,6 +1131,8 @@ void ScoreCanvas::song_changed(int flags) for (list::iterator it=staves.begin(); it!=staves.end(); it++) it->recalculate(); + + recalc_staff_pos(); redraw(); emit canvas_width_changed(canvas_width()); @@ -1143,11 +1149,12 @@ void ScoreCanvas::song_changed(int flags) } cleanup_staves(); - recalc_staff_pos(); for (list::iterator it=staves.begin(); it!=staves.end(); it++) it->recalculate(); + recalc_staff_pos(); + redraw(); } @@ -2444,6 +2451,9 @@ void staff_t::calc_item_pos() //key signature is properly drawn. int pos_add=0; + max_y_coord=0; + min_y_coord=0; + for (ScoreItemList::iterator it2=itemlist.begin(); it2!=itemlist.end(); it2++) { for (set::iterator it=it2->second.begin(); it!=it2->second.end();it++) @@ -2454,6 +2464,9 @@ void staff_t::calc_item_pos() if (it->type==FloItem::NOTE) { + if (it->y > max_y_coord) max_y_coord=it->y; + if (it->y < min_y_coord) min_y_coord=it->y; + it->x+=parent->note_x_indent() + it->shift*NOTE_SHIFT; switch (it->len) @@ -2527,6 +2540,9 @@ void staff_t::calc_item_pos() } } } + + max_y_coord+= (pix_quarter->height()/2 +NOTE_YDIST/2); + min_y_coord-= (pix_quarter->height()/2 +NOTE_YDIST/2); } void ScoreCanvas::calc_pos_add_list() @@ -3797,16 +3813,33 @@ void ScoreCanvas::recalc_staff_pos() { case NORMAL: it->y_draw = it->y_top + STAFF_DISTANCE/2; + if (it->min_y_coord < -STAFF_DISTANCE/2) + it->y_draw+= (-it->min_y_coord - STAFF_DISTANCE/2); + it->y_bottom = it->y_draw + STAFF_DISTANCE/2; + if (it->max_y_coord > STAFF_DISTANCE/2) + it->y_bottom+= (it->max_y_coord - STAFF_DISTANCE/2); + break; + case GRAND_TOP: it->y_draw = it->y_top + STAFF_DISTANCE/2; + if (it->min_y_coord < -STAFF_DISTANCE/2) + it->y_draw+= (-it->min_y_coord - STAFF_DISTANCE/2); + it->y_bottom = it->y_draw + GRANDSTAFF_DISTANCE/2; + break; + case GRAND_BOTTOM: it->y_draw = it->y_top + GRANDSTAFF_DISTANCE/2; + it->y_bottom = it->y_draw + STAFF_DISTANCE/2; + if (it->max_y_coord > STAFF_DISTANCE/2) + it->y_bottom+= (it->max_y_coord - STAFF_DISTANCE/2); + break; + default: cerr << "ERROR: THIS SHOULD NEVER HAPPEN: invalid staff type!" << endl; } diff --git a/muse2/muse/midiedit/scoreedit.h b/muse2/muse/midiedit/scoreedit.h index 920c150b..ceb41679 100644 --- a/muse2/muse/midiedit/scoreedit.h +++ b/muse2/muse/midiedit/scoreedit.h @@ -474,6 +474,9 @@ struct staff_t int y_draw; int y_bottom; + int min_y_coord; + int max_y_coord; + staff_type_t type; clef_t clef; -- cgit v1.2.3