Draft PathArray/pl

Rysunek Roboczy: Szyk po ścieżce

Lokalizacja w menu
Modyfikacja → Narzędzia szyku → Szyk po ścieżce
Modyfikacja → Szyk po ścieżce
Środowisko pracy
Rysunek Roboczy, BIM
Domyślny skrót
brak
Wprowadzono w wersji
0.14
Zobacz także
Szyk ortogonalny, Szyk biegunowy, Szyk kołowy, Szyk powiązań po ścieżce, Szyk z punktów, Szyk powiązań w punktach

Opis

Polecenie Szyk po ścieżce tworzy zwykły szyk z wybranego obiektu przez umieszczenie kopii wzdłuż ścieżki. Zamiast tego użyj polecenia Szyk powiązań po ścieżce, aby utworzyć bardziej wydajny szyk powiązań. Z wyjątkiem typu utworzonych szyków (szyk powiązań lub zwykły szyk), polecenie Szyk powiązań po ścieżce jest identyczne z tym poleceniem.

Oba polecenia mogą być używane na obiektach 2D utworzonych za pomocą środowisk pracy Rysunek Roboczy lub Szkicownik, ale można ich również użyć dla wielu typów obiektów 3D, takich jak te utworzone za pomocą środowisk pracy Część, Projekt Części lub BIM.

Szyk po ścieżce

Użycie

  1. Wybierz obiekt, który chcesz wyświetlić.
  2. Dodaj obiekt ścieżki do zaznaczenia. Zamiast tego można również wybrać krawędzie. Krawędzie muszą należeć do tego samego obiektu i muszą być połączone.
  3. Polecenie można wywołać na kilka sposobów:
  4. Szyk zostanie utworzony.
  5. Opcjonalnie można zmienić właściwości szyku w edytorze właściwości.

Wyrównanie

Wyrównanie elementów w Szyk po ścieżce zależy od właściwości szyku i orientacji obiektu źródłowego. Pozycja obiektu źródłowego jest ignorowana: dla celów szyku wartości x, y i z są ustawione na 0. Jeśli właściwość DANEWyrównaj szyku jest ustawiona na wartość FAŁSZ, orientacja elementów szyku jest identyczna z orientacją obiektu źródłowego. Jeśli jest ustawiona na PRAWDA, oś X lokalnego układu współrzędnych każdego umieszczonego elementu jest styczna do ścieżki. Osie Y i Z lokalnych układów współrzędnych zależą od właściwości DANETryb wyrównania szyku. Inne właściwości szyku związane z wyrównaniem obejmują: DANEWektor styczny, DANEWymuś pionowo i DANEWektor pionowy.

Trzy szyki oparte na tej samej nieplanarnej ścieżce. Od lewej do prawej: Wyrównanie ustawiono na Fałsz, Wyrównanie ustawiono na Prawda z trybem wyrównania Original i Wyrównaj ustawiono na Prawda z trybem wyrównania Frenet.

.

Tryb wyrównania

Dostępne są trzy tryby:

Original

Ten tryb jest najbardziej zbliżony do pojedynczego DANETryb wyrównania dostępnego w wersji 0.18. Opiera się on na stałym wektorze normalnym. Jeśli ścieżka jest płaska, wektor ten jest prostopadły do płaszczyzny ścieżki, w przeciwnym razie używany jest wektor domyślny, o dodatniej osi Z. Na podstawie tego wektora normalnego i lokalnego wektora stycznego (lokalna oś X) obliczany jest iloczyn krzyżowy. Ten nowy wektor jest używany jako lokalna oś Z. Orientacja lokalnej osi Y jest określana na podstawie lokalnych osi X i Z.

Frenet

Tryb ten wykorzystuje lokalny wektor normalny wyprowadzony ze ścieżki przy każdym umieszczeniu elementu. Jeśli nie można określić tego wektora (na przykład w przypadku odcinka prostego), zamiast niego używany jest wektor domyślny, ponownie dodatnia oś Z. Za pomocą tego wektora i lokalnego wektora stycznego lokalny układ współrzędnych jest określany przy użyciu tej samej procedury, co w poprzednim akapicie.

Styczna

Tryb ten jest podobny do DANETrybu wyrównania Original, ale obejmuje możliwość wstępnego obrócenia obiektu źródłowego poprzez określenie DANEWektora stycznej.

Wymuś pionowo i Wektor pionowy

Właściwości te są dostępne tylko wtedy, gdy DANETryb wyrównania ma wartość Original lub Styczny. Jeśli właściowść DANEWymuś pionowo jest ustawione na PRAWDA, lokalny układ współrzędnych jest obliczany w inny sposób. DANEWektor pionowy jest używany jako stały wektor normalny. Z tego wektora normalnego i lokalnego wektora stycznego (lokalna oś X) ponownie obliczany jest iloczyn krzyżowy. Ale teraz ten wektor jest używany jako lokalna oś Y. Orientacja lokalnej osi Z jest określana na podstawie lokalnych osi X i Y.

Użycie tych właściwości może być wymagane, jeśli jedna z krawędzi ścieżki jest (prawie) równoległa do domyślnej normalnej ścieżki.

Właściwości

Zobacz również stronę: Edytor właściwości.

Obiekt Szyk po ścieżce środowiska Rysunek Roboczy wywodzi się z obiektu Część: Cecha i dziedziczy wszystkie jego właściwości (z wyjątkiem niektórych właściwości Widoku, które nie są dziedziczone przez szyki Łączy). Poniższe właściwości są dodatkowe, chyba że zaznaczono inaczej:

Dane

Łącze

Właściwości w tej grupie są dostępne tylko dla szyków łączy. Więcej informacji można znaleźć na stronie Std: Utwórz łącze.

Wyrównanie

Obiekty

Widok

Łącze

Właściwości w tej grupie, z wyjątkiem właściwości dziedziczonej, są dostępne tylko dla szyków łączy. Więcej informacji można znaleźć na stronie Std: Utwórz łącze.

Podstawa

Właściwości w tej grupie, z wyjątkiem właściwości dziedziczonej, są dostępne tylko dla szyków łączy. Więcej informacji można znaleźć na stronie Std: Utwórz łącze.

Opcje wyświetlania

Właściwości w tej grupie są dziedziczone. Więcej informacji można znaleźć na stronie Część: Cecha.

Rysunek Roboczy

Styl obiektu

Właściwości w tej grupie nie są dziedziczone przez szyk łączy.

Tworzenie skryptów

Zobacz również stronę: Dokumentacja API generowana automatycznie oraz Podstawy pisania skryptów dla FreeCAD.

Aby utworzyć Szyk po ścieżce, należy użyć metody make_path_array (dostępne w wersji 0.19) modułu Rysunek Roboczy. Metoda ta zastępuje przestarzałą metodę makePathArray.

path_array = make_path_array(base_object, path_object,
                             count=4, extra=App.Vector(0, 0, 0), subelements=None,
                             align=False, align_mode="Original", tan_vector=App.Vector(1, 0, 0),
                             force_vertical=False, vertical_vector=App.Vector(0, 0, 1),
                             use_link=True)

Przykład:

import FreeCAD as App
import Draft

doc = App.newDocument()

p1 = App.Vector(500, -1000, 0)
p2 = App.Vector(1500, 1000, 0)
p3 = App.Vector(3000, 500, 0)
p4 = App.Vector(4500, 100, 0)
spline = Draft.make_bspline([p1, p2, p3, p4])
obj = Draft.make_polygon(3, 500)

path_array = Draft.make_path_array(obj, spline, 6)
doc.recompute()

wire = Draft.make_wire([p1, -p2, -p3, -p4])
path_array2 = Draft.make_path_array(obj, wire, count=3, extra=App.Vector(0, -500, 0), subelements=["Edge2", "Edge3"], align=True, force_vertical=True)
doc.recompute()