Drawing Workbench/ru

Модуль Черчения позволяет поместить ваши 3D наработки на бумагу. То есть, поместить проекции ваших моделей в 2D окно и вставить это окно в рисунок, например на лист с рамкой, вашим заголовком и логотипом и наконец распечатать всё это. Модуль черчения находится в стадии разработки и приблизительного технологического тестирования!

GUI Инструменты
Примечание Инструмент Draft View главным образом используется, чтобы поместить чертёжные объекты на бумагу. Он имеет множество дополнительных возможностей кроме стандартных чертёжных инструментов, и поддерживает специффические объекты вроде размеров на чертеже.



На картинке вы видите, основные концепции модуля Черчения. Документ содержит объект-форму (Schenkel) который мы хотим извлечь для черчения. Поэтому создается "Лист". Лист автоматически получает шаблон, в данном случае шаблон "A3_Landscape". Этот шаблон представляет собой документ SVG и может содержать обычную чертежную рамку, ваш логотип или же соответствовать вашим собственным стандартам.

На этот лист вы можете поместить один и более видов. Каждый вид обладает своей позицией на странице (свойства X,Y), и коэффициентом масштабирования (свойство scale) и другие дополнительные свойства. Каждый раз когда лист или вид или объект на который они ссылаются, изменяются лист перерисовывается, и отображение листа обновляется.

Написание сценариев
На данный момент рабочий процес для конечного пользователя(GUI) очень ограничен, поэтому интересней писать сценарии для API. Ниже следуют примеры о том как сценариев API чертежного модуля.

Это скрипт, с помощью которого можно легко заполнить лист Macro_CartoucheFC FreeCAD A3_Landscape.

Простейшие примеры
Прежде всего нам нужны модули Part и Drawing:

Создадим простую маленькую деталь

Прямая проекция. G0 будет жесткой гранью, а G1 непрерывно касается.

Всё помещено в проекцию на плоскость Z:

Различные вектора проекции

Спроецировать в SVG

Параметрический метод
Создадим новое тело

вставляем на лист и добавляем шаблон

Создает вид на "Форму" объекта,определяем положение и масштаб и помещаем его на лист

Создать второй вид на тот же объект, но на этот раз вид представление объекта будет повернуто на 90 градусов.

Создание третьего вида на данный объект, но с изометрической точки зрения. Также активируем скрытые линии.

Изменим кое-что и обновим. В процессе обновления, изменится отображение и лист.

Получение доступа к битам и деталям
Получить SVG фрагмент первого вида

Получить весь лист (это файл в во временном каталоге документа, доступный только для чтения)

Важно : освобождаем файл!

Вставить вид с вашим собственным содержанием:

Это приводит к следующим результатам:



Размеры и допуска
Чертёжные размеры и допуска еще в стадии проектирования, но Вы можете получить некоторую базовую функциональность при помощи небольшой работы.

Сначала Вам нужно взять отсюда модуль python под названием gdtsvg (ВНИМАНИЕ: Он может оказаться испорченным в любой момент!):

https://github.com/jcc242/FreeCAD

Чтобы получить контрольную рамку, попробуйте следующее:

Here is a good breakdown of the contents of a feature control frame: http://www.cadblog.net/adding-geometric-tolerances.htm

Параметры, отправляемые в кадр управления, следующие:
 * 1) Координата X в координатной системе SVG (строковый тип)
 * 2) Координата Y в координатной системе SVG (строковый тип)
 * 3) Требуемый символ геометрической характеристики (кортеж, сначала строка SVG, затем ширина символа, затем высота символа)
 * 4) Допуск (тип string)
 * 5) (опционально) символ диаметра (кортеж, сначала строка SVG, затем ширина символа, затем высота символа)
 * 6) (опционально) Условия изменения материала (кортеж, сначала строка SVG, затем ширина символа, затем высота символа)
 * 7) (опционально) The first datum (строковый тип)
 * 8) (опционально) The first datum's modifying condition (кортеж, сначала строка SVG, затем ширина символа, затем высота символа)
 * 9) (опционально) The second datum (строковый тип)
 * 10) (опционально) The second datum's modifying condition (кортеж, сначала строка SVG, затем ширина символа, затем высота символа)
 * 11) (опционально) The third datum (строковый тип)
 * 12) (опционально) The third datum's material condition (кортеж, сначала строка SVG, затем ширина символа, затем высота символа)

The ControlFrame function returns a type containing (svg string, overall width of control frame, overall height of control frame)'''

Чтобы получить размер, попробуйте следующее:

Inputs for linear dimension are:
 * 1) point1, an (x,y) tuple with svg-coordinates, this is one of the points you would like to dimension between
 * 2) point2, an (x,y) tuple with svg-coordinates, this is the second point you would like to dimension between
 * 3) textpoint, an (x,y) tuple of svg-coordinates, this is where the text of your dimension will be
 * 4) dimensiontext, a string containing the text you want the dimension to say
 * 5) linestyle, a string containing svg (i.e. css) styles, using the getStyle function to retrieve a preset string, for styling the how the lines look
 * 6) arrowstyle, a string containing svg (i.e. css) styles, using the getStyle function to retrieve a preset string, for styling how the arrows look
 * 7) textstyle, a string containing svg (i.e. css) styles, using the getStyle function to retrieve a preset string, for styling how the text looks

With those two, you can proceed as above for displaying them on the drawing page. This module is very buggy and can be broken at any given moment, bug reports are welcome on the github page for now, or contact jcc242 on the forums if you post a bug somewhere else.

Шаблоны
FreeCAD поставляется вместе с набором стандартных шаблонов, но вы также можете найти больше на странице Чертежных шаблонов.

Расширение модуля Drawing
Некоторые примечания по программной стороне модуля были добавлены на страницу Drawing Documentation. Это для быстрого понимания, как работает модуль Drawing, позволяя программистам быстро начать программирование для него.

Учебники

 * Учебник по модулю Drawing

Внешние ссылки

 * Intro to mechanical drawing on Youtube - by Normal Universe