57d05113e14215efc11ed252f2c0f9ece9f3c4fd
[scilab.git] / scilab / modules / gui / help / en_US / usecanvas.xml
1 <?xml version="1.0" encoding="UTF-8"?>
2 <refentry xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:svg="http://www.w3.org/2000/svg" xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:db="http://docbook.org/ns/docbook" version="5.0-subset Scilab" xml:lang="en" xml:id="usecanvas">
3   <info>
4     <pubdate>$LastChangedDate: 2007-12-07 11:59:53 +0100 (ven, 07 déc 2007) $</pubdate>
5   </info>
6   <refnamediv>
7     <refname>usecanvas</refname>
8     <refpurpose>Get/Set the main component used for Scilab graphics.</refpurpose>
9   </refnamediv>
10   <refsynopsisdiv>
11     <title>Calling Sequence</title>
12     <synopsis>
13        [canvasused] = usecanvas([usecanvasfordisplay]);
14     </synopsis>
15   </refsynopsisdiv>
16   <refsection>
17     <title>Parameters</title>
18     <variablelist>
19       <varlistentry>
20         <term>canvasused</term>
21         <listitem>
22           <para>Boolean:</para>
23           <itemizedlist>
24             <listitem>
25               <para><literal>%T</literal> if a "GLCanvas" is used for graphics display (Mixing uicontrols and graphics <emphasis role="bold">not available</emphasis>).</para>
26             </listitem>
27             <listitem>
28               <para><literal>%F</literal> if a "GLJPanel" is used for graphics display (Mixing uicontrols and graphics available).</para>
29             </listitem>
30           </itemizedlist>
31         </listitem>
32       </varlistentry>
33       <varlistentry>
34         <term>usecanvasfordisplay</term>
35         <listitem>
36           <para>Boolean:</para>
37           <itemizedlist>
38             <listitem>
39               <para><literal>%T</literal> to use a "GLCanvas" for graphics display (Mixing uicontrols and graphics <emphasis role="bold">not available</emphasis>).</para>
40             </listitem>
41             <listitem>
42               <para><literal>%F</literal> to use a "GLJPanel" for graphics display (Mixing uicontrols and graphics available).</para>
43             </listitem>
44           </itemizedlist>
45         </listitem>
46       </varlistentry>
47     </variablelist>
48   </refsection>
49   <refsection>
50     <title>Description</title>
51     <para>Scilab uses a "GLJPanel" (a Swing OpenGL component) to display graphics (plot3d, plot, ...). This component uses some high level OpenGL primitives which are not correctly supported on some platforms (depending on the operating system, video cards, drivers ...)</para>
52     <para>"GLCanvas" (AWT + OpenGL) is an alternative component provided by the Java Framework. Scilab can use it to render graphics. <emphasis role="bold">However, using this component disables some capabilities such as mixing plots and uicontrols (see demo GUI/UIcontrol2). That is why it is not the default behavior.</emphasis></para>
53
54     <para>In some particular cases, the use of the "GLCanvas" component is forced when Scilab starts (a warning message is displayed when a graphics function is used for the first time), here is a list of these cases:</para>
55     <informaltable border="2">
56       <tr>
57         <td align="center"><emphasis role="bold">Operating System</emphasis></td>
58         <td align="center"><emphasis role="bold">Video Card</emphasis></td>
59         <td align="center"><emphasis role="bold">Details</emphasis></td>
60       </tr>
61
62       <tr>
63         <td align="center">64-bits Windows</td>
64         <td align="center">All</td>
65         <td align="center">When Scilab is used in a remote session.</td>
66       </tr>
67
68       <tr>
69         <td rowspan="3" valign="middle" align="center">Linux</td>
70         <td align="center">NVIDIA Card</td>
71         <td align="center">With free drivers.</td>
72       </tr>
73       <tr>
74         <td align="center">ATI Card</td>
75         <td align="center">With free drivers or ATI-drivers with version &lt; 8.52.3 (Installer version &lt; 8.8 / OpenGL version &lt; 2.1.7873).</td>
76       </tr>
77       <tr>
78         <td align="center">INTEL Card</td>
79         <td align="center">With Direct Rendering activated.</td>
80       </tr>
81     </informaltable>
82
83     <para>You can also dynamically activate this component through Scilab using <literal>usecanvas</literal>: </para>
84     <itemizedlist>
85       <listitem>
86         <para><literal>usecanvas(%T)</literal> will use "GLCanvas" for plot rendering.</para>
87       </listitem>
88       <listitem>
89         <para><literal>usecanvas(%F)</literal> will use "GLJPanel" for plot rendering. If your configuration is known as a one having problems with "GLJPanel" (See table above), a warning message will be displayed.</para>
90       </listitem>
91     </itemizedlist>
92
93     <para>If you believe your configuration is able to use the "GLJPanel" and Scilab automatically forces the use of "GLCanvas", you can test your configuration by swithing to "GLJPanel" (<literal>usecanvas(%F)</literal>) and try to plot something (<literal>plot3d()</literal> for example). If Scilab graphics work, please inform us about it by sending an email to <literal>scilab.support@scilab.org</literal> and giving us your Operating System/Video Card/Video Card driver version: this will help use to improve future versions of Scilab.</para>
94   </refsection>
95
96   <!-- This part comes from http://wiki.scilab.org/Graphical_issues_with_Scilab_5.0 -->
97   <refsection>
98     <title>Technical Aspects</title>
99     
100     <para>Since version 5.0, Scilab is doing an advanced use of JOGL (the Java Binding for the OpenGL), which is using the Java2D OpenGL Pipeline. For performance reasons, we use the Java2D OpenGL Pipeline. From a more technical aspect, it uses the internal buffer of the graphic cards called <literal>pbuffer</literal>.</para>
101     
102     <para>Problems may occur when the driver of the graphic card does not support properly this approach. As far as we know, there is no free driver under Linux handling this feature. In the proprietary world, the situation is as follows: </para>
103     <itemizedlist>
104       <listitem>
105         <para><literal>NVIDIA</literal>: Nvidia provides the appropriate proprietary drivers. Scilab's graphics work without any problem with most NVIDIA drivers.</para>
106       </listitem>
107       <listitem>
108         <para><literal>ATI</literal>: From the driver version 8.8, most ATI graphics supports the pbuffer under Linux.</para>
109       </listitem>
110       <listitem>
111         <para><literal>Intel</literal>: This is the big drawback of using the pbuffer. There is currently no support of pbuffer by any official Intel drivers under Linux.</para>
112       </listitem>
113     </itemizedlist>
114     
115     <para>There is a workaround for Linux to tackle this issue, but a solution is to use a software accelerated driver. To do it, in <literal>/etc/X11/xorg.conf</literal>, look for the <emphasis role="italic">Section "Device"</emphasis> and change the option <emphasis role="italic">Driver</emphasis> to <emphasis role="italic">vesa</emphasis>: </para>
116     <programlisting role="example"><![CDATA[
117
118 Section "Device"
119         Identifier      "Your Graphic card"
120         Driver  "vesa"
121 [...]
122 EndSection
123
124   ]]></programlisting>
125     <para>Unfortunately, this solution makes Scilab pretty slow. </para>
126
127     <para>Under Windows, video cards manufacturers update regularly and <literal>pbuffers</literal> are managed. Please download recent drivers at:</para>
128     <itemizedlist>
129       <listitem>
130         <para>For <literal>ATI cards</literal>: <ulink url="http://ati.amd.com/support/driver.html">http://ati.amd.com/support/driver.html</ulink></para>
131       </listitem>
132       <listitem>
133         <para>For <literal>Intel cards</literal>: <ulink url="http://www.intel.com/support/graphics/">http://www.intel.com/support/graphics/</ulink></para>
134       </listitem>
135       <listitem>
136         <para>For <literal>Matrox cards</literal>: <ulink url="http://www.matrox.com/graphics/en/support/drivers/">http://www.matrox.com/graphics/en/support/drivers/</ulink></para>
137       </listitem>
138       <listitem>
139         <para>For <literal>NVIDIA cards</literal>: <ulink url="http://www.nvidia.com/content/drivers/drivers.asp">http://www.nvidia.com/content/drivers/drivers.asp</ulink></para>
140       </listitem>
141       <listitem>
142         <para>For <literal>S3 cards</literal>: <ulink url="http://www.s3graphics.com/en/resources/drivers/index.jsp">http://www.s3graphics.com/en/resources/drivers/index.jsp</ulink></para>
143       </listitem>
144       <listitem>
145         <para>For <literal>SiS cards</literal>: <ulink url="http://www.sis.com/download/">http://www.sis.com/download/</ulink></para>
146       </listitem>
147       <listitem>
148         <para>For <literal>VIA cards</literal>: <ulink url="http://www.viaarena.com/default.aspx?PageID=2">http://www.viaarena.com/default.aspx?PageID=2</ulink></para>
149       </listitem>
150     </itemizedlist>
151     <para>Some troubles can also occur when using Windows 2000 (video drivers are no more updated and no more supported).</para>
152
153     <para>In the cases where pBuffer create a problem, waiting for a working <literal>pbuffer</literal> is not a solution indeed: <ulink url="https://jogl.dev.java.net/issues/show_bug.cgi?id=163"><emphasis role="italic">The OpenGL community is moving away from pbuffers and toward the frame buffer object extension, which is a more portable and higher-performance solution for offscreen rendering than pbuffers.</emphasis></ulink>. The JOGL team is working to fix this issue.</para>
154
155     <para>For more information about this problem, please refer to: </para>
156     <itemizedlist>
157       <listitem>
158         <para><literal>JoGL</literal> bug database: <ulink url="https://jogl.dev.java.net/issues/show_bug.cgi?id=366">Bug #366</ulink></para>
159       </listitem>
160       <listitem>
161         <para><literal>Scilab</literal> bug database: <ulink url="http://bugzilla.scilab.org/show_bug.cgi?id=3525">Bug #3525</ulink></para>
162       </listitem>
163       <listitem>
164         <para><literal>Debian</literal> bug database: <ulink url="http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=501799">Bug #501799</ulink></para>
165       </listitem>
166       <listitem>
167         <para><literal>Freedesktop</literal> bug database: <ulink url="https://bugs.freedesktop.org/show_bug.cgi?id=17603">Bug #17603</ulink></para>
168       </listitem>
169     </itemizedlist>
170   </refsection>
171
172   <refsection>
173     <title>Examples</title>
174     <programlisting role="example"><![CDATA[
175
176 // Example using GLJPanel (Mixing uicontrols and graphics is available)
177 usecanvas(%F);
178 plot2d();
179 uicontrol("String", "Close the window", "Position", [10 10 100, 25], "Callback", "delete(gcf())");
180 messagebox("You can see the button on the figure.", "Usecanvas example", "info");
181
182 // Example using GLCanvas (Mixing uicontrols and graphics is not available, uicontrols are not visible)
183 usecanvas(%T);
184 plot2d();
185 uicontrol("String", "Close the window", "Position", [10 10 100, 25], "Callback", "delete(gcf())");
186 messagebox("You can''t see any button on the figure.", "Usecanvas example", "info");
187
188   ]]></programlisting>
189   </refsection>
190   <refsection>
191     <title>Authors</title>
192     <para>Vincent COUVERT</para>
193   </refsection>
194 </refentry>