Zend_Service_LiveDocx.xml 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 21819 -->
  3. <!-- Reviewed: 21819 -->
  4. <sect1 id="zend.service.livedocx">
  5. <title>Zend_Service_LiveDocx</title>
  6. <sect2 id="zend.service.livedocx.introduction">
  7. <title>Einführung in LiveDocx</title>
  8. <para>
  9. LiveDocx ist ein <acronym>SOAP</acronym>-Service, der es Entwicklern erlaubt, MS Word
  10. Dokumente zu erstellen, indem strukturierte Daten von <acronym>PHP</acronym> mit einem
  11. Template kombiniert werden, die in einer MS Word-kompatiblen Anwendung erstellt wurden.
  12. Das resultierende Dokument kann als <acronym>PDF</acronym>, <acronym>DOCX</acronym>,
  13. <acronym>DOC</acronym>, <acronym>HTML</acronym> oder <acronym>RTF</acronym> Datei
  14. gespeichert werden. LiveDocx implementiert <ulink
  15. url="http://en.wikipedia.org/wiki/Mail_merge">Mail-Merge</ulink> in
  16. <acronym>PHP</acronym>.
  17. </para>
  18. <para>
  19. Die Familie der <classname>Zend_Service_LiveDocx</classname> Komponenten bietet ein
  20. klares und einfaches Interface zur <ulink url="http://www.livedocx.com">LiveDocx
  21. API</ulink> und bietet zusätzlich Funktionalitäten, um die Geschwindigkeit im
  22. Netzwerk zu erhöhen.
  23. </para>
  24. <para>
  25. Wenn man zusätzlich zu diesem Kapitel des Handbuchs daran interessiert ist, mehr
  26. über <classname>Zend_Service_LiveDocx</classname> und den dahinterliegenden
  27. <acronym>SOAP</acronym>-Service LiveDocx zu lernen, kann man bei den folgenden
  28. Ressourcen nachsehen:
  29. </para>
  30. <itemizedlist>
  31. <listitem>
  32. <para>
  33. <emphasis>Mitgelieferte Beispielanwendungen</emphasis>. Es gibt eine große
  34. Anzahl an Beispielanwendungen im Verzeichnis
  35. <emphasis>/demos/Zend/Service/LiveDocx</emphasis> der Zend Framework
  36. Distributionsdatei, oder der Trunk Version die vom standardmäßigen SVN
  37. Repository ausgecheckt werden kann. Diese sind dazu gedacht, schnell, in nur
  38. ein paar Minuten, mit <classname>Zend_Service_LiveDocx</classname> zurecht zu
  39. kommen.
  40. </para>
  41. </listitem>
  42. <listitem>
  43. <para>
  44. <ulink url="http://www.phplivedocx.org/">
  45. <classname>Zend_Service_LiveDocx</classname> Blog und Webseite</ulink>.
  46. </para>
  47. </listitem>
  48. <listitem>
  49. <para>
  50. <ulink url="http://www.livedocx.com/pub/documentation/api.aspx">
  51. LiveDocx SOAP API Dokumentation</ulink>.
  52. </para>
  53. </listitem>
  54. <listitem>
  55. <para>
  56. <ulink url="https://api.livedocx.com/1.2/mailmerge.asmx?wsdl">
  57. LiveDocx WSDL</ulink>.
  58. </para>
  59. </listitem>
  60. <listitem>
  61. <para>
  62. <ulink url="https://www.livedocx.com/">LiveDocx Blog und Webseite</ulink>.
  63. </para>
  64. </listitem>
  65. </itemizedlist>
  66. <sect3 id="zend.service.livedocx.account">
  67. <title>Für einen Account anmelden</title>
  68. <para>
  69. Bevor man damit beginnt LiveDocx zu verwenden, muss man sich zuerst für einen Account
  70. <ulink
  71. url="https://www.livedocx.com/user/account_registration.aspx">anmelden</ulink>.
  72. Der Account ist komplett kostenlos, und es muss nur ein
  73. <emphasis>Benutzername</emphasis>, ein <emphasis>Passwort</emphasis> und eine
  74. <emphasis>E-Mail-Adresse</emphasis> eingegeben werden. Die Anmeldedaten werden mit der
  75. E-Mail-Adresse verknüpft, die man angibt, deshalb sollte man vorsichtig tippen.
  76. </para>
  77. </sect3>
  78. <sect3 id="zend.service.livedocx.templates-documents">
  79. <title>Templates und Dokumente</title>
  80. <para>
  81. LiveDocx unterscheidet zwischen den folgenden Ausdrücken: 1)
  82. <emphasis>Template</emphasis> und 2) <emphasis>Dokument</emphasis>. Um die
  83. Dokumentation und auch die aktuelle <acronym>API</acronym> vollständig zu verstehen,
  84. ist es wichtig dass jeder Programmierer der LiveDocx ausliefert, den Unterschied
  85. versteht.
  86. </para>
  87. <para>
  88. Der Ausdruck <emphasis>Template</emphasis> wird verwendet, um auf eine Eingabedatei
  89. zu verweisen, die in einer Textverarbeitung erstellt wurde und Formatierungen sowie
  90. Textfelder enthält. Man kann ein <ulink
  91. url="http://www.phplivedocx.org/wp-content/uploads/2009/01/license-agreement-template.docx">Beispieltemplate</ulink>
  92. herunterladen, welches als <acronym>DOCX</acronym> Datei gespeichert ist. Der Ausdruck
  93. <emphasis>Dokument</emphasis> wird verwendet, um auf eine Ausgabedatei zu verweisen,
  94. welche die Templatedatei enthält, zusammen mit Daten - z.B. das fertiggestellte
  95. Dokument. Man kann ein <ulink
  96. url="http://www.phplivedocx.org/wp-content/uploads/2009/01/license-agreement-document.pdf">Beispieldokument</ulink>
  97. herunterlaen, welches als <acronym>PDF</acronym> Datei gespeichert ist.
  98. </para>
  99. </sect3>
  100. <sect3 id="zend.service.livedocx.formats">
  101. <title>Unterstützte Dateiformate</title>
  102. <para>
  103. LiveDocx unterstützt die folgenden Dateiformate:
  104. </para>
  105. <sect4 id="zend.service.livedocx.formats.template">
  106. <title>Template Dateiformate (Eingabe)</title>
  107. <para>
  108. Templates können in jedem der folgenden Dateiformate gespeichert werden:
  109. </para>
  110. <itemizedlist>
  111. <listitem>
  112. <para>
  113. <ulink url="http://en.wikipedia.org/wiki/Office_Open_XML">DOCX</ulink> -
  114. Office Open <acronym>XML</acronym> Format
  115. </para>
  116. </listitem>
  117. <listitem>
  118. <para>
  119. <ulink url="http://en.wikipedia.org/wiki/DOC_(computing)">DOC</ulink> -
  120. Microsoft Word <acronym>DOC</acronym> Format
  121. </para>
  122. </listitem>
  123. <listitem>
  124. <para>
  125. <ulink url="http://en.wikipedia.org/wiki/Rich_Text_Format">RTF</ulink> -
  126. Rich-Text-Dateiformat
  127. </para>
  128. </listitem>
  129. <listitem>
  130. <para>
  131. <ulink url="http://www.textcontrol.com/">TXD</ulink> - TX Text Control
  132. Format
  133. </para>
  134. </listitem>
  135. </itemizedlist>
  136. </sect4>
  137. <sect4 id="zend.service.livedocx.formats.document">
  138. <title>Dateiformate des Dokuments (Ausgabe):</title>
  139. <para>
  140. Das resultierende Dokument kann in jedem der folgenden Dateiformate gespeichert
  141. werden:
  142. </para>
  143. <itemizedlist>
  144. <listitem>
  145. <para>
  146. <ulink url="http://en.wikipedia.org/wiki/Office_Open_XML">DOCX</ulink> -
  147. Office Open <acronym>XML</acronym> Format
  148. </para>
  149. </listitem>
  150. <listitem>
  151. <para>
  152. <ulink url="http://en.wikipedia.org/wiki/DOC_(computing)">DOC</ulink> -
  153. Microsoft Word <acronym>DOC</acronym> Format
  154. </para>
  155. </listitem>
  156. <listitem>
  157. <para>
  158. <ulink url="http://en.wikipedia.org/wiki/Xhtml">HTML</ulink> -
  159. <acronym>XHTML</acronym> 1.0 Transitional Format
  160. </para>
  161. </listitem>
  162. <listitem>
  163. <para>
  164. <ulink url="http://en.wikipedia.org/wiki/Rich_Text_Format">RTF</ulink> -
  165. Rich-Text-Dateiformat
  166. </para>
  167. </listitem>
  168. <listitem>
  169. <para>
  170. <ulink
  171. url="http://en.wikipedia.org/wiki/Portable_Document_Format">PDF</ulink>
  172. - Acrobat Portable Document Format
  173. </para>
  174. </listitem>
  175. <listitem>
  176. <para>
  177. <ulink url="http://www.textcontrol.com/">TXD</ulink> - TX Text Control
  178. Format
  179. </para>
  180. </listitem>
  181. <listitem>
  182. <para>
  183. <ulink url="http://en.wikipedia.org/wiki/Text_file">TXT</ulink> -
  184. <acronym>ANSI</acronym> reiner Text
  185. </para>
  186. </listitem>
  187. </itemizedlist>
  188. </sect4>
  189. <sect4 id="zend.service.livedocx.formats.image">
  190. <title>Bilddateiformate (Ausgabe):</title>
  191. <para>
  192. Das resultierende Dokument kann in jedem der folgenden grafischen Dateiformate
  193. gespeichert werden:
  194. </para>
  195. <itemizedlist>
  196. <listitem>
  197. <para>
  198. <ulink url="http://en.wikipedia.org/wiki/BMP_file_format">BMP</ulink> -
  199. Bitmap Bildformat
  200. </para>
  201. </listitem>
  202. <listitem>
  203. <para>
  204. <ulink url="http://en.wikipedia.org/wiki/GIF">GIF</ulink> - Graphics
  205. Interchange Format
  206. </para>
  207. </listitem>
  208. <listitem>
  209. <para>
  210. <ulink url="http://en.wikipedia.org/wiki/Jpg">JPG</ulink> - Joint
  211. Photographic Experts Group Format
  212. </para>
  213. </listitem>
  214. <listitem>
  215. <para>
  216. <ulink
  217. url="http://en.wikipedia.org/wiki/Portable_Network_Graphics">PNG</ulink>
  218. - Portable Network Graphics Format
  219. </para>
  220. </listitem>
  221. <listitem>
  222. <para>
  223. <ulink
  224. url="http://en.wikipedia.org/wiki/Tagged_Image_File_Format">TIFF</ulink>
  225. - Tagged Image File Format
  226. </para>
  227. </listitem>
  228. <listitem>
  229. <para>
  230. <ulink url="http://en.wikipedia.org/wiki/Windows_Metafile">WMF</ulink> -
  231. Windows Meta File Format
  232. </para>
  233. </listitem>
  234. </itemizedlist>
  235. </sect4>
  236. </sect3>
  237. </sect2>
  238. <sect2 id="zend.service.livedocx.mailmerge">
  239. <title>Zend_Service_LiveDocx_MailMerge</title>
  240. <para>
  241. <classname>Zend_Service_LiveDocx_MailMerge</classname> ist das Mail-Merge-Objekt in der
  242. <classname>Zend_Service_LiveDocx</classname> Familie.
  243. </para>
  244. <sect3 id="zend.service.livedocx.mailmerge.generation">
  245. <title>Prozess der Dokumentenerstellung</title>
  246. <para>
  247. Der Prozess der Erstellung des Dokuments kann mit der folgenden Gleichung
  248. vereinfacht dargestellt werden:
  249. </para>
  250. <para>
  251. <emphasis>Template + Daten = Dokument</emphasis>
  252. </para>
  253. <para>
  254. Oder durch das folgende Diagramm ausgedrückt werden:
  255. </para>
  256. <para>
  257. <inlinegraphic
  258. fileref="figures/zend.service.livedocx.mailmerge.generation-diabasic_zoom.png"
  259. format="PNG" />
  260. </para>
  261. <para>
  262. Daten werden in ein Template eingefügt, um ein Dokument zu erstellen.
  263. </para>
  264. <para>
  265. Ein Template, das in einer Textverarbeitungsanwendung, wie Microsoft Word, erstellt
  266. wird, wird in LiveDocx geladen. Daten werden in das Template eingesetzt und
  267. das resultierende Dokument wird in jedes der unterstützten Formate gespeichert.
  268. </para>
  269. </sect3>
  270. <sect3 id="zend.service.livedocx.mailmerge.templates">
  271. <title>Erstellen von Templates in Microsoft Word 2007</title>
  272. <para>
  273. Man muss damit beginnen Microsoft Word zu starten und ein neues Dokument zu
  274. erstellen. Als nächstes wird der Dialog <emphasis>Felder</emphasis> geöffnet.
  275. Er sieht wie folgt aus:
  276. </para>
  277. <para>
  278. <inlinegraphic
  279. fileref="figures/zend.service.livedocx.mailmerge.templates-msworddialog_zoom.png"
  280. format="PNG" />
  281. </para>
  282. <para>
  283. Dialogbox Felder in Microsoft Word 2007.
  284. </para>
  285. <para>
  286. Durch Verwendung dieses Dialogs kann man die benötigten Merge-Felder in das eigene
  287. Dokument einfügen. Anbei ist ein Screenshot der Lizenzvereinbarung in Microsoft
  288. Word 2007. Die Merge-Felder sind als <code>{ MERGEFIELD FieldName }</code> markiert:
  289. </para>
  290. <para>
  291. <inlinegraphic
  292. fileref="figures/zend.service.livedocx.mailmerge.templates-mswordtemplatefull_zoom.png"
  293. format="PNG" />
  294. </para>
  295. <para>
  296. Das Template in Microsoft Word 2007.
  297. </para>
  298. <para>
  299. Jetzt muss das Template als <emphasis>template.docx</emphasis> gespeichert werden.
  300. </para>
  301. <para>
  302. Im nächsten Schritt vereinen wir die Merge-Felder mit textuellen Daten von
  303. <acronym>PHP</acronym>.
  304. </para>
  305. <para>
  306. <inlinegraphic
  307. fileref="figures/zend.service.livedocx.mailmerge.templates-mswordtemplatecropped_zoom.png"
  308. format="PNG" />
  309. </para>
  310. <para>
  311. Unterteiltes Template in Microsoft Word 2007.
  312. </para>
  313. <para>
  314. Um die Merge Felder, im vorher unterteilten Screenshot des <ulink
  315. url="http://www.phplivedocx.org/wp-content/uploads/2009/01/license-agreement-template.docx">Templates</ulink>,
  316. in Microsoft Word auszufüllen, muss das folgende geschrieben werden:
  317. </para>
  318. <programlisting language="php"><![CDATA[
  319. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge();
  320. $phpLiveDocx->setUsername('myUsername')
  321. ->setPassword('myPassword');
  322. $phpLiveDocx->setLocalTemplate('template.docx');
  323. $phpLiveDocx->assign('software', 'Magic Graphical Compression Suite v1.9')
  324. ->assign('licensee', 'Henry Döner-Meyer')
  325. ->assign('company', 'Co-Operation');
  326. $phpLiveDocx->createDocument();
  327. $document = $phpLiveDocx->retrieveDocument('pdf');
  328. file_put_contents('document.pdf', $document);
  329. ]]></programlisting>
  330. <para>
  331. Das resultierende Dokument wird auf der Festplatte in die Datei
  332. <emphasis>document.pdf</emphasis> geschrieben. Diese Datei kann nun weiter
  333. bearbeitet, per E-Eail versendet oder einfach angezeigt werden, wie anbei im
  334. <emphasis>Document Viewer 2.26.1</emphasis> auf <emphasis>Ubuntu 9.04</emphasis>
  335. gezeigt:
  336. </para>
  337. <para>
  338. <inlinegraphic
  339. fileref="figures/zend.service.livedocx.mailmerge.templates-msworddocument_zoom.png"
  340. format="PNG" />
  341. </para>
  342. <para>
  343. Resultierendes Dokument als <acronym>PDF</acronym> im Document Viewer 2.26.1.
  344. </para>
  345. </sect3>
  346. <sect3 id="zend.service.livedocx.mailmerge.advanced">
  347. <title>Gehobeneres Mail-Merge</title>
  348. <para>
  349. <classname>Zend_Service_LiveDocx_MailMerge</classname> erlaubt es Entwicklern eine
  350. beliebige Anzahl an Text-Feldern in ein Template einzufügen. Diese Text-Felder
  351. werden mit Daten gefüllt, wenn <emphasis>createDocument()</emphasis> aufgerufen
  352. wird.
  353. </para>
  354. <para>
  355. Zusätzlich zu Textfeldern ist es auch möglich, spezielle Regionen eines Dokuments
  356. anzugeben, die wiederholt werden sollen.
  357. </para>
  358. <para>
  359. In einer Telefonrechnung ist es z.b. notwendig, eine Liste aller Verbindungen,
  360. inklusive der Zielnummern, der Dauer und den Kosten jedes Anrufs abzubilden,.
  361. Diese Funktion der wiederholten Zeile kann mit sogenannten Blöcken erzielt werden.
  362. </para>
  363. <para>
  364. <emphasis>Blöcke</emphasis> sind einfach Regionen eines Dokuments, welche wiederholt
  365. werden wenn <methodname>createDocument()</methodname> aufgerufen wird. In einem
  366. Block kann eine beliebige Anzahl an <emphasis>Block-Feldern</emphasis> spezifiziert
  367. werden.
  368. </para>
  369. <para>
  370. Blöcke bestehen aus zwei zusammenhängenden Sprungmarken mit eindeutigen
  371. Namen. Der folgende Screenshot zeigt diese Sprungmarken und deren Namen in Rot:
  372. </para>
  373. <para>
  374. <inlinegraphic
  375. fileref="figures/zend.service.livedocx.mailmerge.advanced-mergefieldblockformat_zoom.png"
  376. format="PNG" />
  377. </para>
  378. <para>
  379. Das Format eines Blocks ist wie folgt:
  380. </para>
  381. <programlisting language="text"><![CDATA[
  382. blockStart_ + unique name
  383. blockEnd_ + unique name
  384. ]]></programlisting>
  385. <para>Zum Beispiel:</para>
  386. <programlisting language="text"><![CDATA[
  387. blockStart_block1
  388. blockEnd_block1
  389. ]]></programlisting>
  390. <para>
  391. Der Inhalt eines Blocks wird wiederholt, bis alle zugeordneten Daten in Blockfeldern
  392. des Templates eingefügt wurden. Die Daten der Blockfelder werden in
  393. <acronym>PHP</acronym> als mehrfach-assoziatives Array spezifiziert.
  394. </para>
  395. <para>
  396. Der folgende Screenshot eines Templates in Microsoft Word 2007 zeigt wie Blockfelder
  397. verwendet werden:
  398. </para>
  399. <para>
  400. <inlinegraphic
  401. fileref="figures/zend.service.livedocx.mailmerge.advanced-mswordblockstemplate_zoom.png"
  402. format="PNG" />
  403. </para>
  404. <para>
  405. Template, welches Blöcke in Microsoft Word 2007 zeigt.
  406. </para>
  407. <para>
  408. Der folgende Code füllt das obige Template mit Daten.
  409. </para>
  410. <programlisting language="php"><![CDATA[
  411. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge();
  412. $phpLiveDocx->setUsername('myUsername')
  413. ->setPassword('myPassword');
  414. $phpLiveDocx->setLocalTemplate('template.doc');
  415. $billConnections = array(
  416. array(
  417. 'connection_number' => '+49 421 335 912',
  418. 'connection_duration' => '00:00:07',
  419. 'fee' => '€ 0.03',
  420. ),
  421. array(
  422. 'connection_number' => '+49 421 335 913',
  423. 'connection_duration' => '00:00:07',
  424. 'fee' => '€ 0.03',
  425. ),
  426. array(
  427. 'connection_number' => '+49 421 335 914',
  428. 'connection_duration' => '00:00:07',
  429. 'fee' => '€ 0.03',
  430. ),
  431. array(
  432. 'connection_number' => '+49 421 335 916',
  433. 'connection_duration' => '00:00:07',
  434. 'fee' => '€ 0.03',
  435. ),
  436. );
  437. $phpLiveDocx->assign('connection', $billConnections);
  438. // ... andere Daten hier zuweisen ...
  439. $phpLiveDocx->createDocument();
  440. $document = $phpLiveDocx->retrieveDocument('pdf');
  441. file_put_contents('document.pdf', $document);
  442. ]]></programlisting>
  443. <para>
  444. Die Daten, welche im Array <varname>$billConnections</varname> spezifiziert sind,
  445. werden im Template im Block 'connection' wiederholt. Die Schlüssel des Arrays
  446. (<varname>connection_number</varname>, <varname>connection_duration</varname> und
  447. <varname>fee</varname>) sind die Namen der Blockfelder - deren Daten werden bei
  448. jeder Iteration in einer Zeile eingefügt.
  449. </para>
  450. <para>
  451. Das resultierende Dokument wird auf der Festplatte in die Datei
  452. <emphasis>document.pdf</emphasis> geschrieben. Diese Datei kann anschließend
  453. nachbearbietet, per E-Mail gesendet, oder einfach dargestellt werden, wie anbei im
  454. <emphasis>Document Viewer 2.26.1</emphasis> unter <emphasis>Ubuntu 9.04</emphasis>
  455. gezeigt:
  456. </para>
  457. <para>
  458. <inlinegraphic
  459. fileref="figures/zend.service.livedocx.mailmerge.advanced-mswordblocksdocument_zoom.png"
  460. format="PNG" />
  461. </para>
  462. <para>
  463. Das resultierende Dokument als <acronym>PDF</acronym> im Document Viewer
  464. 2.26.1.
  465. </para>
  466. <para>
  467. Man kann die <acronym>DOC</acronym> <ulink
  468. url="http://www.phplivedocx.org/wp-content/uploads/2009/01/telephone-bill-template.doc">Template
  469. Datei</ulink> und das resultierende <ulink
  470. url="http://www.phplivedocx.org/wp-content/uploads/2009/01/telephone-bill-document.pdf">PDF
  471. Dokument</ulink> hier herunterladen.
  472. </para>
  473. <para>
  474. <emphasis>BEACHTE:</emphasis> Blöcke können nicht verschachtelt werden.
  475. </para>
  476. </sect3>
  477. <sect3 id="zend.service.livedocx.mailmerge.bitmaps">
  478. <title>Erstellen von Bitmap Bildern</title>
  479. <para>
  480. Zusätzlich zu den Dateiformaten für Dokumente erlaubt es
  481. <classname>Zend_Service_LiveDocx_MailMerge</classname> auch Dokumente als eine
  482. Anzahl von Bildern zu speichern (<acronym>BMP</acronym>,
  483. <acronym>GIF</acronym>, <acronym>JPG</acronym>, <acronym>PNG</acronym> und
  484. <acronym>TIFF</acronym>). Jede Seite des Dokuments wird als eine Datei gespeichert.
  485. </para>
  486. <para>
  487. Das folgende Beispiel zeigt die Verwendung von <methodname>getBitmaps($fromPage,
  488. $toPage, $zoomFactor, $format)</methodname> und
  489. <methodname>getAllBitmaps($zoomFactor, $format)</methodname>.
  490. </para>
  491. <para>
  492. <varname>$fromPage</varname> ist die untere Grenze der Seitenzahl des Bereichs an
  493. Seiten, die als Bilder zurückgegeben werden sollen und <varname>$toPage</varname>
  494. ist die obere Grenze der Seitenzahlen. <varname>$zoomFactor</varname> ist die Größe
  495. der Bilder als Prozentwert relativ zur originalen Seitengröße. Der Bereich dieses
  496. Parameters ist von 10 bis 400. <varname>$format</varname> ist das Format des
  497. Bildes, welches von dieser Methode zurückgegeben wird. Die unterstützten Formate
  498. erhält man, wenn man <methodname>getImageFormats()</methodname> aufruft.
  499. </para>
  500. <programlisting language="php"><![CDATA[
  501. $date = new Zend_Date();
  502. $date->setLocale('en_US');
  503. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge();
  504. $phpLiveDocx->setUsername('myUsername')
  505. ->setPassword('myPassword');
  506. $phpLiveDocx->setLocalTemplate('template.docx');
  507. $phpLiveDocx->assign('software', 'Magic Graphical Compression Suite v1.9')
  508. ->assign('licensee', 'Daï Lemaitre')
  509. ->assign('company', 'Megasoft Co-operation')
  510. ->assign('date', $date->get(Zend_Date::DATE_LONG))
  511. ->assign('time', $date->get(Zend_Date::TIME_LONG))
  512. ->assign('city', 'Lyon')
  513. ->assign('country', 'France');
  514. $phpLiveDocx->createDocument();
  515. // Alle Bitmaps holen
  516. // (zoomFactor, format)
  517. $bitmaps = $phpLiveDocx->getAllBitmaps(100, 'png');
  518. // Nur Bitmaps im spezifizierten Bereich erhalten
  519. // (fromPage, toPage, zoomFactor, format)
  520. // $bitmaps = $phpLiveDocx->getBitmaps(2, 2, 100, 'png');
  521. foreach ($bitmaps as $pageNumber => $bitmapData) {
  522. $filename = sprintf('documentPage%d.png', $pageNumber);
  523. file_put_contents($filename, $bitmapData);
  524. }
  525. ]]></programlisting>
  526. <para>
  527. Das produziert zwei Bilder (<filename>documentPage1.png</filename> und
  528. <filename>documentPage2.png</filename>) und schreibt diese auf die Festplatte
  529. in das gleiche Verzeichnis wie die ausführbare <acronym>PHP</acronym>-Datei.
  530. </para>
  531. <para>
  532. <inlinegraphic
  533. fileref="figures/zend.service.livedocx.mailmerge.bitmaps-documentpage1_zoom.png"
  534. format="PNG" />
  535. </para>
  536. <para>
  537. documentPage1.png.
  538. </para>
  539. <para>
  540. <inlinegraphic
  541. fileref="figures/zend.service.livedocx.mailmerge.bitmaps-documentpage2_zoom.png"
  542. format="PNG" />
  543. </para>
  544. <para>
  545. documentPage2.png.
  546. </para>
  547. </sect3>
  548. <sect3 id="zend.service.livedocx.mailmerge.templates-types">
  549. <title>Lokale vs. Remote Templates</title>
  550. <para>
  551. Templates können <emphasis>lokal</emphasis> auf der Client-Maschine gespeichert
  552. werden oder <emphasis>remote</emphasis> auf dem Server. Jede Variante hat Vorteile
  553. und Nachteile.
  554. </para>
  555. <para>
  556. Im Falle, dass ein Template lokal gespeichert ist, muss es bei jeder Anfrage vom
  557. Client auf den Server transferiert werden. Wenn sich der Inhalt vom Templates
  558. selten ändert, ist dieser Weg sehr ineffizient. Ähnlich auch, wenn das Template eine
  559. Größe von mehreren Megabyte hat, kann es eine beträchtliche Zeit dauern, es auf den
  560. Server zu transferieren. Lokale Templates sind in Situationen sinnvoll, in denen der
  561. Inhalt des Templates konstant geändert wird.
  562. </para>
  563. <para>
  564. Der folgende Code zeigt, wie man ein lokales Template verwendet.
  565. </para>
  566. <programlisting language="php"><![CDATA[
  567. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge();
  568. $phpLiveDocx->setUsername('myUsername')
  569. ->setPassword('myPassword');
  570. $phpLiveDocx->setLocalTemplate('./template.docx');
  571. // Daten hinzufügen und das Dokument erstellen
  572. ]]></programlisting>
  573. <para>
  574. Im Falle, dass ein Template remote gespeichert ist, wird es nur einmal auf den
  575. Server geladen und anschließend bei allen nachfolgenden Anfragen darauf
  576. referenziert. Natürlich ist es viel schneller, als ein lokales Template zu
  577. verwenden, da das Template nicht bei jeder Anfrage übertragen werden muss. Für
  578. Anwendungen bei denen die Geschwindigkeit kritisch ist, wird es empfohlen die
  579. Remote-Template-Methode zu verwenden.
  580. </para>
  581. <para>
  582. Der folgende Code zeigt, wie ein Template auf den Server übertragen wird:
  583. </para>
  584. <programlisting language="php"><![CDATA[
  585. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge();
  586. $phpLiveDocx->setUsername('myUsername')
  587. ->setPassword('myPassword');
  588. $phpLiveDocx->uploadTemplate('template.docx');
  589. ]]></programlisting>
  590. <para>
  591. Der folgende Code zeigt, wie auf das remote gespeicherte Template bei allen
  592. weiteren Anfragen referenziert wird:
  593. </para>
  594. <programlisting language="php"><![CDATA[
  595. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge();
  596. $phpLiveDocx->setUsername('myUsername')
  597. ->setPassword('myPassword');
  598. $phpLiveDocx->setRemoteTemplate('template.docx');
  599. // assign data and create document
  600. ]]></programlisting>
  601. </sect3>
  602. <sect3 id="zend.service.livedocx.mailmerge.information">
  603. <title>Informationen erhalten</title>
  604. <para>
  605. <classname>Zend_Service_LiveDocx_MailMerge</classname> bietet eine Anzahl an
  606. Methoden um Informationen über Feldnamen, vorhandene Schriftarten und unterstützte
  607. Formate zu erhalten.
  608. </para>
  609. <example id="zend.service.livedocx.mailmerge.information.getfieldname">
  610. <title>Ein Array an Feldnamen vom Template erhalten</title>
  611. <para>
  612. Der folgende Code gibt ein Array aller Feldnamen im angegebenen Template
  613. zurück und zeigt diese an. Diese Funktionalität ist nützlich, wenn man eine
  614. Anwendung erstellt, in welcher der Endbenutzer das Template aktualisieren kann.
  615. </para>
  616. <programlisting language="php"><![CDATA[
  617. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge();
  618. $phpLiveDocx->setUsername('myUsername')
  619. ->setPassword('myPassword');
  620. $templateName = 'template-1-text-field.docx';
  621. $phpLiveDocx->setLocalTemplate($templateName);
  622. $fieldNames = $phpLiveDocx->getFieldNames();
  623. foreach ($fieldNames as $fieldName) {
  624. printf('- %s%s', $fieldName, PHP_EOL);
  625. }
  626. ]]></programlisting>
  627. </example>
  628. <example id="zend.service.livedocx.mailmerge.information.getblockfieldname">
  629. <title>Ein Array an Blockfeldnamen vom Template erhalten</title>
  630. <para>
  631. Der folgende Code zeigt ein Array aller Blockfeldnamen im
  632. angegebenen Template an. Diese Funktionalität ist nützlich, wenn man eine
  633. Anwendung erstellt, in welcher der Endbenutzer das Template aktualisieren kann.
  634. Bevor solche Templates veröffentlicht werden können, ist es notwendig, die Namen
  635. der enthaltenen Blockfelder herauszufinden.
  636. </para>
  637. <programlisting language="php"><![CDATA[
  638. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge();
  639. $phpLiveDocx->setUsername('myUsername')
  640. ->setPassword('myPassword');
  641. $templateName = 'template-block-fields.doc';
  642. $phpLiveDocx->setLocalTemplate($templateName);
  643. $blockNames = $phpLiveDocx->getBlockNames();
  644. foreach ($blockNames as $blockName) {
  645. $blockFieldNames = $phpLiveDocx->getBlockFieldNames($blockName);
  646. foreach ($blockFieldNames as $blockFieldName) {
  647. printf('- %s::%s%s', $blockName, $blockFieldName, PHP_EOL);
  648. }
  649. }
  650. ]]></programlisting>
  651. </example>
  652. <example id="zend.service.livedocx.mailmerge.information.getfontnames">
  653. <title>
  654. Ein Array von Schriftarten erhalten welche auf dem Server installiert sind
  655. </title>
  656. <para>
  657. Der folgende Code zeigt ein Array aller auf dem Server installierten
  658. Schriftarten an. Diese Methode kann verwendet werden, um eine Liste
  659. von Schriftarten anzuzeigen, welche in einem Template verwendet werden können.
  660. Das ist nützlich, um den Endbenutzer über die auf dem Server installierten
  661. Schriften zu informieren, da nur diese Schriftarten in einem Template verwendet
  662. werden können. Im Falle, dass ein Template Schriften enthält, welche auf dem
  663. Server nicht enthalten sind, wird eine andere Schriftart verwendet. Dies kann
  664. zu unerwünschten Ergebnissen führen.
  665. </para>
  666. <programlisting language="php"><![CDATA[
  667. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge();
  668. $phpLiveDocx->setUsername('myUsername')
  669. ->setPassword('myPassword');
  670. Zend_Debug::dump($phpLiveDocx->getFontNames());
  671. ]]></programlisting>
  672. <para>
  673. <emphasis>BEACHTE:</emphasis> Da sich der Rückgabewert diese Methode sehr
  674. selten ändert, ist es sehr empfehlenswert einen Cache zu verwenden, wie z.B.
  675. <classname>Zend_Cache</classname> - das macht die Anwendung sichtbar schneller.
  676. </para>
  677. </example>
  678. <example id="zend.service.livedocx.mailmerge.information.gettemplateformats">
  679. <title>Ein Array an unterstützten Dateiformaten für Templates erhalten</title>
  680. <para>
  681. Der folgende Code zeigt ein Array aller unterstützten
  682. Dateiformate für Templates. Diese Methode ist partiell nützlich im Fall, dass
  683. eine Auswahlliste angezeigt werden soll, welche es dem Endbenutzer erlaubt,
  684. das Eingabeformat für den Erstellungsprozess des Dokuments auszuwählen.
  685. </para>
  686. <programlisting language="php"><![CDATA[
  687. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge()
  688. $phpLiveDocx->setUsername('myUsername')
  689. ->setPassword('myPassword');
  690. Zend_Debug::dump($phpLiveDocx->getTemplateFormats());
  691. ]]></programlisting>
  692. <para>
  693. <emphasis>BEACHTE:</emphasis> Da sich der Rückgabewert diese Methode sehr
  694. selten ändert, ist es sehr empfehlenswert einen Cache zu verwenden, wie z.B.
  695. <classname>Zend_Cache</classname> - das macht die Anwendung sichtbar schneller.
  696. </para>
  697. </example>
  698. <example id="zend.service.livedocx.mailmerge.information.getdocumentformats">
  699. <title>Ein Array an unterstützten Dateiformaten für Dokumente erhalten</title>
  700. <para>
  701. Der folgende Code zeigt ein Array aller unterstützten
  702. Dateiformate für Dokumente. Diese Methode ist besonders nützlich, falls
  703. eine Auswahlliste angezeigt werden soll, welche es dem Endbenutzer erlaubt,
  704. das Ausgabeformat für den Erstellungsprozess des Dokuments auszuwählen.
  705. </para>
  706. <programlisting language="php"><![CDATA[
  707. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge();
  708. $phpLiveDocx->setUsername('myUsername')
  709. ->setPassword('myPassword');
  710. Zend_Debug::dump($phpLiveDocx->getDocumentFormats());
  711. ]]></programlisting>
  712. </example>
  713. <example id="zend.service.livedocx.mailmerge.information.getimageformats">
  714. <title>Ein Array an unterstützten Dateiformaten für Bilder erhalten</title>
  715. <para>
  716. Der folgende Code zeigt ein Array aller unterstützten
  717. Dateiformate für Bilder. Diese Methode ist besonders nützlich, falls
  718. eine Auswahlliste angezeigt werden soll, welche es dem Endbenutzer erlaubt,
  719. das Ausgabeformat für den Erstellungsprozess des Dokuments auszuwählen.
  720. </para>
  721. <programlisting language="php"><![CDATA[
  722. $phpLiveDocx = new Zend_Service_LiveDocx_MailMerge();
  723. $phpLiveDocx->setUsername('myUsername')
  724. ->setPassword('myPassword');
  725. Zend_Debug::dump($phpLiveDocx->getImageFormats());
  726. ]]></programlisting>
  727. <para>
  728. <emphasis>BEACHTE:</emphasis> Da sich der Rückgabewert diese Methode sehr
  729. selten ändert, ist es sehr empfehlenswert einen Cache zu verwenden, wie z.B.
  730. <classname>Zend_Cache</classname> - das macht die Anwendung sichtbar schneller.
  731. </para>
  732. </example>
  733. </sect3>
  734. </sect2>
  735. </sect1>