Obiekt Cecha Części, lub formalnie Part::Feature
, jest prostym elementem kształtu topologicznego, który może być wyświetlany w oknie widoku 3D.
Cecha części jest klasą nadrzędną dla większości obiektów 2D (Rysunek roboczy, Szkicownik) i 3D (Część, Projekt części), z wyjątkiem siatek, które są zwykle oparte na cechach siatek, lub obiektach FemMesh dla obiektów MES.
Uproszczony diagram zależności pomiędzy podstawowymi obiektami w programie FreeCAD.
Obiekt cecha części jest obiektem wewnętrznym, więc nie można go utworzyć z poziomu interfejsu graficznego, tylko z poziomu konsoli Python jak opisano w sekcji tworzenie skryptów.
Klasa Part::Feature
jest zdefiniowana w środowisku Część ale może być użyta jako klasa bazowa dla obiektów tworzonych skryptami we wszystkich środowiskach pracy które produkują kształty geometryczne 2D i 3D. Zasadniczo wszystkie obiekty produkowane w środowisku pracy Część są instancjami Part::Feature
.
Part::Feature
jest również klasą nadrzędną zawartości Projektu części, cechy Projektu części, oraz Part2DObject, która jest wyspecjalizowana dla kształtów 2D (planarnych).
Środowisko pracy może dodać więcej właściwości do tego podstawowego elementu, aby stworzyć obiekt o złożonym wyglądzie.
Zobacz stronę Właściwości dla wszystkich typów właściwości, które mogą mieć obiekty tworzone skryptami.
Cecha części (klasa Part::Feature
) wywodzi się z podstawowej App: GeoFeature (klasa App::GeoFeature
), i dziedziczy wszystkie jego właściwości. Posiada również kilka dodatkowych właściwości. W szczególności właściwość DANEKształt, która przechowuje kształt topologiczny obiektu. Jest to geometria, która jest wyświetlana w oknie widoku 3D. Inne właściwości tego obiektu to te związane z wyglądem jego kształtu topologicznego.
Są to właściwości dostępne w edytorze właściwości|. Ukryte właściwości można pokazać za pomocą polecenia Pokaż ukryte w menu kontekstowym okna edycji właściwości.
Podstawa
PythonObject
): niestandardowa klasa powiązana z tym obiektem. Występuje tylko w wersji Python. Zobacz Tworzenie skryptów.PartShape
): Kształt topologiczny powiązany z tym obiektem.Material
): materiał obiektu.Placement
): położenie obiektu. Położenie jest określane przez punkt Base
(wektor) oraz Rotation
(oś i kąt). Zobacz Umiejscowienie.
0°
(zero stopni).0
a 1
. Jeśli jakakolwiek wartość przekracza 1
, wektor zostanie znormalizowany tak, by jego długość wynosiła 1
. Domyślnie dodatnia oś Z: (0, 0, 1)
.(0, 0, 0)
.String
): Do określenia. dostępne w wersji 1.1String
): edytowalna przez użytkownika nazwa obiektu; dowolny ciąg UTF8.String
): dłuższy, edytowalny opis obiektu; dowolny ciąg UTF8 mogący zawierać znaki nowej linii. Domyślnie pusty ciąg ""
.ExpressionEngine
): lista wyrażeń. Domyślnie pusta []
.Bool
): czy obiekt ma być widoczny.
Większość obiektów we FreeCAD ma coś, co nazywa się „dostawca widoku”, jest to klasa definiująca wygląd obiektu w oknie widoku 3D oraz w drzewie widoku. Domyślny dostawca widoku obiektów elementu części definiuje właściwości prezentowane poniżej. Obiekty skryptowe, które pochodzą z elementu cecha części, również będą miały dostęp do tych właściwości.
Podstawa
PythonObject
): klasa własna dostawca widoku związana z tym obiektem. Istnieje wyłącznie dla wersji środowiska Python. Zobacz sekcję tworzenie skryptów.Placement
): przechowuje punkt początkowy używany przez Przemieszczenie. dostępne w wersji 1.1Opcje wyświetlania
Bool
): jeśli prawda, obiekt wyświetli ramkę ograniczającą w widoku 3D.Enumeration
): Linie główne
(regularna wizualizacja), Zacieniony
(bez krawędzi), Model krawędziowy
(bez ścian), Punkty
(tylko wierzchołki).Bool
): jeśli prawda, obiekt pojawi się w widoku drzewa. W przeciwnym razie obiekt zostanie ukryty w widoku drzewa. Gdy obiekt w drzewie jest niewidoczny, można go ponownie wyświetlić, otwierając menu kontekstowe nad nazwą dokumentu (prawy przycisk myszy) i wybrać PRAWDA
.Bool
): jeśli prawda, pokazywany jest układ współrzędnych wskazujący DANEUmiejscowienie obiektu. dostępne w wersji 1.1Bool
): jeśli prawda, obiekt pojawia się w widoku 3D; inaczej jest niewidoczny. Domyślnie ta właściwość może być włączana i wyłączana za pomocą klawisza Spacja.Wygląd obiektu
Angle
): jest uzupełnieniem właściwości WIDOKDeviation. To inny sposób określenia, jak dokładna ma być siatka generowana do wyświetlania na ekranie lub eksportu. Wartość domyślna to 28.5 degrees
lub 0.5 radians
. Jest to wartość maksymalna — im mniejsza wartość, tym gładszy wygląd i dokładniejsza siatka eksportowa.FloatConstraint
): jest uzupełnieniem właściwości WIDOKAngular Deflection. To inny sposób określenia dokładności siatki generowanej do wyświetlania lub eksportu. Domyślna wartość to 0.5%
. Jest to wartość maksymalna — im mniejsza, tym gładszy wygląd i dokładniejsza siatka.Enumeration
): Solid
(domyślnie), Dashed
, Dotted
, Dashdot
; definiuje styl krawędzi.Enumeration
): Two side
(domyślnie), One side
; oświetlenie pochodzi z dwóch stron lub jednej strony w widoku 3D.Color
): krotka czterech wartości zmiennoprzecinkowych RGBA określająca kolor krawędzi.ColorList
): lista krotek RGBA określających kolory, podobnie jak WIDOKLine Color.Material
): materiał powiązany z krawędziami tego obiektu. Domyślnie pusty.FloatConstraint
): liczba zmiennoprzecinkowa określająca szerokość krawędzi w pikselach.Color
): podobnie jak WIDOKKolor linii, definiuje kolor wierzchołków.ColorList
): jest to lista krotek RGBA określających kolory, podobna do WIDOKKolor wierzchołka.Material
): Materiał powiązany z wierzchołkami w tym obiekcie. Domyślnie wartość jest pusta.FloatConstraint
): podobnie jak WIDOKSzerokość linii, definiuje rozmiar wierzchołków.MaterialList
): lista materiałów definiujących wygląd obiektu. Domyślnie lista zawiera jeden element, który jest używany dla wszystkich ścian obiektu. Alternatywnie może zawierać osobny materiał aplikacji dla każdej ściany. Zobacz Kolor dla ściany. W edytorze właściwości wyświetlany jest tylko pierwszy materiał aplikacji. Edytowanie go spowoduje utworzenie listy z jednym elementem. Materiał aplikacji zawiera następujące właściwości:
Percent
): liczba całkowita z zakresu od 0
do 100
, określająca poziom przezroczystości ścian. Wartość 100
oznacza całkowicie niewidoczne ściany; są one niewidoczne, ale nadal można je zaznaczyć, o ile WIDOKSelectable ma wartość PRAWDA
. Zmiana tej właściwości spowoduje również zmianę listy WIDOKShape Appearance obiektu. Powstała lista będzie zawierać jeden element.Wybieranie
Enumeration
): kontroluje sposób, w jaki zaznaczenie pojawia się w oknie widoku 3D, jeśli obiekt ma kształt i jest wiele obiektów częściowo zakrytych przez inne. Domyślna wartość to Wyłaczone
, co oznacza, że nie pojawi się żadne specjalne podświetlenie. Wartość Włączone
oznacza, że obiekt pojawi się na wierzchu każdego innego obiektu, gdy zostanie wybrany, Object
oznacza, że obiekt pojawi się na wierzchu tylko jeśli cały obiekt jest zaznaczony w widoku drzewa. Wartość Element
oznacza, że obiekt pojawi się na wierzchu tylko jeśli element podrzędny (wierzchołek, krawędź, ściana) jest zaznaczony w widoku 3D.Bool
): jeśli prawda, obiekt może być wybrany kursorem myszki w widoku 3D. W przeciwnym razie, obiekt może być wybrany tylko w widoku drzewa.Enumeration
): kontroluje sposób podświetlania obiektu. Jeśli wybrano Kształt
, cały kształt (wierzchołki, krawędzie i ściany) będzie podświetlony w widoku 3D; jeśli jest to Ramka otaczająca
, pole ograniczające pojawi się wokół obiektu i zostanie podświetlone.
Ugięcie kątowe i parametry odchylenia; d < odchylenie liniowe, α < ugięcie kątowe.
Odchylenie jest wartością w procentach, która jest związana z wymiarami w milimetrach ramki otaczającej obiekt. Odchylenie w milimetrach można obliczyć w następujący sposób:
deviation_in_mm = (w + h + d)/3 * deviation/100
gdzie w
, h
, d
są wymiarami ramki otaczającej.
Zobacz również: Podstawy tworzenia skryptów FreeCAD, oraz Obiekty skryptowe.
Cecha części jest tworzona za pomocą metody dokumentu addObject()
.
import FreeCAD as App
doc = App.newDocument()
obj = App.ActiveDocument.addObject("Part::Feature", "Name")
obj.Label = "Custom label"
Dlatego też, dla klasy podrzędnej Python, powinieneś stworzyć obiekt Part::FeaturePython
.
import FreeCAD as App
doc = App.newDocument()
obj = App.ActiveDocument.addObject("Part::FeaturePython", "Name")
obj.Label = "Custom label"
Zobacz również: Nazwa obiektu, aby uzyskać więcej informacji na temat właściwości Nazwy
.
Metoda addObject
posiada dwa podstawowe argumenty typu string.
"Part::FeaturePython"
.Name
. Jeśli nie zostanie podany, domyślnie przyjmuje taką samą nazwę jak klasa, czyli "Part__FeaturePython"
. Nazwa Name
może zawierać tylko proste znaki alfanumeryczne oraz podkreślnik, [_0-9a-zA-Z]
. Jeśli podane zostaną inne symbole, zostaną one zamienione na znaki podkreślenia, na przykład "A+B:C*"
jest zamieniane na "A_B_C_"
.
W razie potrzeby atrybut Etykieta
może zostać zmieniony na bardziej wymowny tekst.
Etykieta
może przyjąć dowolny ciąg znaków UTF8, włączając w to akcenty i spacje. Ponieważ widok drzewa wyświetla Etykietę
, dobrą praktyką jest zmiana atrybutu Etykiety
na bardziej opisowy ciąg znaków.Etykieta
jest unikalna, tak jak Nazwa
. Jednak to zachowanie może być zmienione w Edytorze Preferencji, Edycja → Preferencje → Ogólne → Dokument → Zezwalaj na duplikowanie etykiet obiektów w jednym dokumencie. Oznacza to, że ogólnie Etykieta
może być powtarzana w tym samym dokumencie, podczas testowania dla konkretnego elementu użytkownik powinien polegać na Nazwie
, a nie na Etykiecie
.