update dev300-m57
[ooovba.git] / odk / examples / examples.html
blob98afc9b119941099f6dced4404ccc86d09f21969
1 <html>
2 <head>
3 <title>[TITLE] - Examples</title>
4 <link rel="stylesheet" type="text/css" href="../docs/sdk_styles.css">
5 <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
6 <meta name="author" content="J&uuml;rgen Schmidt">
7 <meta name="created" content="2004-12-14">
8 </head>
10 <body class="sdkbody"><a name="examples"/>
11 <table class="table1" cellpadding=0>
12 <tr style="background-image:url(../docs/images/sdk_head-2.gif); backgorund-position: bottom; ">
13 <td class="background" colspan="2" align="left"><img src="../docs/images/sdk_head-1.gif" width="335" height="109" usemap="#Map" border="0"></td>
14 <td class="background" align=right><img src="../docs/images/sdk_head-3.gif" width="32" height="109"></td>
15 </tr>
16 <tr>
17 <td colspan="3"><img class="nothing10" src="../docs/images/nada.gif"></td>
18 </tr>
19 <tr>
20 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
21 <td>
22 <table class="table2">
23 <tr>
24 <td colspan="3"><img class="nothing1" src="../docs/images/nada.gif"></td>
25 </tr>
26 <tr>
27 <td>
28 <table class="table3">
29 <tr>
30 <td colspan="2" class="head1">Examples</td>
31 <td align="right"><a href="../index.html" title="link to the SDK start page"><img class="navigate" src="../docs/images/nav_home.png"></a></td>
32 </tr>
33 </table>
34 </td>
35 </tr>
36 <tr>
37 <td>
38 <table class="table3">
39 <tr>
40 <td colspan="3">
41 <p>The SDK provides a rich set of examples in different programming
42 languages (Java, C++, [PRODUCTNAME] Basic, OLE) to illustrate the use
43 of the API and demonstrate how to benefit from the included word
44 processor, spreadsheet, presentation software, graphics program and
45 database of [PRODUCTNAME].<br>
46 Some fo the examples need a running office instance listening on a
47 port. If this is necessary you will get further information in the
48 makefiles.</p>
49 <p>Every makefile contains at least one run target to execute an
50 running example, please see the makefile output in the different
51 example directories. Some of the examples which create a component have
52 no run target. In these cases a document is provided which instantiates
53 and runs the component (see the makefile output). Also the Basic
54 examples provide documents which use and shows the implemented
55 functionality.</p>
56 </td>
57 </tr>
58 <tr>
59 <td><img class="line" src="../docs/images/sdk_line-1.gif"></td>
60 </tr>
61 </table>
62 </tr>
63 <tr>
64 <td>
65 <table class="table3">
66 <tr valign="top">
67 <td class="content3"><img src="../docs/images/arrow-1.gif"></td>
68 <td><a href="DevelopersGuide/examples.html" title="link to the Developer's Guide examples overview page">Developer's Guide examples</a></td>
69 <td class="content75">The <a href="http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/OpenOffice.org_Developers_Guide" title="link to the Developer's Guide in the Wiki">Developer's Guide</a> comes
70 with a rich set of examples which demonstrate the use of the API in
71 the different application areas.</td>
72 </tr>
73 <tr valign="top">
74 <td class="content3"><img src="../docs/images/arrow-1.gif"></td>
75 <td><a href="#Java_examples" title="link to the Java examples section">Java examples</a></td>
76 <td class="content75">Set of simple and more complex examples which
77 shows the use of the API from Java.</td>
78 </tr>
79 <tr valign="top">
80 <td class="content3"><img src="../docs/images/arrow-1.gif"></td>
81 <td><a href="#Cpp_examples" title="link to the C++ examples section">C++ examples</a></td>
82 <td class="content75">Small set of examples which shows the use of
83 the API from C++.</td>
84 </tr>
85 <tr valign="top">
86 <td class="content3"><img src="../docs/images/arrow-1.gif"></td>
87 <td><a href="#Basic_examples" title="link to the [PRODUCTNAME] Basic examples section">[PRODUCTNAME] Basic examples</a></td>
88 <td class="content75">Small set of examples which shows the use of
89 the API from [PRODUCTNAME] Basic.</td>
90 </tr>
91 <tr valign="top">
92 <td class="content3"><img src="../docs/images/arrow-1.gif"></td>
93 <td><a href="#OLE_examples" title="link to the OLE examples section">Object Linking and Embedding (OLE) examples</a></td>
94 <td class="content75">Examples which show the use of the API from
95 OLE.</td>
96 </tr>
97 <tr valign="top">
98 <td class="content3"><img src="../docs/images/arrow-1.gif"></td>
99 <td><a href="#CLI_examples" title="link to the CLI examples section">Common Language Infrastructure (CLI) examples</a></td>
100 <td class="content75">Examples which show the use of the API from
101 the CLI.</td>
102 </tr>
103 </table>
104 </tr>
105 </table>
106 </td>
107 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
108 </tr>
109 <tr>
110 <td colspan="3"><img class="line" src="../docs/images/sdk_line-2.gif"></td>
111 </tr>
112 <tr>
113 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
114 <td>
115 <table class="table2">
116 <tr>
117 <td>
118 <table class="table3">
119 <tr>
120 <td colspan="2" class="head1"><a name="Java_examples">Java examples</td>
121 <td align="right">
122 <a href="#examples" title="link to the examples overview"><img class="navigate" src="../docs/images/nav_up.png"></a>
123 <a href="../index.html" title="link to the SDK start page"><img class="navigate" src="../docs/images/nav_home.png"></a>
124 </td>
125 </tr>
126 </table>
127 </td>
128 </tr>
129 <tr>
130 <td>
131 <table class="table4">
132 <tbody>
133 <tr class="thead">
134 <td class="cell20">Text Document Examples</td>
135 <td class="cell80">Description</td>
136 </tr>
137 <tr>
138 <td class="cell20"><a href="java/Text/" title="link to the source directory of the Java Text examples">BookmarkInsertion</a></td>
139 <td class="cell80">This application connects to the office server and
140 gets the <a href="../docs/common/ref/com/sun/star/lang/XMultiComponentFactory.html" title="link into the IDL reference to the interface com.sun.star.lang.XMultiComponentFactory"> multi component factory</a>. An empty text document will be opened
141 and an example text will be entered. Afterwards, some bookmarks will be
142 inserted.</td>
143 </tr>
144 <tr>
145 <td class="cell20"><a href="java/Text/" title="link to the source directory of the Java Text examples">HardFormatting</a></td>
146 <td class="cell80">This program connects to the office server and gets
147 the <a href="../docs/common/ref/com/sun/star/lang/XMultiComponentFactory.html" title="link into the IDL reference to the interface com.sun.star.lang.XMultiComponentFactory"> multi component factory</a>. Furthermore, an empty text document will be
148 opened, an example text will be entered, some text attributes will be
149 inspected, and the <a href="../docs/common/ref/com/sun/star/beans/PropertyState.html" title="link into the IDL reference to the enum com.sun.star.beans.PropertyState"> PropertyState</a> will be checked from the selection.</td>
150 </tr>
151 <tr>
152 <td class="cell20"><a href="java/Text/" title="link to the source directory of the Java Text examples">SWriter</a></td>
153 <td class="cell80">The program connects to the office server and gets the
154 <a href="../docs/common/ref/com/sun/star/lang/XMultiComponentFactory.html" title="link into the IDL reference to the interface com.sun.star.lang.XMultiComponentFactory"> multi component factory</a>. An empty text document will be created, some
155 text will be entered, and a text table, a colored text, and text frame
156 will be inserted.</td>
157 </tr>
158 <tr>
159 <td class="cell20"><a href="java/Text/" title="link to the source directory of the Java Text examples">StyleCreation</a></td>
160 <td class="cell80">The example connects to the office server and gets the
161 <a href="../docs/common/ref/com/sun/star/lang/XMultiComponentFactory.html" title="link into the IDL reference to the interface com.sun.star.lang.XMultiComponentFactory"> multi component factory</a>. An empty text document will be opened, a new
162 paragraph style will be created, and applied.</td>
163 </tr>
164 <tr>
165 <td class="cell20"><a href="java/Text/" title="link to the source directory of the Java Text examples">StyleInitialization</a></td>
166 <td class="cell80">The program connects to the office server and gets the
167 <a href="../docs/common/ref/com/sun/star/lang/XMultiComponentFactory.html" title="link into the IDL reference to the interface com.sun.star.lang.XMultiComponentFactory"> multi component factory</a>. Thereafter, an empty text document will be
168 opened and an example text will be entered. The paragraph collection will
169 be used, in order to apply a different paragraph style on the
170 paragraphs.</td>
171 </tr>
172 <tr>
173 <td class="cell20"><a href="java/Text/" title="link to the source directory of the Java Text examples">TextDocumentStructure</a></td>
174 <td class="cell80">The application connects to the office server and gets
175 the <a href="../docs/common/ref/com/sun/star/lang/XMultiComponentFactory.html" title="link into the IDL reference to the interface com.sun.star.lang.XMultiComponentFactory"> multi component factory</a>. An empty text document will be opened, an
176 enumeration of all paragraphs and an enumeration of all text portions
177 will be created.</td>
178 </tr>
179 <tr>
180 <td class="cell20"><a href="java/Text/" title="link to the source directory of the Java Text examples">TextReplace</a></td>
181 <td class="cell80">The example connects to the office server and gets the
182 <a href="../docs/common/ref/com/sun/star/lang/XMultiComponentFactory.html" title="link into the IDL reference to the interface com.sun.star.lang.XMultiComponentFactory"> multi component factory</a>. An empty text document will be created, an
183 example text will be inserted, and some English spelled words will be
184 replaced with US spelled words.</td>
185 </tr>
186 <tr>
187 <td class="cell20"><a href="java/Text/" title="link to the source directory of the Java Text examples">GraphicsInserter</a></td>
188 <td class="cell80">The GraphicsInserter creates a graphics object on an
189 empty text document by setting its position, width, height, and URL.</td>
190 </tr>
191 <tr>
192 <td class="cell20"><a href="java/Text/" title="link to the source directory of the Java Text examples">WriterSelector</a></td>
193 <td class="cell80">This class gives you information on the selected
194 objects (text range, text frame, or graphics) at an OpenOffice.org
195 Server.</td>
196 </tr>
197 <tbody>
198 </table>
199 </td>
200 </tr>
201 <tr>
202 <td>
203 <table class="table4">
204 <tbody>
205 <tr class="thead">
206 <td class="cell20">Spreadsheet Document Examples</td>
207 <td class="cell80">Description</td>
208 </tr>
209 <tr>
210 <td class="cell20"><a href="java/Spreadsheet/" title="link to the source directory of the Java Spreadsheet examples">CalcAddins</a></td>
211 <td class="cell80">This component adds new functions to the spreadsheet
212 application. After registering the component, the inserted functions can
213 be found with help of the functions autopilot. The new functions are
214 assigned to the category <i>Add-in</i>.</td>
215 </tr>
216 <tr>
217 <td class="cell20"><a href="java/Spreadsheet/" title="link to the source directory of the Java Spreadsheet examples">ChartTypeChange</a></td>
218 <td class="cell80">This class loads an [PRODUCTNAME] Calc document and
219 changes the type of the embedded chart.</td>
220 </tr>
221 <tr>
222 <td class="cell20"><a href="java/Spreadsheet/" title="link to the source directory of the Java Spreadsheet examples">EuroAdaption</a></td>
223 <td class="cell80">The application connects to the office server and gets
224 the <a href="../docs/common/ref/com/sun/star/lang/XMultiComponentFactory.html" title="link into the IDL reference to the interface com.sun.star.lang.XMultiComponentFactory"> multi component factory</a>, opens an empty Calc document, enters an
225 example text, sets the number format to DM, changes the number format to
226 EUR (Euro), and uses the DM/EUR factor on each cell with content.</td>
227 </tr>
228 <tr>
229 <td class="cell20"><a href="java/Spreadsheet/" title="link to the source directory of the Java Spreadsheet examples">SCalc</a></td>
230 <td class="cell80">The program connects to the office server and gets the
231 <a href="../docs/common/ref/com/sun/star/lang/XMultiComponentFactory.html" title="link into the IDL reference to the interface com.sun.star.lang.XMultiComponentFactory"> multi component factory</a>. Then an empty calc document will be opened,
232 cell styles will be created, some data will be inserted into the sheets,
233 and the created cell styles will be applied. Finally, a 3D chart will be
234 inserted.</td>
235 </tr>
236 <tbody>
237 </table>
238 </td>
239 </tr>
240 <tr>
241 <td>
242 <table class="table4">
243 <tbody>
244 <tr class="thead">
245 <td class="cell20">Drawing Document Examples</td>
246 <td class="cell80">Description</td>
247 </tr>
248 <tr>
249 <td class="cell20"><a href="java/Drawing/" title="link to the source directory of the Java Drawing examples">SDraw</a></td>
250 <td class="cell80">This program connects to the office server and gets
251 the <a href="../docs/common/ref/com/sun/star/lang/XMultiComponentFactory.html" title="link into the IDL reference to the interface com.sun.star.lang.XMultiComponentFactory"> multi component factory</a>. Afterwards, an empty text document will
252 be created and some shapes will be inserted on the draw page.</td>
253 </tr>
254 <tbody>
255 </table>
256 </td>
257 </tr>
258 <tr>
259 <td>
260 <table class="table4">
261 <tbody>
262 <tr class="thead">
263 <td class="cell20">Document Handling Examples</td>
264 <td class="cell80">Description</td>
265 </tr>
266 <tr>
267 <td class="cell20"><a href="java/DocumentHandling/" title="link to the source directory of the Java DocumentHandling examples">DocumentConverter</a></td>
268 <td class="cell80">The program offers a service that converts arbitrary
269 documents to a favored document type.</td>
270 </tr>
271 <tr>
272 <td class="cell20"><a href="java/DocumentHandling/" title="link to the source directory of the Java DocumentHandling examples">DocumentLoader</a></td>
273 <td class="cell80">The <i>DocumentLoader</i> can open a new or an
274 existing document.</td>
275 </tr>
276 <tr>
277 <td class="cell20"><a href="java/DocumentHandling/"title="link to the source directory of the Java DocumentHandling examples">DocumentPrinter</a></td>
278 <td class="cell80">The <i>DocumentPrinter</i> allows you to print the
279 favored pages of a specified document on your favored printer.</td>
280 </tr>
281 <tr>
282 <td class="cell20"><a href="java/DocumentHandling/" title="link to the source directory of the Java DocumentHandling examples">DocumentSaver</a></td>
283 <td class="cell80">The DocumentSaver shows how to save a document and
284 how you can change the type of your document.</td>
285 </tr>
286 <tbody>
287 </table>
288 </td>
289 </tr>
290 <tr>
291 <td>
292 <table class="table4">
293 <tbody>
294 <tr class="thead">
295 <td class="cell20">UNO Component Examples</td>
296 <td class="cell80">Description</td>
297 </tr>
298 <tr>
299 <td class="cell20"><a href="http://wiki.services.openoffice.org/wiki/Object_Inspector" title="link to the Object Inspector project page in the wiki">Object Inspector</a></td>
300 <td class="cell80">The Object Inspector is primarily an auxiliary tool
301 for the developer, which can present information about an object of the
302 [PRODUCTNAME] API at run-time. Depending on the object to be inspected,
303 appropriate methods, interfaces, services, and attributes can be displayed
304 to the developer. The methods, interfaces, services and attributes are
305 represented in a predictable tree. If the attributes contained in an
306 object are to be examined, the appropriate nodes in the tree can be
307 expanded with the help of the mouse. For each non primitive object, five
308 categories are offered to the user, as long as those are available with
309 that object. The Object Inspector is currently available as a NetBeans project
310 only because of major code changes. Please see the <a href="http://wiki.services.openoffice.org/wiki/Object_Inspector" title="link to the Object Inspector project page in the wiki">project page</a> for further details.</td>
311 </tr>
312 <tr>
313 <td class="cell20"><a href="java/MinimalComponent/" title="link to the source directory of the Java MinimalComponent example">MinimalComponent</a></td>
314 <td class="cell80">This class provides a minimal UNO component. You can
315 take this class as a base for your own components. By extensions of this
316 class it is possible to also extend the function range of the Office.</td>
317 </tr>
318 <tr>
319 <td class="cell20"><a href="java/PropertySet/" title="link to the source directory of the Java PropertySet example">PropTest</a></td>
320 <td class="cell80">Contains a component that provides property set
321 interfaces by means of inheriting <a href="../docs/java/ref/com/sun/star/lib/uno/helper/PropertySet.html" title="link into the Java UNO reference to the PropertySet helper class">com.sun.star.lib.uno.helper.ProperterSet</a>.</td>
322 </tr>
323 <tr>
324 <td class="cell20"><a href="java/ToDo/" title="link to the source directory of the Java ToDo example">ToDo</a></td>
325 <td class="cell80">For every to-do listed in a spreadsheet document, this
326 component calculates the start date, day of week of the start date, the
327 end date, and the day of week of the end date. All calculations are
328 dependent upon the values of &quot;Needed Days&quot;, &quot;Due Date&quot;
329 and &quot;Status&quot;. The columns &quot;Needed Days&quot; and
330 &quot;Status&quot; are mandatory. The first to-do should be placed in
331 row nine. The date to start the calculation should be placed in cell C6.
332 The private holidays should be placed in cell K4/K5 and below.<br>
333 All rows will be calculated up to the first empty cell in the first
334 column. If a cell in the column &quot;Due Date&quot; is colored red,
335 you should take a look at your entries.</td>
336 </tr>
337 <tr>
338 <td class="cell20"><a href="java/EmbedDocument/EmbeddedObject" title="link to the source directory of the Java EmbeddedObject example">EmbeddedObject</a></td>
339 <td class="cell80">Contains a component that provides an example of embedded object implementation.</td>
340 </tr>
341 <tbody>
342 </table>
343 </td>
344 </tr>
345 <tr>
346 <td>
347 <table class="table4">
348 <tbody>
349 <tr class="thead">
350 <td class="cell20">Other Examples</td>
351 <td class="cell80">Description</td>
352 </tr>
353 <tr>
354 <td class="cell20"><a href="java/ConverterServlet/" title="link to the source directory of the Java ConverterServlet examle">ConverterServlet</a></td>
355 <td class="cell80">This servlet shows how to convert arbitrary documents
356 on a remotely running office server. The converted document will be
357 pushed from the web server to the client browser. Please see the <a href="java/ConverterServlet/README" title="link to the README file of the Java ConverterServlet example">README</a> file for further information.</td>
358 </tr>
359 <tr>
360 <td class="cell20"><a href="java/NotesAccess/" title="link to the source directory of the Java NotesAccess example">NotesAccess</a></td>
361 <td class="cell80">This class creates a spreadsheet document and fills it
362 with existing values of documents from a Lotus Notes database. For this
363 examples some external APIs from Lotus Notes/Domino are necessary. You
364 can download a trial version from <a href="http:///www.lotus.com/downloads">http:///www.lotus.com/downloads</a>. After installing please add the install path
365 to the PATH or LD_LIBRARY_PATH of your SDK environment and either copy
366 the &quot;Notes.jar&quot; into your &lt;OFFICE_CLASSES_DIR&gt; directory
367 or adapt the SDK_CLASSPATH variable in the example Makefile to use the
368 &quot;Notes.jar&quot; of your installation.</td>
369 </tr>
370 <tbody>
371 </table>
372 </td>
373 </tr>
374 <tr>
375 <td>
376 <table class="table3">
377 <tr>
378 <td colspan="3">
379 <p>Additional information:</p>
381 <a href="http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/WritingUNO/Simple_Component_in_Java" title="link to the &quot;Simple component in Java&quot; chapter in the Developer's Guide">How to write a UNO component in Java</a><br>
382 <a href="http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/ProUNO/Java/Java_Language_Binding" title="link to the &quot;Java UNO Language Bnding&quot; chapter in the Developer's Guide">Java UNO Language Binding</a><br>
383 <a href="http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/WritingUNO/Debugging" title="link to the &quot;Debugging Java components&quot; chapter in the Developer's Guide">Debugging Java components</a><br>
384 </p>
385 </td>
386 </tr>
387 </table>
388 </td>
389 </tr>
390 </table>
391 </td>
392 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
393 </tr>
394 <tr>
395 <td colspan="3"><img class="line" src="../docs/images/sdk_line-2.gif"></td>
396 </tr>
397 <tr>
398 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
399 <td>
400 <table class="table2">
401 <tr>
402 <td>
403 <table class="table3">
404 <tr>
405 <td colspan="2" class="head1"><a name="Cpp_examples">C++ examples</td>
406 <td align="right">
407 <a href="#examples" title="link to the examples overview"><img class="navigate" src="../docs/images/nav_up.png"></a>
408 <a href="../index.html" title="link to the SDK start page"><img class="navigate" src="../docs/images/nav_home.png"></a>
409 </td>
410 </tr>
411 <tr>
412 <td colspan="3">
413 The DocumentLoader example needs a running office server, before
414 running this program you should invoke the office with the following
415 command:
416 <blockquote>
417 <code>soffice &quot;-accept=socket,host=localhost,port=2083;urp;StarOffice.ServiceManager&quot;</code>
418 </blockquote>
419 You can also customize the mentioned host and port to your needs.
420 </td>
421 </tr>
422 </table>
423 </td>
424 </tr>
425 <tr>
426 <td>
427 <table class="table4">
428 <tbody>
429 <tr class="thead">
430 <td class="cell20">Example</td>
431 <td class="cell80">Description</td>
432 </tr>
433 <tr>
434 <td class="cell20"><a href="cpp/DocumentLoader/"title="link to the source directory of the C++ DocumentLoader example">DocumentLoader</a></td>
435 <td class="cell80">This component works the same as the appropriate Java
436 example, but is implemented in C++.</td>
437 </tr>
438 <tr>
439 <td class="cell20"><a href="cpp/counter/" title="link to the source directory of the C++ counter example">Counter</a></td>
440 <td class="cell80">This demo shows how to implement a very simple UNO
441 component and how to access the UNO component from an executable.</td>
442 </tr>
443 <tr>
444 <td class="cell20"><a href="cpp/remoteclient/" title="link to the source directory of the C++ remoteclient example">Remote client</a></td>
445 <td class="cell80">The 'uno' program is used to export an arbitrary
446 service to other processes. In this example the com.sun.star.uno.Pipe
447 service (which is built in io-module) is exported. The client component
448 implements the <a href="../docs/common/ref/com/sun/star/lang/XMain.html" title="link into the IDL reference to the interface com.sun.star.lang.XMain">
449 com.sun.star.lang.XMain</a> interface. In the run method, it connects to
450 the servers process and retrieves an instance and does some calls on the
451 instance.</td>
452 </tr>
453 <tbody>
454 </table>
455 </td>
456 </tr>
457 <tr>
458 <td>
459 <table class="table3">
460 <tr>
461 <td colspan="3">
462 <p>Additional information:</p>
464 <a href="http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/WritingUNO/C%2B%2B/C%2B%2B_Component" title="link to the &quot;How to write a UNO component in C++&quot; chapter in the Developer's Guide">How to write a UNO component in C++</a><br>
465 <a href="http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/ProUNO/C%2B%2B/C%2B%2B_Language_Binding" title="link to the &quot;C++ UNO Language Binding&quot; chapter in the Developer's Guide">C++ UNO Language Binding</a><br>
466 <a href="../docs/cpp/ref/index.html" title="link to the C++ API reference">C++ reference</a>
467 </p>
468 </td>
469 </tr>
470 </table>
471 </td>
472 </tr>
473 </table>
474 </td>
475 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
476 </tr>
477 <tr>
478 <td colspan="3"><img class="line" src="../docs/images/sdk_line-2.gif"></td>
479 </tr>
480 <tr>
481 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
482 <td>
483 <table class="table2">
484 <tr>
485 <td>
486 <table class="table3">
487 <tr>
488 <td colspan="2" class="head1"><a name="Basic_examples">[PRODUCTNAME] Basic examples</td>
489 <td align="right">
490 <a href="#examples" title="link to the examples overview"><img class="navigate" src="../docs/images/nav_up.png"></a>
491 <a href="../index.html" title="link to the SDK start page"><img class="navigate" src="../docs/images/nav_home.png"></a>
492 </td>
493 </tr>
494 <tr>
495 <td colspan="3">
496 <p>The example programs are embedded in [PRODUCTNAME] documents in the
497 samples directory. To view or edit the [PRODUCTNAME] Basic source,
498 select the appropriate document and then select Tools-&gt;Macro.</p>
499 <p>Most of the examples are stand-alone, but two of them (Creating an
500 Index and Import/Export of ASCII Files) have an associated data file
501 identified by a .txt file name suffix).</p>
502 <p>Some of the examples are also available in Java, you can find them in
503 the <a href="#Java_examples" title="link to the Java examples section">
504 Java section</a>.</p>
505 </td>
506 </tr>
507 </table>
508 </td>
509 </tr>
510 <tr>
511 <td>
512 <table class="table4">
513 <tbody>
514 <tr class="thead">
515 <td class="cell20">Example</td>
516 <td class="cell80">Description</td>
517 </tr>
518 <tr>
519 <td class="cell20"><a href="basic/text/modifying_text_automatically/" title="link to the source directory of the [PRODUCTNAME] Basic text/modifying_text_automatically examples">Changing Appearance</a></td>
520 <td class="cell80"> To change the style used for certain words, you can
521 start with the following example. This code searches for the regular
522 expression <code>the[a-z]</code>, which stands for the text portion the
523 followed by exactly one lowercase letter. All occurrences of these four
524 letters are then changed to bold characters. The same happens in the next
525 part of the program, this time changing the appearance of
526 <code>all[a-z]</code> to italic. In order for this example to work, you
527 must execute it from an open text document.</td>
528 </tr>
529 <tr>
530 <td class="cell20"><a href="basic/text/modifying_text_automatically/" title="link to the source directory of the [PRODUCTNAME] Basic text/modifying_text_automatically examples">Replacing Text</a></td>
531 <td class="cell80">If you regularly receive documents from other people
532 for editing, you might want to make sure that certain words are always
533 written the same. The next example illustrates this by forcing certain
534 words to be spelled in American English.<br>
535 In order for this example to work, you must execute it from an open text
536 document. For a real world application, it is a good idea to read the
537 words from an external file.</td>
538 </tr>
539 <tr>
540 <td class="cell20"><a href="basic/text/modifying_text_automatically/" title="link to the source directory of the [PRODUCTNAME] Basic text/modifying_text_automatically examples">Using Regular Expressions</a></td>
541 <td class="cell80">Another application of automatic text modification is
542 related to stylistic questions. Suppose your company&#146;s policy is to
543 avoid the use of certain words. You want to replace these words, but you
544 cannot do that automatically because you have to find the appropriate
545 replacement, which depends on the context. So instead of deleting or
546 replacing the offending words automatically, you change their color to
547 make them stand out during a subsequent manual review process.<br>
548 The following example handles two kinds of unwanted wordings: those
549 which are absolutely forbidden and must be replaced by something else,
550 and those which are considered bad style. A subroutine is responsible
551 for the changes. It can be used to make all words in a list appear in a
552 certain color in the text document. To keep the lists short, we use
553 regular expressions which provide for the variants of the words
554 (plural, adjective etc.).</td>
555 </tr>
556 <tr>
557 <td class="cell20"><a href="basic/text/modifying_text_automatically/" title="link to the source directory of the [PRODUCTNAME] Basic text/modifying_text_automatically examples">Inserting Bookmarks</a></td>
558 <td class="cell80">
559 <p>The next example does something very similar. This time, however, we
560 do not change the color of the words but insert a bookmark at each of
561 them. You can thus use the StarOffice navigator to jump directly from
562 word to word. Bookmarks must first be created using
563 <code>createInstance()</code>. They are then inserted with
564 <code>insertTextContent()</code> at the current text range.</p>
565 <p>The main difference to the preceding example is the For loop in
566 <code>markList()</code>. Instead of changing the color of the current
567 word, it creates a new bookmark, oBookmark, whose name is the current
568 word with an integer appended. It then inserts this bookmark at the
569 word.</td>
570 </tr>
571 <tr>
572 <td class="cell20"><a href="basic/text/creating_an_index/" title="link to the source directory of the [PRODUCTNAME] Basic text/create_index example">Creating an Index</a></td>
573 <td class="cell80">Indices for text documents can be created manually in
574 [PRODUCTNAME] Writer by clicking on the words that should appear in the
575 index. If the document is large, or if you have to generate indices for
576 several documents, this task should be automated.</td>
577 </tr>
578 <tr>
579 <td class="cell20"><a href="basic/sheet/" title="link to the source directory of the [PRODUCTNAME] Basic sheet example">Adapting to Euroland</a></td>
580 <td class="cell80">Most of the members of the European Union will abandon
581 their old currency in favor of the new Euro in 2001. This requires
582 modifications to all programs using the old currencies. Since the exchange
583 rates for the old currencies have been fixed at the end of 1999, one can
584 already convert old data. The following program does this for all values
585 in a table that are formatted with the currency string DM.</td>
586 </tr>
587 <tr>
588 <td class="cell20"><a href="basic/drawing/" title="link to the source directory of the [PRODUCTNAME] Basic drawing example">Import/Export of ASCII Files</a></td>
589 <td class="cell80">You can use the drawing facilities of StarOffice API
590 to generate a picture from ASCII input. One application would be a
591 hierarchical representation of a directory listing, based on textual
592 data.</td>
593 </tr>
594 <tr>
595 <td class="cell20"><a href="basic/stock_quotes_updater/" title="link to the source directory of the [PRODUCTNAME] Basic stock_quotes_updater example">Stock Quotes Updater</a></td>
596 <td class="cell80">If you want to display stock charts for certain
597 companies, you can open up your browser every day, go to a search engine,
598 look up the quote and copy it by hand into a table. Or you can use a
599 program that does all this automatically. The following example relies on
600 the sheet module. It uses URLs to obtain the current stock quotes. The
601 quotes are displayed in sheets, one for each company. We show a line
602 diagram and the numerical values for this company on every sheet. The
603 functionality is hidden in the three subroutines <code>GetValue()</code>,
604 <code>UpdateValue()</code>, and <code>UpdateChart()</code>.</td>
605 </tr>
606 <tr>
607 <td class="cell20"><a href="basic/forms_and_controls/" title="link to the source directory of the [PRODUCTNAME] Basic forms_and_controls example">Forms and Controls</a></td>
608 <td class="cell80">The example document Burger Factory offers some forms
609 and controls, which you can use to order your desired burger type,
610 beverage, topping, and sauce. By hitting the button
611 &quot;Order now!&quot;, your order will be placed.</td>
612 </tr>
613 <tbody>
614 </table>
615 </td>
616 </tr>
617 <tr>
618 <td>
619 <table class="table3">
620 <tr>
621 <td colspan="3">
622 Additional information: <a href="http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/ProUNO/Basic/OpenOffice.org_Basic" title="link to the &quot;[PRODUCTNAME] Basic language binding&quot; chapter in the Developer's Guide">[PRODUCTNAME] Basic language binding</a>
623 </td>
624 </tr>
625 </table>
626 </td>
627 </tr>
628 </table>
629 </td>
630 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
631 </tr>
632 <tr>
633 <td colspan="3"><img class="line" src="../docs/images/sdk_line-2.gif"></td>
634 </tr>
635 <tr>
636 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
637 <td>
638 <table class="table2">
639 <tr>
640 <td>
641 <table class="table3">
642 <tr>
643 <td colspan="2" class="head1"><a name="OLE_examples">Object Linking and Embedding (OLE) examples</td>
644 <td align="right">
645 <a href="#examples" title="link to the examples overview"><img class="navigate" src="../docs/images/nav_up.png"></a>
646 <a href="../index.html" title="link to the SDK start page"><img class="navigate" src="../docs/images/nav_home.png"></a>
647 </td>
648 </tr>
649 </table>
650 </td>
651 </tr>
652 <tr>
653 <td>
654 <table class="table4">
655 <tbody>
656 <tr class="thead">
657 <td class="cell20">Example</td>
658 <td class="cell80">Description</td>
659 </tr>
660 <tr>
661 <td class="cell20"><a href="OLE/activex/" title="link to the source directory of the activex plugin example using the OLE bridge">ActiveX Control</a></td>
662 <td class="cell80">The ActiveX control shows an example of access to UNO
663 through COM technology. It requires a properly installed StarOffice
664 version 6.0 or OpenOffice 1.0 or newer. This is a Lite ActiveX control
665 so it can be used only in containers that allow the use of such controls.
666 It can be activated with an &lt;OBJECT&gt; tag from a html-page to embed
667 a document. Without any parameters a new writer document will be opened
668 for editing. For more details please see the <a href="OLE/activex/README.txt" title="link to the README file of the activex example">README</a>.<br>
669 Note: This example works only under windows and if you don't use the MS
670 .Net C++ compiler please check the makefile and take notice of the
671 comments.</td>
672 </tr>
673 <tr>
674 <td class="cell20"><a href="OLE/vbscript/" title="link to the source directory of the VBScript example using the OLE bridge">WriterDemo</a></td>
675 <td class="cell80">This Visual Basic Script creates an empty text
676 document and inserts text, a table, and a text frame.</td>
677 </tr>
678 <tbody>
679 </table>
680 </td>
681 </tr>
682 <tr>
683 <td>
684 <table class="table3">
685 <tr>
686 <td colspan="3">
687 Additional information: <a href="http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/ProUNO/Bridge/Automation_Bridge" title="link to the &quot;Automation Language Binding&quot; chapter in the Developer's Guide">Automation Language Binding</a>
688 </td>
689 </tr>
690 </table>
691 </td>
692 </tr>
693 </table>
694 </td>
695 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
696 </tr>
697 <tr>
698 <td colspan="3"><img class="line" src="../docs/images/sdk_line-2.gif"></td>
699 </tr>
700 <tr>
701 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
702 <td>
703 <table class="table2">
704 <tr>
705 <td>
706 <table class="table3">
707 <tr>
708 <td colspan="2" class="head1"><a name="CLI_examples">Common Language Infrastructure (CLI) examples</td>
709 <td align="right">
710 <a href="#examples" title="link to the examples overview"><img class="navigate" src="../docs/images/nav_up.png"></a>
711 <a href="../index.html" title="link to the SDK start page"><img class="navigate" src="../docs/images/nav_home.png"></a>
712 </td>
713 </tr>
714 </table>
715 </td>
716 </tr>
717 <tr>
718 <td>
719 <table class="table4">
720 <tbody>
721 <tr class="thead">
722 <td class="cell20">Example</td>
723 <td class="cell80">Description</td>
724 </tr>
725 <tr>
726 <td class="cell20"><a href="CLI/CSharp/Spreadsheet/" title="link to the source directory of the Spreadsheet example using the CLI-UNO bridge">Spreadsheet Example</a></td>
727 <td class="cell80">This example is written in C# and shows how Spreadsheet
728 documents are created and filled with content. This example actually
729 consists of three separate executables, SpreadsheetSample.exe,
730 GeneralTableSample.exe, ViewSample.exe.</td>
731 </tr>
732 <tr>
733 <td class="cell20"><a href="CLI/VB.NET/WriterDemo/" title="link to the source directory of the WriterDeom example using the CLI-UNO bridge">WriterDemo</a></td>
734 <td class="cell80">This example is written in VB.NET. It creates a text
735 document and inserts text, a table, and a text frame.</td>
736 </tr>
737 <tbody>
738 </table>
739 </td>
740 </tr>
741 <tr>
742 <td>
743 <table class="table3">
744 <tr>
745 <td colspan="3">
746 Additional information: <a href="http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/ProUNO/CLI/CLI_Language_Binding" title="link to the &quot;CLI-UNO Language Binding&quot; chapter in the Developer's Guide">CLI-UNO Language Binding</a>
747 </td>
748 </tr>
749 </table>
750 </td>
751 </tr>
752 </table>
753 </td>
754 <td class="content1"><img class="nothing8" src="../docs/images/nada.gif"></td>
755 </tr>
756 <tr>
757 <td colspan="3"><img class="nothing30" src="../docs/images/nada.gif"></td>
758 </tr>
759 <tr>
760 <td colspan="3"><img class="line" src="../docs/images/sdk_line-1.gif"></td>
761 </tr>
762 <tr>
763 <td colspan="3">
764 <div align="center"><p>Copyright 2009 Sun Microsystems, Inc.</p></div>
765 </td>
766 </tr>
767 </table>
768 <map name="Map">
769 <area shape="rect" coords="10,68,93,105" href="http://www.sun.com">
770 </map>
771 </body>
772 </html>