Macro Texture: Difference between revisions

From FreeCAD Documentation
No edit summary
(Marked this version for translation)
Line 15: Line 15:
}}
}}


==Description==
==Description== <!--T:43-->


<!--T:2-->
<!--T:2-->
Line 39: Line 39:
{{Caption|Texture 004 Honda}}
{{Caption|Texture 004 Honda}}


==Usage==
==Usage== <!--T:44-->


<!--T:6-->
<!--T:6-->
Line 61: Line 61:
[[File:Texture_002.png|300px|none|Texture 002]]
[[File:Texture_002.png|300px|none|Texture 002]]


====Coordinates====
====Coordinates==== <!--T:45-->


<!--T:12-->
<!--T:12-->
Line 68: Line 68:
* {{Button|Coordinate Z [[Image:Std_CoordinateSystem.svg|24px]]}} {{SpinBox|0,00 mm}}: The '''Z''' coordinate position of the object (default: 0)
* {{Button|Coordinate Z [[Image:Std_CoordinateSystem.svg|24px]]}} {{SpinBox|0,00 mm}}: The '''Z''' coordinate position of the object (default: 0)


====Stretching====
====Stretching==== <!--T:46-->


<!--T:31-->
<!--T:31-->
Line 75: Line 75:
* {{Button|Stretching Z}} {{SpinBox|0,00 mm}}: narrowing or enlarging of the '''Z''' (depth) of the object (default: 0)
* {{Button|Stretching Z}} {{SpinBox|0,00 mm}}: narrowing or enlarging of the '''Z''' (depth) of the object (default: 0)


====Inversion====
====Inversion==== <!--T:47-->


<!--T:32-->
<!--T:32-->
Line 82: Line 82:
* {{CheckBox|Axis Z}}: inverts the '''Z''' coordinates of the image.
* {{CheckBox|Axis Z}}: inverts the '''Z''' coordinates of the image.


====8 bit Mode====
====8 bit Mode==== <!--T:48-->


<!--T:33-->
<!--T:33-->
Line 94: Line 94:
* {{CheckBox|Nuance}}: if the shade option is checked, the color of the point is represented as a picture.
* {{CheckBox|Nuance}}: if the shade option is checked, the color of the point is represented as a picture.


====32 bit Mode====
====32 bit Mode==== <!--T:49-->


<!--T:35-->
<!--T:35-->
Line 100: Line 100:
* {{RadioButton|Plan}}: allows for importing a '''32-bit image''' and ignore the background of the plan. By default the map background is black to ignore colors are adjustable with the '''Capping''' command. If White is checked, the bottom has ignore will be white. (Note: this procedure is CPU intensive)
* {{RadioButton|Plan}}: allows for importing a '''32-bit image''' and ignore the background of the plan. By default the map background is black to ignore colors are adjustable with the '''Capping''' command. If White is checked, the bottom has ignore will be white. (Note: this procedure is CPU intensive)


====File====
====File==== <!--T:50-->


<!--T:36-->
<!--T:36-->
Line 106: Line 106:
* {{CheckBox|.asc}}: if checked, a file (originalName.bmp.asc) is saved in the same directory of the file. This file can be used as a point cloud (format: X Y Z).
* {{CheckBox|.asc}}: if checked, a file (originalName.bmp.asc) is saved in the same directory of the file. This file can be used as a point cloud (format: X Y Z).


====Capping (10mm)====
====Capping (10mm)==== <!--T:51-->


<!--T:37-->
<!--T:37-->
Line 117: Line 117:
* {{SpinBox|20 Capping}}: this spinbox gives the degrees of capping.
* {{SpinBox|20 Capping}}: this spinbox gives the degrees of capping.


====Command====
====Command==== <!--T:52-->


<!--T:13-->
<!--T:13-->
Line 215: Line 215:
<br />
<br />


==Links==
==Links== <!--T:53-->


<!--T:17-->
<!--T:17-->

Revision as of 08:50, 18 September 2021

Macro Texture

Description
Creates a 3D image from an 8 bit (256 color) BMP image.
In other words, it allows one to build a 3D project very easily from a bitmap image using grayscale (256 shades of gray).
If one 32 bit BMP image is selected, the image is represented in points.
The FCCreaLoft Macro Loft macro is used to automate the multi loft operation.

Macro version: 0.14c
Last modified: 2021/01/16
FreeCAD version: 0.18 and more
Download: ToolBar Icon, Macro Loft FCCreaLoft
Author: Mario52
Author
Mario52
Download
ToolBar Icon, Macro Loft FCCreaLoft
Links
Macro Version
0.14c
Date last modified
2021/01/16
FreeCAD Version(s)
0.18 and more
Default shortcut
None
See also
FCCreaLoft Macro Loft

Description

This small macro allows one to build a 3D project very easily from a bitmap image with 256 shades of gray.

I hope that this macro will revolutionize the way we think when modeling with CAD and CNC converting to 3D objects with little to no intervention.

Everything becomes possible regardless of the complexity of the image!

The macro FCCreaLoft Macro Loft is used to automate the multi loft operation.

Temporary code for external macro link. Do not use this code. This code is used exclusively by Addon Manager. Link for optional manual installation: Macro


# This code is copied instead of the original macro code
# to guide the user to the online download page.
# Use it if the code of the macro is larger than 64 KB and cannot be included in the wiki
# or if the RAW code URL is somewhere else in the wiki.

from PySide import QtGui, QtCore

diag = QtGui.QMessageBox(QtGui.QMessageBox.Information,
    "Information",
    "This macro must be downloaded from this link\n"
    "\n"
    "https://gist.githubusercontent.com/mario52a/262317bc7d8555885b0e/raw/3ec2ab127d8ad01a6b657aa5df9a6127ff07c7c0/Macro%2520FCTexture.FCMacro" + "\n"
    "\n"
    "Quit this window to access the download page")

diag.setWindowFlags(QtCore.Qt.WindowStaysOnTopHint)
diag.setWindowModality(QtCore.Qt.ApplicationModal)
diag.exec_()

import webbrowser 
webbrowser.open("https://gist.githubusercontent.com/mario52a/262317bc7d8555885b0e/raw/3ec2ab127d8ad01a6b657aa5df9a6127ff07c7c0/Macro%2520FCTexture.FCMacro")


Texture 004 Honda

Usage

This macro requires an image in 256 shades of gray (0-255) therefore before executing the macro, convert your image into grayscale (black and white). When running the macro, the number of colors is detected automatically. Note: if the image is more than 256 colors another function is expected (WIP). Each color (gray level) is regarded as a deep, white (255) the level high and black (0) the lowest level (deep).

Configuration is done before the opening of the file, default values are the settings provided to get a project's dimensions:

  • width of the image in points in the coordinate X,
  • height of the image in points in the coordinate Y,
  • depth or thickness of the project leaked 10 mm (in raw mode, on 256 mm) in the coordinate Z.

The image file unfolds like a scanner x1 x2 x3 ... in 1 mm increments in FreeCAD similarly to the value y of 1 mm at a time. The value of z is given by the value of the color. These values are configurable in the macro.

Important note: depending on the size of the image, the project can become very large in size! For example, a simple image of (100px x 100px) width/height would be: 100 x 100 = 10000 points. Each of the 10,000 points corresponds to a coordinate, so that means 10000 X, 10000 Y, and 10000 Z coordinates in actuality.

Interface

Texture 002
Texture 002

Coordinates

  • Coordinate X 0,00 mm : The X coordinate position of the object (default: 0)
  • Coordinate Y 0,00 mm : The Y coordinate position of the object (default: 0)
  • Coordinate Z 0,00 mm : The Z coordinate position of the object (default: 0)

Stretching

  • Stretching X 0,00 mm : narrowing or enlarging of the X (length) of the object (default: 0)
  • Stretching Y 0,00 mm : narrowing or enlarging of the Y (height) of the object (default: 0)
  • Stretching Z 0,00 mm : narrowing or enlarging of the Z (depth) of the object (default: 0)

Inversion

  • Axis X: inverts the X coordinates of the image.
  • Axis Y: inverts the Y coordinates of the image.
  • Axis Z: inverts the Z coordinates of the image.

8 bit Mode

The beginning of the operation value automatically adapts to the selected function: 0 if the setting is on black (Black) 255 or 20 if the setting is white (White).

  • Wire: build the line (vector) in the form of Wire.
  • Bspline: build the line (vector) in the form of Bspline.
  • Cloud: build the points vectors in a point cloud.
  • Point: creates a point at each pixel (vector) (Note: this procedure is CPU intensive)
  • Nuance: if the shade option is checked, the color of the point is represented as a picture.

32 bit Mode

  • Photo: photo mode is automatically activated when a 32-bit image is detected. (Note: this procedure is CPU intensive)
  • Plan: allows for importing a 32-bit image and ignore the background of the plan. By default the map background is black to ignore colors are adjustable with the Capping command. If White is checked, the bottom has ignore will be white. (Note: this procedure is CPU intensive)

File

  • .pcd: if checked, a file (originalName.bmp.pcd) is saved in the same directory of the file (pcd v0.7).
  • .asc: if checked, a file (originalName.bmp.asc) is saved in the same directory of the file. This file can be used as a point cloud (format: X Y Z).

Capping (10mm)

  • Slider: Enter the height of the form. The height is displayed on title frame.
  • 0 height : Enter the height of the form. The height is displayed on title frame.
  • Raw mode 20: For adjusting the number of colors (depth). The default mode is 0-20 (which constitutes a filter and to obtain more details according to the complexity of the image) once the checked the mode is 0 to 255 (the entire range of colors).
  • : this option enables the ability to access the Contour spinbox
  • 0/2 Contour : this spinbox gives the contour line. do not use (ex: 0 for the base).
  • Capping White: this function can be made on the choice of colours, white (default) or black. The degrees of capping rule 20 to 0 (or 255 to 0) if the checkbox is set on W (unchecked) or 0 to 20 (or 0 to 255) if the checkbox is set on B (checked).
  • 20 Capping : this spinbox gives the degrees of capping.

Command

  • File and launch: opens the image file and launches the conversion.
  • Help:
    • Display the Wiki page in the FreeCAD browser
    • For change the parameter disponible: go to Tools → Edit parameter...
    • __The global step on spinBox:__
    • User parameter:BaseApp/Preferences/Macros/FCMmacros/FCTexture → SingleStep
    • Adjust the value desired (1.0 by default)
    • __For search if the macro is upgraded :__
    • User parameter:BaseApp/Preferences/Macros/FCMmacros/FCTexture → switchVesionMacroSearch
    • Adjust the switchVesionMacroSearch to true (false by default)
  • Quit: exits the function.

Script

The icons .png and .svg

Macro_Texture.FCMacro

Download the macro to Gist Macro FCTexture.FCMacro

Example

The images were inclined to enhance the 3D effect.









Links

The discussion on the forum to give your impressions or contact me.

The macro FCCreaLoft Macro Loft for automate the multi loft.

apply hair cell texture

How to handle pdf import properly and feasibly?

Revision

  • Ver 0.14c : 15-01-2021 include Gui.SendMsgToActiveView("ViewFit")
  • Ver 0.14b : 15-01-2021 Create Tab Coordinate and Tab Stretching for diminish the height of the macro and accepted in 15" screen
  • ver 0.14 : 06/01/2021 change the search path procedure and adding preference option: search the new macro upgraded
####new2
                pathFile      = os.path.dirname(SaveName) + "/"  #= C:/Provisoire400/
                formatFichier = os.path.splitext(SaveName)[1]    #= .png
                SaveName      = os.path.splitext(SaveName)[0]    #= /home/kubuntu/.FreeCAD/Macro/Texture_007_H #= C:/Provisoire400/image3D
                SaveNameformatFichier = SaveName + formatFichier #= C:/Provisoire400/image3D.png
                ####new2
                FreeCAD.ParamGet("User parameter:BaseApp/Preferences/Macros/FCMmacros/FCTexture").SetString("Path",pathFile)
                ####new
  • ver 0.13b: 30/12/2020 add try for time.clock() and time.process_time() for Python 3xyz...
  • ver 0.13 : 17/04/2020 Layout and PySide2 Qt5
  • ver 0.12 : 04/08/2019 add spinbox button for height
  • ver 0.11 :03/07/2019 adapt to Python 3
  • ver 0.10 : 28/12/2016 add save point in .pcd, .asc display a points cloud, height form, contour
  • ver 0.9 : 12/12/2016 adding save file .asc for cloud point
  • ver 0.8 : 16/03/2016 adding progressBar
  • ver 0.7 : 03/09/2014 Delete "translate" forgotten and bug fix discovered by the passage of PyQt to Pyside !
  • ver 0.6 : 26/08/2014 Delete all "_translate"
  • ver 0.5 : 25/08/2014 Delete "_translate (" MainWindow "," Stretching X ", None)" that prevented the display of tooltip with PySide (Windows Vista)
  • ver 0.4 : 08/08/2014 PyQt4 PySide
  • ver 0.3 : 28/03/2014 :comment out the line "# self.checkBox_5.setAccessibleName(_fromUtf8(""))"

that causes an error with the version FreeCAD : Version: 0.14.3343 (Git), Python version: 2.7.6, Qt version: 4.8.5