mercredi 29 mai 2013

3D Printer Project

I belong to the robotic club of my engineering school and we have a new project. It is divided in two part : first build a 3D Printer, then print chess pieces that we have modelised with CATIA V5.

The 3D Printer name is Prusa Mendel from this website http://reprap.org/wiki/.

A Prusa Mendel
For the moment we haven't done the electronic part, only the mechanical. But we will print our printed circuit soon.

As regards the modelisation part, we have for the moment designed three pieces. They should represent some important tools or symbols of science in general.

The first achieved piece is the tower :


Click here if you want to download it.

The pawn should be a LED but the design is still under discussion.




The bishop is likely to be a engine or a part of it.

Next step

lundi 6 mai 2013

Quick overview of VBA

This article recap the basics things you can do with VBA.


  • The code is read from top to bottom, with loops or not
  • You have to totally build the user interface through a userform (insert/userform) and add buttons, labels...
  • VBA could be considered as an oriented object programming language as well and you have methods, properties, functions, sub...
1) Userform



Tip : F5 to see how your userform looks like














To add a userform : insert/userform in your VBA Project

You can enlarge the userform, add other controls...If the little window with controls doesn't appear, just click on toolbox in your toolbar.

Useful Methods and properties :
  • your_userform.Caption : the name that appears on the top of the userform (it's not the intrinsic name of the userform, which is your_userform.Name)
  • your_userform.StarUpPosition (choose the initial position of your userform)
  • your_userform.Show : show the userform...
  • Userform_Initialize() : this sub is run when your userfom appears
2) Label


This is a text, which can't be modified by the user.




Useful Methods and properties :
  • label1.Caption : modify the text
  • label1.Font : change the backround color
  • label1.Visible = True (or False) Tell if the label is shown to the user or not (useful for no-intrusive error message)





3) Textbox






It's possible to enter a text or a number in a textbox.

Useful Methods and properties :
  • textbox1.Text or textbox1.Value : return the expression, which is type in the textbox (it's a string expression. Nothing typed equals to "" )
  • textbox1.Font





4) Command button




It allows to run an action, when selecting the button




Useful Methods and properties :
  • CommandButton1.Caption : to control the button text







5) Image




Add a picture in your userform (bmp, jpg or gif)

Useful Methods and properties :
  • Image1.Picture : select the image you want to show with the syntax : Image1.Picture = LoadPicture("your_path\your_image.jpg")
  • Image1.Autosize : automaticaly resize your image
Image1.PictureSizeMode=fmPictureSizeModeClip
(let your image unchanged)
Image1.PictureSizeMode=fmPictureSizeModeStretch

(enlarge and deform your image to fit to your frame)
Image1.PictureSizeMode=fmPictureSizeModeZoom
(enlarge your image with no deformation)


6) Listbox



It's possible to display a list, from which you can select an object

Useful Methods and properties :
  • listbox1.AddItem "text" : add an item in the list
  • listbox1.Clear : erase all values
  • listebox1.RemoveItem(listbox1.Listindex) : remove the n-1 item (where n=listbox1.Listindex)
  • listbox1.ListCount : number of values available on the list
  • listbox1.Text or Value : to get the selected element
  • listbox1.List(n) : to get item n in the list

7) Checkbox and option box


- Checkbox : activate an option
- Optionbox : allow to pick up only one option among others (you have to gather them in a same frame)




Useful Methods and properties :

  • checkbox1.Caption
  • checkbox1.Value / optionbox1.Value : if ticked = True else = False







For further information, follow this links :
In french
In english

Memento : Main type of data

Numeric :


Non numeric :


Interacting with the user :

Other than the userform there are pre-formatted interface.

  • MsgBox
Simple MsgBox :



MsgBox "Your message" 






Error MsgBox :




MsgBox "Are you sure?",vbOKCancel + vbCritical, "Question"





You can get the result in a variable ( result=MsgBox "Are you sure?",vbOKCancel + vbCritical, "Question")

Information MsgBox :




MsgBox "Just click on OK", vbInformation, "Question"






Exclamation MsgBox :





MsgBox "Be careful", vbExclamation, "Error"





  • InputBox
syntax : Inputbox (message,title,default. value)





nb_part = InputBox("How many parts do you want ? :", "Part creation", 2)




Back to the summary
Back to the tutorial

dimanche 5 mai 2013

Modifiying a sketch : Examples and exercices

I told you how to add a sketch and only a sketch. Now I present you some examples and exercices to modify sketches.

WARNING : If you want to use the macro recorder, don't forget to leave the sketch mode by the exit workbench button, or nothing will be recorded.

First, here you have the basic lines, which are needed every time, with the two alternatives :

  • With the sketch directly in the main body
sub your_sub()

Dim CATIA As Object

On Error Resume Next
Set CATIA = GetObject("CATIA.Application")
If Err.Number <> 0 Then
 Set CATIA = CreateObject("CATIA.Application")
 CATIA.Visible=True
End if
On Error GoTo 0

Dim myDocument As Documents
Set myDocument = CATIA.documents

Dim partDocument1 As partDocument
Set partDocument1 = myDocument.Add("Part")

Dim part1 As part
Set part1=partDocument1.Part

Dim bodies1 As Bodies
Set bodies1 = part1.Bodies

Dim body1 As Body
Set body1 = bodies1.Item("PartBody")

Dim sketches1 As Sketches
Set sketches1 = body1.Sketches

Dim originelements1 As OriginElements
Set originelements1 = part1.OriginElements

Dim reference1 As Reference
Set reference1 = originelements1.PlaneXY

Dim sketch1 As Sketch
Set sketch1 = sketches1.Add(reference1)

Dim factory2D1 as Factory2D
Set factory2D1 = sketch1.OpenEdition

sketch1.CloseEdition

part1.Update

End sub


  • With the sketch in your geometrical set


sub your_sub()
Dim CATIA As Object

On Error Resume Next
Set CATIA = GetObject("CATIA.Application")
If Err.Number <> 0 Then
 Set CATIA = CreateObject("CATIA.Application")
 CATIA.Visible=True
End if
On Error GoTo 0

Dim myDocument As Documents
Set myDocument = CATIA.documents

Dim partDocument1 As partDocument
Set partDocument1 = myDocument.Add("Part")

Dim part1 As part
Set part1=partDocument1.Part

Dim hybridBodies1 As HybridBodies
Set hybridBodies1 = part1.HybridBodies

Dim hybridBody1 As HybridBody
Set hybridBody1 = hybridBodies1.Item("Geometrical Set.1")

Dim sketches1 As Sketches
Set sketches1 = hybridbody1.HybridSketches

Dim originelements1 As OriginElements
Set originelements1 = part1.OriginElements

Dim reference1 As Reference
Set reference1 = originelements1.PlaneXY

Dim sketch1 As Sketch
Set sketch1 = sketches1.Add(reference1)

Dim factory2D1 as Factory2D
set factory2D1 = sketch1.OpenEdition

sketch1.CloseEdition

part1.Update

End sub

You can just copy/paste this code.

Now it's possible to modify this sketch. I suppose that the sketch is in your geometrical set (the code with the sketch directly in the body is slightly the same)

First I make a short list of the useful items in the sketch mode :


'To create a point
Dim point2D1 As Point2D
Set point2D1 = factory2D1.CreatePoint(your_H_coordinate, your_V_coordinate)

'To create a line
'Create the line using this command line

Dim line2D1 As Line2D
Set line2D1 = factory2D1.CreateLine(first_point_H_coordinate, first_point_V_coordinate, second_point_H_coordinate, second_point_V_coordinate)

'To create a circle

Dim circle2D1 As Circle2D
Set circle2D1 = factory2D1.CreateClosedCircle(center_H_coordinate, center_V_coordinate, radius_of_your_circle)

'To create a spline
'A spline needs control points instead of simple points
'Create a spline with three control points like this :


Dim controlPoint2D1 As ControlPoint2D
Set controlPoint2D1 = factory2D1.CreateControlPoint(H1, V1)

Dim controlPoint2D2 As ControlPoint2D
Set controlPoint2D2 = factory2D1.CreateControlPoint(H2, V2)

Dim controlPoint2D3 As ControlPoint2D
Set controlPoint2D3 = factory2D1.CreateControlPoint(H3, V3)

'The CreateSpline function needs a CATSafeArrayVariant according to the help

'Create an array of object like this

Dim arrayOfObject1(2)
Set arrayOfObject1(0) = controlPoint2D1
Set arrayOfObject1(1) = controlPoint2D2
Set arrayOfObject1(2) = controlPoint2D3


Dim spline2D1 As Spline2D
Set factory2D1temp=factory2D1
Set spline2D1 = factory2D1temp.CreateSpline(arrayOfObject1)


Refer to the help for the definition of more methods

CreateCircle
Creates and returns a 2D circle arc.

CreateClosedCircle
Creates and returns a closed 2D circle.

CreateClosedEllipse
Creates and returns a closed 2D ellipse.

CreateControlPoint
Creates and returns a 2D spline control point.

CreateEllipse
Creates and returns a 2D ellipse arc.

CreateHyperbola
Creates and returns a hyperbola.

CreateIntersection
Creates and returns the intersection of an object with the sketch.

CreateIntersections
Creates and returns the possible intersections of an object with the sketch.

CreateLine
Creates and returns a 2D line.

CreateLineFromVector
Creates and returns a 2D line.

CreateParabola
Creates and returns a parabola.

CreatePoint
Creates and returns a 2D point.

CreateProjection
Creates and returns the projection of an object on the sketch.

CreateProjections
Creates and returns the possible projections of an object on the sketch.

CreateSpline
Creates and returns a 2D b-spline.

Don't forget to use the macro recorder when you need a specific thing, it's a rough code but always useful.

Let's try a little crossover exercice between CATIA and Excel

Exercice :
You have an Excel table available which contain coordinates of points. Create a spline in CATIA V5 from this table.
Then create a circle : center (200,90) , radius = 22

Here for the excel file
Spoiler:

Sub splineexercice()
Dim CATIA As Object

On Error Resume Next
Set CATIA = GetObject("CATIA.Application")
If Err.Number <> 0 Then
Set CATIA = CreateObject("CATIA.Application")
CATIA.Visible = True
End If
On Error GoTo 0

Dim myDocument As Documents
Set myDocument = CATIA.Documents

Dim partDocument1 As partDocument
Set partDocument1 = myDocument.Add("Part")

Dim part1 As Part
Set part1 = partDocument1.Part

Dim hybridBodies1 As HybridBodies
Set hybridBodies1 = part1.HybridBodies

Dim hybridBody1 As HybridBody
Set hybridBody1 = hybridBodies1.Item("Geometrical Set.1")

Dim sketches1 As Sketches
Set sketches1 = hybridBody1.HybridSketches

Dim originelements1 As OriginElements
Set originelements1 = part1.OriginElements

Dim reference1 As Reference
Set reference1 = originelements1.PlaneXY

Dim sketch1 As Sketch
Set sketch1 = sketches1.Add(reference1)

Dim factory2D1 As Factory2D
Set factory2D1 = sketch1.OpenEdition

Dim i As Integer
i = 2

Dim arrayOfObject1(36)

Dim H As Single
Dim V As Single

While Worksheets("Feuil1").Range("A" & i) <> ""

H = Worksheets("Feuil1").Range("A" & i).Value
V = Worksheets("Feuil1").Range("B" & i).Value

Dim controlPoint2D1 As ControlPoint2D
Set controlPoint2D1 = factory2D1.CreateControlPoint(H, V)

Set arrayOfObject1(i - 1) = controlPoint2D1

i = i + 1

Wend

Dim spline2D1 As Spline2D
Set factory2D1temp = factory2D1
Set spline2D1 = factory2D1temp.CreateSpline(arrayOfObject1)

Dim circle2D1 As Circle2D
Set circle2D1 = factory2D1.CreateClosedCircle(200, 90, 22)

sketch1.CloseEdition

part1.Update

End Sub


Let's head to the Part Design workbench !

jeudi 2 mai 2013

CATIA Structure


What is the CATIA structure ?

The CATIA structure is quite complex and for this tutorial, you need to open V5Automation.chm. On the first page you see this : 



As the color tells it, there are three types of objects in CATIA :
  • A collection : it's basically a liste of objects
  • An abstract object : you can't concretely create one but you need to define them
  • An object : an entity you can create it and work with it
As VBA is called an oriented-object programming language, it has a particular structure. And documents, parts, sketches, pocket, lines and points are represented as objects in VBA. we can distinct two ways for acting on objects : property and method.

Property : It's a characteristic of an object

Method : It's an action on an object

Take the example of a sketch :


For the property GeometricElements, if you've already defined a sketch named sketch1, you can type :

[...]
Dim geometricelements1 as GeometricElements
Set geometricelements1 = sketch1.GeometricElements
[...]

Notice that Set assign an object to a variable.

For the method OpenEdition, it's  :

[...]
Dim factory2D1 As Factory2D
Set factory2D1 = sketch1.OpenEdition
[...]

You didn't create another object with this method but just opened Sketcher.

Creating and opening a document :

Replace "Part" by "Product" or "Drawing" to have the corresponding document.
[...]
Dim partdocument1 As partdocument
Set pardocument1 = CATIA.Documents.Add("Part")
[...]

[...]
Dim partdocument1 As partdocument
Set partdocument1 = CATIA.Documents.Open("your_path\DocumentToOpen.CATPart")
[...]

Closing and saving a document :

There are three differents ways to use the Close function :
  • To close the active document
[...]
CATIA.ActiveDocument.Close
[...]
Be careful, this line will return an error if there is no active document.

  • To close a document assigned to a document1 variable
[...]
document1.Close
[...]
  • To close a document assigned to a name
[...]
CATIA.Documents.Item("Name").Close
[...]

Like the close function, there are three ways to save :

To save the active document : CATIA.ActiveDocument.Save
To save a Document assigned to a document1 variable : document1.Save
To save a Document assigned to a name : CATIA.Documents.Item(“Name”).Save


In addition, you can use the very useful function SaveAs
CATIA.ActiveDocument.SaveAs “your_path\MyNewName.your_extension”

Application exercice :
Create a macro that allow ou to open the sketch edition using the CATIA structure (fonction name_of_your_sketch.OpenEdition)

Notice that you can't delete your sketch. In fact you didn't closed the editor (even if you can't see it open)
Just delete the part now and add name_of_your_sketch.CloseEdition to your macro.

First choice : the sketch is in the body of your part.
Spoiler:
sub open_sketch_editor()
Dim CATIA As Object

'This part is always needed

On Error Resume Next
Set CATIA = GetObject("CATIA.Application")
If Err.Number <> 0 Then
 Set CATIA = CreateObject("CATIA.Application")
 CATIA.Visible=True
End if
On Error GoTo 0

'I follow the CATIA structure, first : introduce a documents type

Dim myDocument As Documents
Set myDocument As CATIA.documents

'Then add a new part/product/drawing document. Here it's a partdocument.

Dim partDocument1 As partDocument
Set partDocument1 = myDocument.Add("Part")

'Explicit the part

Dim part1 As part
Set part1=partDocument1.Part

'As the sketch is in the body of your part, I introduce a bodies type then a body

Dim bodies1 As Bodies
Set bodies1 = part1.Bodies

Dim body1 As Body
Set body1 = bodies1.Item("MainBody")

'Like the others, we have to intoduce the collection sketches before the sketch

Dim sketches1 As Sketches
Set sketches1 = body1.Sketches

'Set the origin

Dim originelements1 As OriginElements
Set originelements1 = part1.OriginElements

'I choose the XY plane (to choose another reference plane, just replace by YZ or ZX)

Dim reference1 As Reference
Set reference1 = originelements1.PlaneXY

'Finally we can create the sketch !

Dim sketch1 As Sketch
Set sketch1 = sketches1.Add(reference1)

'And use the fonction OpenEdition() (no argument needed but a fonction has always ()

sketch1.OpenEdition()

'Don't forget to close your sketch editor !

sketch1.CloseEdition()

'It's useful to update the part after modifying it

part1.Update

End sub

Second choice : the sketch is in a Geometrical Set
Spoiler:
sub open_sketch_editor()
Dim CATIA As Object

'This part is always needed

On Error Resume Next
Set CATIA = GetObject("CATIA.Application")
If Err.Number <> 0 Then
 Set CATIA = CreateObject("CATIA.Application")
 CATIA.Visible=True
End if
On Error GoTo 0

'I follow the CATIA structure, first : introduce a documents type

Dim myDocument As Documents
Set myDocument As CATIA.documents

'Then add a new part/product/drawing document. Here it's a partdocument.

Dim partDocument1 As partDocument
Set partDocument1 = myDocument.Add("Part")

'Explicit the part

Dim part1 As part
Set part1=partDocument1.Part

'As the sketch is in the geometrical set, I introduce a hybridbodies type then a hybridbody

Dim hybridBodies1 As HybridBodies
Set hybridBodies1 = part1.HybridBodies

Dim hybridBody1 As HybridBody
Set hybridBody1 = hybridBodies1.Item("Geometrical Set.1")

'Like the others, we have to intoduce the collection sketches before the sketch

Dim sketches1 As Sketches
Set sketches1 = body1.Sketches

'Set the origin

Dim originelements1 As OriginElements
Set originelements1 = part1.OriginElements

Dim reference1 As Reference
Set reference1 = originelements1.PlaneXY

'I create the sketch

Dim sketch1 As Sketch
Set sketch1 = sketches1.Add(reference1)

sketch1.OpenEdition()

'Again don't forget to close your sketch editor !

sketch1.CloseEdition()

part1.Update

End sub

Before looking at the next articles I have to talk about the macro recording tool. See what the macro recording records :


Sub CATMain()

Dim partDocument1 As PartDocument
Set partDocument1 = CATIA.ActiveDocument

Dim part1 As Part
Set part1 = partDocument1.Part

Dim hybridBodies1 As HybridBodies
Set hybridBodies1 = part1.HybridBodies

Dim hybridBody1 As HybridBody
Set hybridBody1 = hybridBodies1.Item("Geometrical Set.1")

Dim sketches1 As Sketches
Set sketches1 = hybridBody1.HybridSketches

Dim originElements1 As OriginElements
Set originElements1 = part1.OriginElements

Dim reference1 As Reference
Set reference1 = originElements1.PlaneXY

Dim sketch1 As sketch
Set sketch1 = sketches1.Add(reference1)

Dim arrayOfVariantOfDouble1(8)
arrayOfVariantOfDouble1(0) = 0#
arrayOfVariantOfDouble1(1) = 0#
arrayOfVariantOfDouble1(2) = 0#
arrayOfVariantOfDouble1(3) = 1#
arrayOfVariantOfDouble1(4) = 0#
arrayOfVariantOfDouble1(5) = 0#
arrayOfVariantOfDouble1(6) = 0#
arrayOfVariantOfDouble1(7) = 1#
arrayOfVariantOfDouble1(8) = 0#
Set sketch1Variant = sketch1
sketch1Variant.SetAbsoluteAxisData arrayOfVariantOfDouble1

part1.InWorkObject = sketch1

Dim factory2D1 As Factory2D
Set factory2D1 = sketch1.OpenEdition()

Dim geometricElements1 As GeometricElements
Set geometricElements1 = sketch1.GeometricElements

Dim axis2D1 As Axis2D
Set axis2D1 = geometricElements1.Item("AbsoluteAxis")

Dim line2D1 As Line2D
Set line2D1 = axis2D1.GetItem("HDirection")

line2D1.ReportName = 1

Dim line2D2 As Line2D
Set line2D2 = axis2D1.GetItem("VDirection")

line2D2.ReportName = 2

sketch1.CloseEdition

part1.InWorkObject = hybridBody1

part1.Update

End Sub


There are minor differences.
First : the recorder used the command ActiveDocument. I don't recommended to use this method or whith high precaution. In fact there is a high chance that you have another document which is open in CATIA. So the macro could take another document as ActiveDocument.

It defined a safe arr : arrayOfVariantOfDouble1 You don't need them, for the moment, to have a working code. A safe array can stock variables like arrays in other programming languages. However they have to have a type (like Double, Object...) A example will be showed later.

part1.InWorkObject = sketch1 is optional

Dim factory2D1 As Factory2D
Set factory2D1 = sketch1.OpenEdition()
Factory2D is an object, which contains all the methods of Sketcher Workbench. Look at the help for the exhaustice list of methods.

The axis are automatically set so you don't need to introduce them like the macro recorder do.

The macro recorder autorename the elements with, for example, line2D1.ReportName = 1 ,but you didn't have to do it and simply use the name line2D1.  

You have certainly noticed that this macro did only create a sketch and no more. The next step is to modify this sketch.

Next article : 3.Modifying a sketch

Introduction to CATIA V5 Automation



CATIA V5 is a powerful tool in the CAO field. With some work you could be able to design almost everything. But how many time will you need, for example, to create ALL screws in your assembly ? With each type ? Each diameter ? Hopefully a tool named VBA exist to get rid of this waste of time. 
I will present  you the very basics applications of using VBA macros with CATIA V5.

First of all CATIA V5 can be piloted with mainly three possible languages :
  1. Visual Basic
  2. VBA
  3. CATScript
I choosed to use VBA for a simple reason : It allows me to use easyly Excel to pilot CATIA. That's mean I could use datasheets or graphics to create Parts in CATIA V5. Moreover it offers a better interface with the user (command button, listbox...) and a priceless programming help (automatical completion, help to find errors). However VBA has disavantages like a weak protection and it could be difficult to export VBA macros.

I suppose in the following that you have some prerequisites in VBA. If not, you can look at this article which present briefly VBA for Excel. If it's not enough, you can find plenty of tutorials in Internet.

Before beginning I introduce your new best friend : the CATIA help. It's very dense and complexe but it should be your reference. You find it here : \Catia_V5\intel_a\code\bin\V5Automation.chm. I suggest you to make immediatly a shortcut on your desktop.

1) CATIA V5 OLE (Object Linking and Embedding)

If you want to have an interactive review in Word for example, you can use the link between CATIA and Word : just drag and drop a CATPart on your word document and you have a picture of your part. Double-click on it and you can edit it in CATIA V5 (Figure 1).

Picture 1 : OLE operation


2) IN- and OUT macros

a) IN process application

You have two choices to pilot CATIA.

First you can use the Visual Basic Editor included in CATIA V5 (TOOLS\MACRO\Visual Basic Editor Picture 2)
You create this way IN process application.

Picture 2 : Run the VB Editor

You have the same Macro menu as in VBA Excel where you can see all the macro you have writed. You can run, edit, rename or delete this macro. You can also record a macro if you have a specifical need or when you did'nt remember the right syntax. Then you can find it in the module name you have choosed. 

How to add a macro as a command in a Toolbar ?

Go to Tools\customize\Commands and click on Macro. Select the macro you want and then drag and drop it in the toolbar you wish. You can also use a personalised icon if you don't like the default icon by clicking on Show Properties (Picture 3)

Picture 3 : How to add a macro on your toolbar


b) OUT process application

Otherwise, you can pilot CATIA through Excel.
Personnaly, I found this solution more effective for two reasons :

  • You can use Excel datas
  • You have more freedom (VB Editor in CATIA need a CATMain sub whereas VBA in Excel didn't)
However you have to activate the CATIA functions, propertys and types. Just check the boxes beginning by catia in TOOL\REFERENCES (Picture 3)

Picture 3 : Activate the CATIA libraries in VBA Excel



























However, as you aren't in CATIA VB Editor, you have to declare CATIA as Object in your sub.

You have two cases :

  • If CATIA is already running
The GetObject function allows to set CATIA application as the object you defined.
The code is so :

[...]
Dim CATIA As Object
Set CATIA = GetObject("CATIA.Application")
[...]

  • If CATIA is not running 
You have to create the object using CreateObject :

[...]
Dim CATIA As Object
Set CATIA = CreateObject("CATIA.Application")
[...]

Now you are able to create your first macro, which launch CATIA if not.

sub CATRun()

Dim CATIA As Object

'In Error case CATIA is not already open

On Error Resume Next
Set CATIA = GetObject("CATIA.Application")
If Err.Number <> 0 Then
 Set CATIA = CreateObject("CATIA.Application")
 CATIA.Visible=True
End if
On Error GoTo 0

End sub

Now you're able to run CATIA V5 through Excel. Before going further you need to have a introduction to the CATIA structure.