From 4fb949c2b054e61e6785c1627645a53029a44645 Mon Sep 17 00:00:00 2001 From: Shen Wei Date: Sat, 4 Jan 2025 16:37:36 +0800 Subject: [PATCH 1/3] fix bugs when drawing semicircle --- TeXmacs/progs/graphics/graphics-markup.scm | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/TeXmacs/progs/graphics/graphics-markup.scm b/TeXmacs/progs/graphics/graphics-markup.scm index e8f2645d9b..beda7eeb06 100644 --- a/TeXmacs/progs/graphics/graphics-markup.scm +++ b/TeXmacs/progs/graphics/graphics-markup.scm @@ -87,28 +87,32 @@ (p (if (tm-point? P) (tree->stree P) c)) (q (if (tm-point? Q) (tree->stree Q) p)) (r (points-distance c p)) + (r1 (points-distance c q)) (x (if (equal? r 0.0) c - (points-add (point-times (point-get-unit (points-sub q c)) r) c))) + (if (equal? r1 0.0) + p + (points-add (point-times (point-get-unit (points-sub q c)) r) c)))) (mid-p-x (points-mid p x)) (vec-c-p (points-sub p c)) (vec-c-q (points-sub q c)) - (m (if (equal? r 0.0) - c + (m (if (or (equal? r 0.0) (equal? r1 0.0)) + x (if (clockwise (points-cross-product-k vec-c-p vec-c-q) 0) (points-add (point-times (point-get-unit (points-sub mid-p-x c)) (- r)) c) (if (= (points-cross-product-k vec-c-p vec-c-q) 0) ;; If cross product == 0, then the angle between vec-c-p and vec-c-q is 0 or 180. ;; We should find out whether it's 0 or 180. + ;; And we should determine whether it's clockwise or counterclockwise. (if (equal? (point-get-unit vec-c-p) (point-get-unit vec-c-q)) x - (point-rotate-90 (point-rotate-90 (point-rotate-90 vec-c-p)))) + (if (eq? clockwise >) + (points-add (point-rotate-90 (point-rotate-90 (point-rotate-90 vec-c-p))) c) + (points-add (point-rotate-90 vec-c-p) c))) (points-add (point-times (point-get-unit (points-sub mid-p-x c)) r) c)))))) `(arc ,p ,m ,x))) - - (define-graphics (std-arc C P Q) (std-arc-helper C P Q >)) From df5b4ab7f8d5090693d347306d53c7dff369d24a Mon Sep 17 00:00:00 2001 From: Shen Wei Date: Thu, 9 Jan 2025 19:28:29 +0800 Subject: [PATCH 2/3] add unit test --- TeXmacs/tests/23_27.scm | 78 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 TeXmacs/tests/23_27.scm diff --git a/TeXmacs/tests/23_27.scm b/TeXmacs/tests/23_27.scm new file mode 100644 index 0000000000..4a22da8a87 --- /dev/null +++ b/TeXmacs/tests/23_27.scm @@ -0,0 +1,78 @@ +(import (liii check) + (liii os)) + +; Because std-arc-helper is using define, it is not using tm-define +; We have to load the module directly +; +; (texmacs-module (tests 23_27) +; (:use (graphics graphics-markup))) +(load (string-append (getenv "TEXMACS_PATH") "/progs/graphics/graphics-markup.scm")) + +(define (point x y) + (stree->tree `(point ,x ,y))) + +(define (test-std-arc-helper) + ;c==p==q + (check (std-arc-helper (point "0" "0") (point "0" "0") (point "0" "0") #f) + => `(arc (point "0" "0") + (point "0" "0") + (point "0" "0"))) + ;c==p + (check (std-arc-helper (point "0" "0") (point "0" "0") (point "1" "1") #f) + => `(arc (point "0" "0") + (point "0" "0") + (point "0" "0"))) + ;c==q + (check (std-arc-helper (point "0" "0") (point "1" "1") (point "0" "0") #f) + => `(arc (point "1" "1") + (point "1" "1") + (point "1" "1"))) + ;p==q + (check (std-arc-helper (point "0" "0") (point "1" "0") (point "1" "0") >) + => `(arc (point "1" "0") + (point "1.0" "0.0") + (point "1.0" "0.0"))) + (check (std-arc-helper (point "0" "0") (point "1" "0") (point "1" "0") <) + => `(arc (point "1" "0") + (point "1.0" "0.0") + (point "1.0" "0.0"))) + ;cross-product==0, angle is 0 degree + (check (std-arc-helper (point "0" "0") (point "1" "0") (point "2" "0") >) + => `(arc (point "1" "0") + (point "1.0" "0.0") + (point "1.0" "0.0"))) + (check (std-arc-helper (point "0" "0") (point "1" "0") (point "2" "0") <) + => `(arc (point "1" "0") + (point "1.0" "0.0") + (point "1.0" "0.0"))) + ;cross-product==0, angle is 180 degree + (check (std-arc-helper (point "0" "0") (point "1" "0") (point "-2" "0") >) + => `(arc (point "1" "0") + (point "0.0" "-1.0") + (point "-1.0" "0.0"))) + (check (std-arc-helper (point "0" "0") (point "1" "0") (point "-2" "0") <) + => `(arc (point "1" "0") + (point "0.0" "1.0") + (point "-1.0" "0.0"))) + ;cross-product!=0 + (check (std-arc-helper (point "0" "0") (point "1" "0") (point "0" "1") >) + => `(arc (point "1" "0") + (point "-0.7071067811865475" "-0.7071067811865475") + (point "0.0" "1.0"))) + (check (std-arc-helper (point "0" "0") (point "1" "0") (point "0" "-1") >) + => `(arc (point "1" "0") + (point "0.7071067811865475" "-0.7071067811865475") + (point "0.0" "-1.0"))) + (check (std-arc-helper (point "0" "0") (point "1" "0") (point "0" "1") <) + => `(arc (point "1" "0") + (point "0.7071067811865475" "0.7071067811865475") + (point "0.0" "1.0"))) + (check (std-arc-helper (point "0" "0") (point "1" "0") (point "0" "-1") <) + => `(arc (point "1" "0") + (point "-0.7071067811865475" "0.7071067811865475") + (point "0.0" "-1.0")))) + +(define (test_23_27) + (test-std-arc-helper) + (check-report) + (if (check-failed?) (exit -1))) \ No newline at end of file From 0d9257f5ce5d6a89dc4b6af60b5bcc489e645848 Mon Sep 17 00:00:00 2001 From: Shen Wei Date: Thu, 9 Jan 2025 19:34:11 +0800 Subject: [PATCH 3/3] update per comment --- TeXmacs/progs/graphics/graphics-markup.scm | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/TeXmacs/progs/graphics/graphics-markup.scm b/TeXmacs/progs/graphics/graphics-markup.scm index beda7eeb06..b004b16877 100644 --- a/TeXmacs/progs/graphics/graphics-markup.scm +++ b/TeXmacs/progs/graphics/graphics-markup.scm @@ -88,15 +88,15 @@ (q (if (tm-point? Q) (tree->stree Q) p)) (r (points-distance c p)) (r1 (points-distance c q)) - (x (if (equal? r 0.0) + (x (if (zero? r) c - (if (equal? r1 0.0) + (if (zero? r1) p (points-add (point-times (point-get-unit (points-sub q c)) r) c)))) (mid-p-x (points-mid p x)) (vec-c-p (points-sub p c)) (vec-c-q (points-sub q c)) - (m (if (or (equal? r 0.0) (equal? r1 0.0)) + (m (if (or (zero? r) (zero? r1)) x (if (clockwise (points-cross-product-k vec-c-p vec-c-q) 0) (points-add (point-times (point-get-unit (points-sub mid-p-x c)) (- r)) c)