Any black box must be included in a \bbtk package,
that is in a particular shared library which can be loaded
dynamically by \bbtk (hence applications which use \bbtkns,
-such as the interpreter \bbi, launched by the development environment
+such as the development environment,
\bbStudions).
\begin{enumerate}
\item \textbf{Create a new package. }
Before defining any black box you
have to create a package, or more precisely
-the files which will allow you to generate the package
+the source files which will allow you to generate the package
(compile and link the shared library) and may be install it.
\texttt{bbStudio} does it for you.
You will have to create your new package in a new location and
may be include/link against existing libraries.
\end{itemize}
+You'll have to run the standalone application \bbCreatePackagens, that allows
+to create the basic file architecture
+to start the development of a new black box package.
\item \textbf{Describe your new box. }
You can do it either :
the utility \bbfy will then generate the corresponding \CPP code.
\end{itemize}
+
+You'll have to run the standalone application \bbCreateBlackbox allows to create the basic file architecture
+ to start the development of a new black box, that will be included in an already existing package.
+
\end{enumerate}
% ==========================================
a \texttt{wxWindow} and must be able to return a pointer to it.
If your black box is not a widget black box
(that is : doesn't returns a pointer to a \emph{Widget}),
- it must inherit from \texttt{bbtk::AtomicBlackBox}.
+ it must inherit from \texttt{bbtk::AtomicBlackBox}.\\
+ It returns a \texttt{wxWidget} which can be embedded into the \texttt{wxWindow}.\\
+ In particular, modal dialogs which are created and destroyed at the end of the process method of the box
+ are NOT \texttt{WxBlackBoxes}/
\subsubsection{Inherit or encapsulate ?}
\item Its {\bf type}, either
\begin{enumerate}
- \item a standard one (\texttt{std-template})
- \item a VTK Polydata Algorithm based box (\texttt{VTK\_PolydataAlgorithm-template}),
- \item a VTK Image Algorithm based box (\texttt{VTK\_ImageaAlgorithm-template}),
- \item if it uses the wxWidget Library (\texttt{widget-template})
+ \item AtomicBlackBox : a basic one, with no special I/O (\texttt{std-template})
+ \item WxBackBox : ouputs a \texttt{wxWindow},
+ \item a VTK Polydata Algorithm Box descendant,
+ \item a VTK Image Algorithm Box descendant
+
\end{enumerate}
\item The output format of the file, either a C++ file or an XML file.
% ==========================================
% ==========================================
-\subsubsection{Specific \texttt{xml} tags for \texttt{vtkImageAlgorithm} classes bbfication}
+\subsubsection{Specific \texttt{xml} tags for \texttt{vtkImageAlgorithm} classes bbfication by inheritance}
% ==========================================
\begin{verbatim}
-<blackbox name="..." type="VTK\_ImageAlgorithm">
+<blackbox name="..." type="VTK_ImageAlgorithm">
<vtkparent>the vtk ImageAlgorithm class it inherits from</vtkparent>
<input name="..." type="double" special="vtk parameter" description="..."/>
-<input name="..." type="vtkImageData*" special="vtk output" description="..."/>
+<input name="..." type="vtkImageData*" special="vtk input" description="..."/>
<output name="..." type="double" special="vtk parameter" description="..."/>
<output name="..." type="vtkImageData*" special="vtk output" description="..."/>
\end{verbatim}
% ==========================================
-\subsubsection{Specific \texttt{xml} tags for \texttt{vtkPolyDataAlgorithm} classes bbfication}
+\subsubsection{Specific \texttt{xml} tags for \texttt{vtkPolyDataAlgorithm} classes bbfication by inheritance}
% ==========================================
\begin{verbatim}
-<blackbox name="..." type="VTK\_PolyDataAlgorithm">
+<blackbox name="..." type="VTK_PolyDataAlgorithm">
<vtkparent>the vtk Polydata class it inherits from</vtkparent>
<input name="..." type="double" special="vtk parameter" description="..."/>
-<input name="..." type="vtkPolyData*" special="vtk output" description="..."/>
+<input name="..." type="vtkPolyData*" special="vtk input" description="..."/>
<output name="..." type="double" special="vtk parameter" description="..."/>
<output name="..." type="vtkPolyData*" special="vtk output" description="..."/>
\end{verbatim}
+
+\newpage
+
% ==========================================
\subsubsection{\bbfy \texttt{xml} tags reference}
% ==========================================
-
+ See tables \ref{xml_tags}, \ref{xml_tags2}
% ==========================================
\begin{table}[!ht]
\caption{\label{xml_tags}
-\bbfy \texttt{xml} tags reference}
+\bbfy \texttt{xml} tags reference (part 1)}
\small
\begin{tabular}{|lcllm{6cm}|}
\hline
& \texttt{special} & - & 0-1 & In: \{\texttt{``itk input'',
``vtk input'', ``itk parameter'', ``vtk parameter''}\} (see below).\\\hline
& \texttt{generic\_type} & c) & 0-1 & The ``generic'' type of the input (see text). \\\hline
-\texttt{<output>} & \texttt{name} & - & 1 & The name of the output \\\hline
+
+
+ \end{tabular}
+ \end{table}
+\begin{table}[!ht]
+\caption{\label{xml_tags2}
+\bbfy \texttt{xml} tags reference (part 2)}
+\small
+\begin{tabular}{|lcllm{6cm}|}
+\hline
+Tag & Attributes & Condition & Multiplicity & Description
+ \\ \hline
+ \texttt{<output>} & \texttt{name} & - & 1 & The name of the output \\\hline
& \texttt{type} & - & 1 & The type of the output \\\hline
& \texttt{special} & - & 0-1 & In: \{\texttt{``itk output'',
``vtk output''}\} (see below).\\\hline
& \texttt{generic\_type} & c) & 0-1 & The ``generic'' type of the output (see text).\\\hline
& \texttt{nature} & c) & 0-1 & The ``nature'' of the output (used for automatic GUI generation).\\\hline
-
\texttt{<process>} & - & - & 0-1 & The code of the processing method of the box. Must be put between clear tags : \texttt{<PRE></PRE>} \\\hline
\texttt{<constructor>} & - & - & 0-1 & The code of the user Constructor of the box (may contains default initialisations). Must be put between clear tags : \texttt{<PRE></PRE>} \\\hline
\texttt{<copyconstructor>} & - & - & 0-1 & The code of the user Copy Constructor of the box . Must be put between clear tags : \texttt{<PRE></PRE>} \\\hline
\texttt{<destructor>} & - & - & 0-1 & The code of the user Destructor of the box. Must be put between clear tags : \texttt{<PRE></PRE>} \\\hline
\end{tabular}
\end{table}
+
+ \newpage
+
% ==========================================
\begin{table}[!ht]
-\caption{\label{xml_tags}
+\caption{\label{xml_tags-conditions}
\bbfy \texttt{xml} tags conditions}
\small
\begin{tabular}{|ll|}
\end{tabular}
\end{table}
+.\\
+.\\
+.\\
+.\\
+.\\
+
+
+\newpage
+
+
% ==========================================
\subsection{\CPP description of a box}
% ==========================================