]> git.donarmstrong.com Git - lilypond.git/blobdiff - scm/slur.scm
* scm/define-grobs.scm (all-grob-descriptions): reorganize in
[lilypond.git] / scm / slur.scm
index ce6f4be1230ec9a1ed8d336a6881305c17c910ce..777b4a86dd756795ed63952c1b579237a2bb37cf 100644 (file)
@@ -1,62 +1,28 @@
-
-;;;  als aan echte stok
-;;;      if ((note_column_drul[d] == get_bound (d))
-;;;      && note_column_drul[d]->first_head ()
-;;;      && (note_column_drul[d]->stem_l ()))
-;;;
-;;;  *Need: Score_elment::pointer_alist_
-;;;         Score_elment::property_alist_
-;;;         Spanner::Drul_array<Item*> spanned_drul_;
-;;;         spanner:: (cons get_bound (LEFT) get_bound (RIGHT))
-
-(define (attached-to-stem slur dir)
-  (let* ((note-columns (get-pointer slur 'note-columns))
-        (col (if (= dir 1) (car note-columns) (car (reverse note-columns))))
-        (stem (get-pointer col 'stem)))
-    (and
-     (eq? col (get-bound slur dir))
-     stem
-     (get-pointer stem 'heads))))
-
-(define slur-extremity-rules
-  '(
-    ;;if (stem_l->beam_l () && (stem_l->beam_count (-d) >= 1))
-    ((lambda (slur dir)
-       ;; urg, code dup
-       ;; if attached-to-stem
-       (let* ((note-columns (get-pointer slur 'note-columns))
-        (col (if (= dir 1) (car note-columns) (car (reverse note-columns))))
-        (stem (get-pointer col 'stem)))
-        (and
-         (and
-          (eq? col (get-bound slur dir))
-          stem
-          (get-pointer stem 'heads))
-         ;; and got beam
-         (and (get-pointer stem 'beam)
-              ;; and beam on same side as slur
-              (let ((beaming (get-property stem 'beaming)))
-                (if (pair? beaming)
-                    (>= 1
-                        (if (= dir -1) (car beaming) (cdr beaming)))
-                    #f)))))) . stem)
-    ((lambda (slur dir) (not (attached-to-stem slur dir))) . loose-end)
-    ;; default case, attach to head
-    ((lambda (x y) #t) . head)
-    
-  ;; silly rule, just to check
-  ((lambda (slur dir)
-       (and (attached-to-stem slur dir) 
-           (= (get-property slur 'direction) dir))) . stem)
-  ))
-
-
-(define slur-extremity-offset-alist
-  '(
-    ((head 1 1) . (-0.25 . 0.2))
-    ((head 1 -1) . (-0.25 . -0.75))
-    ((head -1 1) . (-0.25 . 0.75))
-    ((head -1 -1) . (-0.75 . 1.2))
-    ((stem 1 1) . (0 . 0.2))
-    ((stem -1 -1) . (0 . 0.2))
+;;;; slur.scm -- Slur scheme stuff
+;;;;
+;;;; source file of the GNU LilyPond music typesetter
+;;;; 
+;;;; (c) 2000--2005 Jan Nieuwenhuizen <janneke@gnu.org>
+                               ;
+; this is put into the slur-details property of Slur and PhrasingSlur
+(define default-slur-details
+  '((region-size . 4)
+    (head-encompass-penalty . 1000.0)
+    (stem-encompass-penalty . 30.0)
+    (closeness-factor . 10)
+    (edge-attraction-factor . 4)
+    (same-slope-penalty . 20)
+    (steeper-slope-factor . 50)
+    (non-horizontal-penalty . 15)
+    (max-slope . 1.1)
+    (max-slope-factor . 10)
+    (free-head-distance . 0.3)
+    (free-slur-distance . 0.8)
+    (extra-object-collision . 50)
+    (accidental-collision . 3)
+    (extra-encompass-free-distance . 0.3)
+    (head-slur-distance-max-ratio . 3)
+    (head-slur-distance-factor . 10)
+    (absolute-closeness-measure . 0.3)
+    (edge-slope-exponent . 1.7)
     ))