<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Information Centre &#187; web development</title>
	<atom:link href="http://my.center-of.info/tag/web-development/feed/" rel="self" type="application/rss+xml" />
	<link>http://my.center-of.info</link>
	<description>“Wenn etwas schon da war, wie kann man es dann patentieren?” D.E.Knuth, 2002</description>
	<lastBuildDate>Mon, 28 Sep 2009 23:04:39 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Tutorial: JSF 2.0 Beispielanwendung</title>
		<link>http://my.center-of.info/2009/08/27/tutorial-jsf2-beipielanwendung/</link>
		<comments>http://my.center-of.info/2009/08/27/tutorial-jsf2-beipielanwendung/#comments</comments>
		<pubDate>Wed, 26 Aug 2009 22:22:39 +0000</pubDate>
		<dc:creator>Haf</dc:creator>
				<category><![CDATA[JEE]]></category>
		<category><![CDATA[Tutorial]]></category>
		<category><![CDATA[Web]]></category>
		<category><![CDATA[jsf2]]></category>
		<category><![CDATA[web development]]></category>

		<guid isPermaLink="false">http://my.center-of.info/?p=138</guid>
		<description><![CDATA[Wie schon erwähnt, erscheinen bald die ersten Releases von JSF 2.0.
Entsprechend wird nun eine kleine Beispielanwendung erstellt, um einen ersten Eindruck zu bekommen.
Technologie:

JSF 2.0: Mojarra in Version 2.0.0-b16
Tomcat 6
Maven
Eclipse


Voraussetzung:

JDK 6
Tomcat 6
Eclipse inklusive WTP, Maven (m2eclipse)
Beim m2eclipse-Plugin &#8220;Maven integration for WTP&#8221; in Eclipse nachinstallieren, falls nicht vorhanden

Vorbereitung:

In Eclipse ein dynamische Webprojekt erstellen
Tomcat 6 als Server in [...]]]></description>
			<content:encoded><![CDATA[<p>Wie schon <a href="http://my.center-of.info/2009/08/26/jsf2overview/" title="IC: JSF 2 Überblick">erwähnt</a>, erscheinen bald die ersten Releases von JSF 2.0.<br />
Entsprechend wird nun eine kleine Beispielanwendung erstellt, um einen ersten Eindruck zu bekommen.<br />
Technologie:</p>
<ul>
<li>JSF 2.0: Mojarra in Version 2.0.0-b16</li>
<li>Tomcat 6</li>
<li>Maven</li>
<li>Eclipse</li>
</ul>
<p><span id="more-138"></span><br />
<strong>Voraussetzung:</strong></p>
<ul>
<li><a href="http://java.sun.com/javase/downloads/index.jsp" target="_blank" title="SUN: Java Download">JDK 6</a></li>
<li><a href="http://tomcat.apache.org/download-60.cgi" target="_blank" title="Apache Tomcat 6 Download">Tomcat 6</a></li>
<li><a href="http://www.eclipse.org/downloads/packages/eclipse-ide-java-ee-developers/galileor" target="_blank" title="Eclipse Download: Galileor">Eclipse inklusive WTP</a>, Maven (<a href="http://m2eclipse.sonatype.org/" target="_blank" title="Sonatype: Maven Eclipse Plugin">m2eclipse</a>)</li>
<li>Beim m2eclipse-Plugin &#8220;<strong>Maven integration for WTP</strong>&#8221; in Eclipse nachinstallieren, falls nicht vorhanden</li>
</ul>
<p><strong>Vorbereitung:</strong></p>
<ol>
<li>In Eclipse ein dynamische Webprojekt erstellen</li>
<li>Tomcat 6 als Server in Eclipse einrichten</li>
<li>Dem Projekt &#8220;Maven Nature&#8221; hinzufügen. Zur Zeit ist das Projekt ein reines Webprojekt ohne Maven Eigenschaften. Durch Rechte-Maustaste auf das Projekt und dann <em>Maven > Enable Dependency Management</em> wird Maven-Funktionalität für das Projekt hinzugefügt</li>
<li>Maven erwartet eine andere Ordner-Struktur als in dem WTP-Webprojekt. Als erstes muss der Source-Ordner angepasst werden. Hierfür müssen mind. folgender Ordner erstellt werden: src/main/java. Diesen muss man in Eclipse dann auch als Source-Ordner konfigurieren (Java Build Path)</li>
<li>Der WebContent-Ordner wird von Maven mit der WTP-Integration genutzt. Hier ist keine Veränderung/Anpassung notwendig</li>
<li>Die existierende pom.xml muss entsprechende Einträge erweitert werden. Für JSF 2 könnte das wie folgt aussehen:
<pre class="brush: xml">
&lt;project xmlns=&amp;quot;http://maven.apache.org/POM/4.0.0&amp;quot; xmlns:xsi=&amp;quot;http://www.w3.org/2001/XMLSchema-instance&amp;quot; xsi:schemaLocation=&amp;quot;http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd&amp;quot;&gt;
  &lt;modelVersion&gt;4.0.0&lt;/modelVersion&gt;
  &lt;groupId&gt;jsf2test&lt;/groupId&gt;
  &lt;artifactId&gt;jsf2test&lt;/artifactId&gt;
  &lt;version&gt;0.0.1-SNAPSHOT&lt;/version&gt;

  &lt;properties&gt;
  	&lt;version.jsf2&gt;2.0.0-b16&lt;/version.jsf2&gt;
  	&lt;version.junit&gt;4.4&lt;/version.junit&gt;
  	&lt;version.jstl&gt;1.2&lt;/version.jstl&gt;
  	&lt;version.servlet&gt;2.5&lt;/version.servlet&gt;
  	&lt;version.log4j&gt;1.2.14&lt;/version.log4j&gt;
  &lt;/properties&gt;

  &lt;repositories&gt;
  	&lt;repository&gt;
		&lt;id&gt;maven2-repository.dev.java.net&lt;/id&gt;
		&lt;name&gt;Java.net Repository for Maven&lt;/name&gt;
		&lt;url&gt;http://download.java.net/maven/2/&lt;/url&gt;
		&lt;layout&gt;default&lt;/layout&gt;
	&lt;/repository&gt;
  &lt;/repositories&gt;

  &lt;build&gt;
    &lt;finalName&gt;jsf2test&lt;/finalName&gt;
    &lt;plugins&gt;
	    &lt;plugin&gt;
			&lt;artifactId&gt;maven-compiler-plugin&lt;/artifactId&gt;
			&lt;configuration&gt;
			&lt;source&gt;1.5&lt;/source&gt;
			&lt;target&gt;1.5&lt;/target&gt;
			&lt;/configuration&gt;
		&lt;/plugin&gt;

	    &lt;plugin&gt;
		  &lt;groupId&gt;org.mortbay.jetty&lt;/groupId&gt;
		  &lt;!-- jetty 7
		  &lt;artifactId&gt;jetty-maven-plugin&lt;/artifactId&gt;
		   --&gt;
		  &lt;artifactId&gt;maven-jetty-plugin&lt;/artifactId&gt;
		  &lt;version&gt;6.1.15&lt;/version&gt;
		  &lt;!--
		  &lt;configuration&gt;
		    &lt;scanIntervalSeconds&gt;10&lt;/scanIntervalSeconds&gt;
		  &lt;/configuration&gt;
		   --&gt;
		&lt;/plugin&gt;
    &lt;/plugins&gt;
  &lt;/build&gt;

   &lt;dependencies&gt;
   	&lt;!-- JSF2 --&gt;
	&lt;dependency&gt;
		&lt;groupId&gt;com.sun.faces&lt;/groupId&gt;
		&lt;artifactId&gt;jsf-api&lt;/artifactId&gt;
		&lt;version&gt;${version.jsf2}&lt;/version&gt;
	&lt;/dependency&gt;

	&lt;dependency&gt;
		&lt;groupId&gt;com.sun.faces&lt;/groupId&gt;
		&lt;artifactId&gt;jsf-impl&lt;/artifactId&gt;
		&lt;version&gt;${version.jsf2}&lt;/version&gt;
	&lt;/dependency&gt;

	&lt;dependency&gt;
      &lt;groupId&gt;javax.servlet&lt;/groupId&gt;
      &lt;artifactId&gt;jstl&lt;/artifactId&gt;
      &lt;version&gt;${version.jstl}&lt;/version&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
      &lt;groupId&gt;javax.servlet&lt;/groupId&gt;
      &lt;artifactId&gt;servlet-api&lt;/artifactId&gt;
      &lt;version&gt;${version.servlet}&lt;/version&gt;
    &lt;/dependency&gt;

	&lt;!-- Misc --&gt;
    &lt;dependency&gt;
      &lt;groupId&gt;junit&lt;/groupId&gt;
      &lt;artifactId&gt;junit&lt;/artifactId&gt;
      &lt;version&gt;${version.junit}&lt;/version&gt;
      &lt;scope&gt;test&lt;/scope&gt;
    &lt;/dependency&gt;

    &lt;dependency&gt;
	    &lt;groupId&gt;log4j&lt;/groupId&gt;
	    &lt;artifactId&gt;log4j&lt;/artifactId&gt;
	    &lt;version&gt;${version.log4j}&lt;/version&gt;
	&lt;/dependency&gt;

  &lt;/dependencies&gt;
&lt;/project&gt;
</pre>
</li>
<li>Die Bibliotheken, welche Maven bereitstellt, müssen beim Deploy in WEB/lib kopiert werden. Die Nutzung der Maven Dependencies geschieht durch folgende Einstellung: In den Eigenschaften des Projekts muss unter <strong>Java EE Module Dependencies</strong> die <strong>Maven Dependencies</strong> ausgewählt werden.</li>
<li>Web.xml für JSF anpassen. Z.B. wie folgt:
<pre class="brush: xml">
&lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;UTF-8&amp;quot;?&gt;
&lt;web-app xmlns:xsi=&amp;quot;http://www.w3.org/2001/XMLSchema-instance&amp;quot; xmlns=&amp;quot;http://java.sun.com/xml/ns/javaee&amp;quot; xmlns:web=&amp;quot;http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd&amp;quot; xsi:schemaLocation=&amp;quot;http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd&amp;quot; id=&amp;quot;WebApp_ID&amp;quot; version=&amp;quot;2.5&amp;quot;&gt;
  &lt;display-name&gt;dynWebTest&lt;/display-name&gt;

  &lt;servlet&gt;
    &lt;servlet-name&gt;Faces Servlet&lt;/servlet-name&gt;
    &lt;servlet-class&gt;javax.faces.webapp.FacesServlet&lt;/servlet-class&gt;
    &lt;load-on-startup&gt;1&lt;/load-on-startup&gt;
  &lt;/servlet&gt;

  &lt;servlet-mapping&gt;
    &lt;servlet-name&gt;Faces Servlet&lt;/servlet-name&gt;
    &lt;url-pattern&gt;*.xhtml&lt;/url-pattern&gt;
  &lt;/servlet-mapping&gt;

  &lt;!-- This parameter is also possible to set over JNDI --&gt;
  &lt;context-param&gt;
    &lt;param-name&gt;javax.faces.PROJECT_STAGE&lt;/param-name&gt;
    &lt;param-value&gt;Development&lt;/param-value&gt;
  &lt;/context-param&gt;

  &lt;welcome-file-list&gt;
    &lt;welcome-file&gt;index.html&lt;/welcome-file&gt;
    &lt;welcome-file&gt;index.xhtml&lt;/welcome-file&gt;
  &lt;/welcome-file-list&gt;
&lt;/web-app&gt;
</pre>
</li>
</ol>
<p>Nun steht das Grundgerüst bereit, um endlich mit JSF 2.0 anzufangen.<br />
Für diejenigen, die mit JSF 1.x schon gearbeitet haben, werden wohl die faces-config.xml vermissen. Korrekt. Ist gewollt. Ist nämlich die erste Verbesserung von JSF 2.0! Die faces-config.xml kann immer noch verwendet werden, aber vieles ist durch Annotations möglich und die Navigation ist einfacher/verständlicher geworden. Später mehr dazu.</p>
<p>Vielleicht noch ein paar Worte zur Beispielanwendung: Die Beispielanwendung beinhaltet eine Seite, mit einem Input-Feld und zwei Select-Boxen. Man stelle sich folgendes Szenario vor: Man möchte ein Registrierungs-Formular erstellen, in dem der Nutzer überprüfen kann, ob der Username noch vorhanden ist. Zusätzlich soll er das Land auswählen können, in dem er lebt.</p>
<p><strong> Controller:</strong><br />
Der Controller ist das ManagedBean, welches in den XHTML-Seiten verwendet wird und alle Anfragen verarbeitet.</p>
<pre class="brush: java">
@ManagedBean(name = &amp;quot;fc&amp;quot;)
@RequestScoped
public class FrontController {

	private Person person;

	private String country;

	private String continent;

	private Map&lt;String, String[]&gt; countries;

	@ManagedProperty(value = &amp;quot;#{authService}&amp;quot;)
	private AuthService authService;

	public void isUsernameValid() {

		if(authService.isUsernameValid(person.getUsername())) {

			output = &amp;quot;Username ist nocht nicht vorhanden&amp;quot;;
		} else {
			output = &amp;quot;Username ist schon vorhanden. Bitte einen anderen auswählen&amp;quot;;
		}
	}

        public String[] getCountries() {
		// deliver the countries to the actual continent
		return countries.get(continent);
	}
       /* further get/set-Methods */
}
</pre>
<p>Durch die Annotations wird JSF mitgeteilt, dass es sich bei der Klasse um ein managed bean mit dem Namen <strong>fc</strong> handelt (@ManagedBean) und die jeweils immer nur für ein Request gültig ist (@RequestScoped, <a href="https://javaserverfaces.dev.java.net/nonav/docs/2.0/managed-bean-javadocs/" target="_blank" title="API 2.0 - Managed Bean">weitere Scops sind vorhanden</a>). Früher hat man diese Einstellungen in faces-config.xml durchgeführt.<br />
Neu ist auch @ManagedProperty. Mittels dieser Annotation wird die Dependency Injection Funktionalität von JSF 2.0 verwendet. In FrontController#authService wird nun das passende Objekt mit dem managed bean namen &#8220;authService&#8221; injiziert.<br />
Hier sei anzumerken, dass JSF kein field access durchführt, sondern die getter/setter-Methoden verwendet um Properties zu setzen.</p>
<p>Die Domain-Klasse Person ist ein einfaches Bean bzw. POJO, und repräsentiert die einzugebenden Daten in dem Formular.</p>
<p>Zu dem Controller und Model Teil gehört noch die Präsentation und diese wird mittels <a href="https://facelets.dev.java.net/" target="_blank" title="Facelets">Facelets</a> durchgeführt. In JSF 2.0 ist Facelets die primäre Technologie zur <a href="https://javaserverfaces.dev.java.net/nonav/docs/2.0/javadocs/javax/faces/view/ViewDeclarationLanguage.html" target="_blank" title="ViewDeclarationLanguage API">Beschreibung des Views</a>. Man kann natürlich JSP nutzen, wenn man den Sprung nicht durchführen möchte. Aber die Vorteile liegen eher bei Facelets!</p>
<pre class="brush: xml">
&lt;!DOCTYPE html PUBLIC &amp;quot;-//W3C//DTD XHTML 1.0 Transitional//EN&amp;quot;
        &amp;quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&amp;quot;&gt;

&lt;html xmlns=&amp;quot;http://www.w3.org/1999/xhtml&amp;quot;
      xmlns:ui=&amp;quot;http://java.sun.com/jsf/facelets&amp;quot;
      xmlns:f=&amp;quot;http://java.sun.com/jsf/core&amp;quot;
      xmlns:h=&amp;quot;http://java.sun.com/jsf/html&amp;quot;&gt;

&lt;h:head&gt;
  &lt;title&gt;JSF Demo&lt;/title&gt;
&lt;/h:head&gt;
&lt;h:body&gt;
  &lt;h1&gt;Register&lt;/h1&gt;
  &lt;h:form&gt;

    &lt;h:inputText id=&amp;quot;name&amp;quot; value=&amp;quot;#{fc.person.username}&amp;quot;&gt;
    &lt;/h:inputText&gt;
    &lt;h:commandButton value=&amp;quot;Check username&amp;quot; action=&amp;quot;#{fc.isUsernameValid}&amp;quot;&gt;
    	&lt;f:ajax execute=&amp;quot;name&amp;quot; render=&amp;quot;outIsUserValid&amp;quot; /&gt;
    &lt;/h:commandButton&gt;
    &lt;h:outputText id=&amp;quot;outIsUserValid&amp;quot; value=&amp;quot;#{fc.output}&amp;quot; /&gt;
  &lt;/h:form&gt;
  &lt;br /&gt;

  &lt;h:form&gt;
                &lt;!-- First select box to select the continent.... --&gt;
  		&lt;h:selectOneMenu value=&amp;quot;#{fc.continent}&amp;quot;&gt;
  			&lt;f:selectItems value=&amp;quot;#{fc.continents}&amp;quot; /&gt;
  			&lt;f:ajax render=&amp;quot;countrylist&amp;quot; /&gt;
  		&lt;/h:selectOneMenu&gt;

                &lt;!-- ...and depending of the selected continent, contains this
                      second select box the countries
                --&gt;
  		&lt;h:selectOneMenu value=&amp;quot;#{fc.country}&amp;quot; id=&amp;quot;countrylist&amp;quot;&gt;
  			&lt;f:selectItems value=&amp;quot;#{fc.countries}&amp;quot; /&gt;
  		&lt;/h:selectOneMenu&gt;
  &lt;/h:form&gt;
&lt;/h:body&gt;
&lt;/html&gt;
</pre>
<p>Mittels Facelets ist die Beschreibung der Views reiner XML/XHTML.<br />
In dem ersten Formular ist das Input-Feld, in dem der Nutzer überprüfen kann, ob sein Username schon vergeben ist. Die Überprüfung wird mittels Ajax durchgeführt. Hierfür ist der neue <a href="https://javaserverfaces.dev.java.net/nonav/docs/2.0/pdldocs/facelets/f/ajax.html" target="_blank" title="JSF2 API: Ajax Tag">&lt;f:ajax&gt;-Tag</a> zuständig. Beim betätigen des Buttons wird ein Ajax-Request verschickt, dieser beinhaltet die Werte aus den Felder in dem <em>execute</em>-Attribute. In unserem Fall aus dem Feld mit der ID <em>name</em>. Die Antwort wird, wie in dem <em>render</em>-Attribute definiert, in ID <em>outIsUserValid</em> eingefügt. Auf dem Server wird zur Verarbeitung die Methode FrontController.isUsernameValid() aufgerufen. Während des Aufrus ist FrontController#person mit den aktuellen Werten (hier: username) gesetzt.</p>
<p>In dem zweiten Formular gibt es zwei Select-Boxen. In dem einen kann ein Kontinent ausgewählt werden. Resultierend dazu, wird in der zweiten eine Liste von Ländern angezeigt. Diese Länder-Liste wird durch Ajax ermittelt.<br />
In der ersten Liste ist wieder ein &lt;f:ajax&gt;-Tag zu finden. Bei dem 1. Beispiel wurde der Request verschickt, wenn der Nutzer den Button drückt. D.h. in der Javascript-Welt, beim Click-Event, wird der Request verschickt. Das &lt;f:ajax&gt;-Tag wählt immer das passende Event aus, abhängig von der Komponente, in dem es verwendet wird.<br />
Bei Listen horcht es auf ein OnChange-Event. Natürlich kann man ein anderes Event festlegen, dafür gibt es das <em>event</em>-Attribut.<br />
D.h. also, sobald in der ersten Liste die Auswahl verändert wird, wird die zweite Liste aktualisiert (durch render=&#8221;countrylist&#8221;). Auf dem Server wird FrontController.getCountries() aufgerufen. In dem Kontext ist FrontController#continent belegt, da der Nutzer eine Auswahl in der 1.Liste durchgeführt hat. FrontController.getCountries() liefert nun nur ein Array von Ländern zurück. Die korrekte Verschachtelung in HTML-Elemente (option-Tag) übernimmt JSF!</p>
<p><strong>Fazit:</strong></p>
<ul>
<li>Mittels JSF 2.0 hat man weniger Konfigurationsaufwand</li>
<li>Durch den Einsatz von Facelets macht das Erstellen der HTML-Seiten wieder Spass. Hier kann man die vorhandenen HTML-Templates fast unverändert übernehmen&#8230;</li>
<li>Unproblematischer Javascript/Ajax-Einsatz, ohne es wirklich zu merken!</li>
<li>DI ohne Spring!</li>
</ul>
<p>Also der erste Eindruck hat überzeugt. Wenn man JSF-Fan war, wird man JSF-Fan weiter bleiben. Wenn nicht, könnte man es jetzt bestimmt werden <img src='http://my.center-of.info/wp-includes/images/smilies/icon_wink.gif' alt=';-)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://my.center-of.info/2009/08/27/tutorial-jsf2-beipielanwendung/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Spec 2.0: JSF 2 Überblick</title>
		<link>http://my.center-of.info/2009/08/26/jsf2overview/</link>
		<comments>http://my.center-of.info/2009/08/26/jsf2overview/#comments</comments>
		<pubDate>Wed, 26 Aug 2009 20:52:45 +0000</pubDate>
		<dc:creator>Haf</dc:creator>
				<category><![CDATA[JEE]]></category>
		<category><![CDATA[Web]]></category>
		<category><![CDATA[jsf2]]></category>
		<category><![CDATA[web development]]></category>

		<guid isPermaLink="false">http://my.center-of.info/?p=135</guid>
		<description><![CDATA[JSF ist ja nicht jedermanns Sache. Ich fand JSF 1.x auch mit den &#8220;Problemen&#8221; toll. Die Implementierung (Mojarra und MyFaces) hatten so manche Fehler und zusätzliche Funktionalitäten, welche in der Spec nicht definiert wurden. Aber im Großen und Ganzen ein gutes und solides Konzept.
Leider jedoch ein Framework, was ein paar Jährchen und Trends hinter sich [...]]]></description>
			<content:encoded><![CDATA[<p>JSF ist ja nicht jedermanns Sache. Ich fand JSF 1.x auch mit den &#8220;Problemen&#8221; toll. Die Implementierung (<a href="https://javaserverfaces.dev.java.net/" target="_blank" title="Mojarra: JSF SUN RI">Mojarra</a> und <a href="http://myfaces.apache.org/" target="_blank" title="MyFaces Project">MyFaces</a>) hatten so manche Fehler und zusätzliche Funktionalitäten, welche in der Spec nicht definiert wurden. Aber im Großen und Ganzen ein gutes und solides Konzept.<br />
Leider jedoch ein Framework, was ein paar Jährchen und Trends hinter sich hat &#8211; JSF 1.1 (<a href="http://www.jcp.org/en/jsr/detail?id=127" target="_blank" title="JSR 127:JavaServer Faces">JSR 127</a>, 03.2001) und JSF 1.2 (<a href="http://www.jcp.org/en/jsr/detail?id=252" target="_blank" title="JSR 252:JavaServer Faces">JSR 252</a>, 05.2006). Seit 07.2009 gibt es nun das Final Release der JSF 2.0 Spezifikation (<a href="http://www.jcp.org/en/jsr/detail?id=314" target="_blank" title="JSR 314:JavaServer Faces">JSR 314</a>).<br />
<span id="more-135"></span><br />
Die <a href="https://javaserverfaces.dev.java.net/servlets/ProjectDocumentList?folderID=11662" target="_blank" title="Mojarra: 2.0.0-RC">RI von SUN</a> steht auch bald bereit und auch die Truppe um MyFaces hat einen <a href="http://matthiaswessendorf.wordpress.com/2008/08/29/myfaces-goes-jsf-20/" target="_blank" title="Matthias Wessendorf's Weblog: MyFaces goes JSF 2.0">JSF 2.0 Branch</a> erstellt. Spätestens jetzt sollte man einen Blick auf die Neuerungen und Verbesserungen, die mit 2.0 eingeführt werden, werfen.<br />
Möchte man sich nun mit JSF 2.0 auseinander setzen, könnte man sich die ersten Bücher besorgen, aber ob diese aktuell und praxistauglich sind, sei jedem überlassen.<br />
Die vielleicht komplette und aktuelle Information kriegt man zur Zeit, wenn man sich direkt die APIs anschaut und verschiedene Blogs verfolgt.<br />
Hier folgt erstmal eine unvollständige Liste von Informationsquellen (wird aktualisiert):</p>
<ul>
<li><a href="http://andyschwartz.wordpress.com/2009/07/31/whats-new-in-jsf-2/" target="_blank" title="Andy Schwartz’s Weblog: What’s New in JSF 2?">Andy Schwartz Blogeintrag</a> Andy hat selbst eine Auflistung inklusive weitere Erklärung aufgeführt</li>
<li><a href="https://javaserverfaces.dev.java.net/users.html" target="_blank" title="Mojarra: Get Started">Mojarra: Get started</a></li>
<li><a href="https://javaserverfaces.dev.java.net/nonav/rlnotes/2.0.0/index.html" target="_blank" title="Mojarra 2.0.0 RC Release Notes Overview">Mojarra 2.0.0 Release Notes</a>: Mit den Verweisen zu den aktuellen APIs, TLDs etc</li>
</ul>
<p>Zu dieser Auflistung, die aktualisiert wird, folgen in dem Blog ein paar Beispiele zu speziellen Themen.</p>
<p>P.S.: In dem Block &#8220;Spec 2.0&#8243; folgen demnächst Beiträge zu Spezifikationen, Frameworks die nun in Version 2.0 erschienen sind.</p>
]]></content:encoded>
			<wfw:commentRss>http://my.center-of.info/2009/08/26/jsf2overview/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>JSF: Method not called</title>
		<link>http://my.center-of.info/2009/03/10/jsf-method-not-called/</link>
		<comments>http://my.center-of.info/2009/03/10/jsf-method-not-called/#comments</comments>
		<pubDate>Tue, 10 Mar 2009 15:32:45 +0000</pubDate>
		<dc:creator>Haf</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[jsf]]></category>
		<category><![CDATA[web development]]></category>

		<guid isPermaLink="false">http://my.center-of.info/?p=116</guid>
		<description><![CDATA[Java Server Faces (JSF) ist eine schöne Technologie für den Web-JEE-Bereich.
Es bietet eine gute Möglichkeit die Entkopplung der einzelnen Schichten einzuhalten und mit der Kombination von Facelets, kann sogar ein Grafiker einfacher damit arbeiten.
Bei JSF sind bestimmte &#8220;Aktionen&#8221; einer Methode zugeordnet. (Methode aus dem ManagedBean, normale Klasse welche in faces-config.xml festgeleg wird, bzw. bei Spring-Einsatz [...]]]></description>
			<content:encoded><![CDATA[<p>Java Server Faces (JSF) ist eine schöne Technologie für den Web-JEE-Bereich.</p>
<p>Es bietet eine gute Möglichkeit die Entkopplung der einzelnen Schichten einzuhalten und mit der Kombination von Facelets, kann sogar ein Grafiker einfacher damit arbeiten.</p>
<p>Bei JSF sind bestimmte &#8220;Aktionen&#8221; einer Methode zugeordnet. (Methode aus dem ManagedBean, normale Klasse welche in faces-config.xml festgeleg wird, bzw. bei Spring-Einsatz kann man das auch weglassen). D.h. eine Aktion &#8220;Kunde anlegen&#8221;, welches als Button dargestellt wird, wird mit der Methode CustomerController.add() gebunden.</p>
<p>Oft funktioniert das auch ohne Probleme. Man füllt das Formular aus und drückt den Button. JSF konstruiert den ComponentTree, stellt die Daten wieder in die Objekte und sollte irgendwann auch unsere Methode CustomerController.add() aufrufen. Jaein.</p>
<p>&lt;h:form enctype=&#8221;multipart/form-data&#8221;&gt;</p>
<p>Man beachte &lt;code&gt;enctype=&#8221;multipart/form-data&#8221; &lt;/code&gt;. Das ist das Problem. Ein einfaches</p>
<p>&lt;h:form&gt;</p>
<p>funktioniert. Dann wird die Methode wieder auch aufgerufen!</p>
]]></content:encoded>
			<wfw:commentRss>http://my.center-of.info/2009/03/10/jsf-method-not-called/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>JavaFX 1.0 Example</title>
		<link>http://my.center-of.info/2008/12/07/javafx-10-example/</link>
		<comments>http://my.center-of.info/2008/12/07/javafx-10-example/#comments</comments>
		<pubDate>Sun, 07 Dec 2008 13:10:59 +0000</pubDate>
		<dc:creator>Haf</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[javafx]]></category>
		<category><![CDATA[JEE]]></category>
		<category><![CDATA[ria]]></category>
		<category><![CDATA[web development]]></category>

		<guid isPermaLink="false">http://my.center-of.info/?p=89</guid>
		<description><![CDATA[Im letzten Beitrag habe ich kurz JavaFX vorgestellt. Zu den theoretischen Daten folgt nun ein kleines praktisches Beispiel.
Das Beispiel basiert auf das Tutorial von SUN [1] und wurde um die Eigenschaft erweitert, dass das Applet auch auf dem Desktop verwendet werden kann.

Das Beispiel erstellt eine analoge Uhr, welche man sich auf den Desktop ziehen kann. [...]]]></description>
			<content:encoded><![CDATA[<p>Im <a title="Information Centre: JavaFX 1.0" href="http://my.center-of.info/2008/12/07/javafx-10/">letzten Beitrag</a> habe ich kurz <a title="SUN JavaFX" href="http://www.javafx.com" target="_blank">JavaFX</a> vorgestellt. Zu den theoretischen Daten folgt nun ein kleines praktisches Beispiel.</p>
<p>Das Beispiel basiert auf das Tutorial von SUN [1] und wurde um die Eigenschaft erweitert, dass das Applet auch auf dem Desktop verwendet werden kann.</p>
<p><span id="more-89"></span></p>
<p>Das Beispiel erstellt eine analoge Uhr, welche man sich auf den Desktop ziehen kann. Der Fokus liegt auf die Implementierung und nicht auf jegliche graphische Feinheiten.</p>
<p>Ein JavaFX Script wie im unteren Listing zu sehen beinhaltet immer eine <a title="JavaFX API: Stage" href="http://java.sun.com/javafx/1/docs/api/javafx.stage/javafx.stage.Stage.html" target="_blank">Stage</a> Klasse. Dies ist der globale Container, der alle weiteren Elemente beinhaltet.</p>
<pre class="brush: java">
import javafx.scene.Scene;
import javafx.stage.Stage;

var stage = Stage {
      title: &amp;amp;amp;amp;amp;quot;JavaFX Test Clock&amp;amp;amp;amp;amp;quot;
      width: 300
      height: 300
      scene: Scene {
          content: []
     }
}
</pre>
<p>Da JavaFX eine deklarative Sprache ist, beschreibt man, was man haben will. Dafür gibt es verschiedene Propterties (wie in dem Fall: width, height, scene, content), die man belegen kann.</p>
<p>Ein Stage Container besitzt ein <a title="SUN JavaFX API: Scene" href="http://java.sun.com/javafx/1/docs/api/javafx.scene/javafx.scene.Scene.html" target="_blank">Scene</a>, in dem verschiedene Nodes enthalten sind. <a title="SUN JavaFX API: Node" href="http://java.sun.com/javafx/1/docs/api/javafx.scene/javafx.scene.Node.html" target="_blank">Node</a> kann hier als ein graphisches Element (<a title="SUN JavaFX API: Rectangle" href="http://java.sun.com/javafx/1/docs/api/javafx.scene.shape/javafx.scene.shape.Rectangle.html" target="_blank">Rectangle</a>, <a title="SUN JavaFX API: Text" href="http://java.sun.com/javafx/1/docs/api/javafx.scene.text/javafx.scene.text.Text.html" target="_blank">Text</a>, <a title="SUN JavaFX API: ImageView" href="http://java.sun.com/javafx/1/docs/api/javafx.scene.image/javafx.scene.image.ImageView.html" target="_blank">ImageView</a>) angesehen werden. In dem oberen Listing gibt es noch keine Nodes &#8211; content ist ein leeres Array.</p>
<p>Eine Uhr besteht aus verschiedenen Kreisen und Linien für die Zeiger. Nun könnte man in dem stage.scene.content diese graphischen Elemente schreiben, da man jedoch etwas strukturierter arbeiten will, kapseln wir die Funktionalität in eine eigene Klasse. Im folgenden Listing ist ein Teil von Clock.fx zu sehen:</p>
<pre class="brush: java">
public class Clock extends CustomNode {

public var radius: Number = 77;
public var centerX: Number = 144;
public var centerY: Number = 144;

public var hours: Number;
public var minutes: Number;
public var seconds: Number;

public override function create(): Node {
  return Group {
    content: [
     Group {
      transforms: Translate {
        x: centerX
        y: centerY
      }
      content: [
        // displays the number of every third hour
        for (i in [3, 6, 9, 12])
          Text {
             transforms: Translate {
                x: -5,
                y: 5
             }
             fill: Color.GREEN
             font: Font {
               size: 16
             }
             x: radius * (( i + 0 ) mod 2 * ( 2 - i / 3))
             y: radius * (( i + 1 ) mod 2 * ( 3 - i / 3))
             content: &amp;amp;amp;amp;amp;quot;{i}&amp;amp;amp;amp;amp;quot;
          },  //Text

          // display a yellow point for the rest of the
          // hours on the clock
          for (i in [1..12] )
            if (i mod 3 != 0 ) then Circle {
               transforms: Rotate {
                  angle: 30 * i
               }
               centerX: radius
               radius: 3
               fill: Color.YELLOW
            } // if
            else [ ],

            // clock&#039;s first center circle
            Circle {
              radius: 5
              fill: Color.DARKRED
            }, //Circle
            // the smaller center circle
            Circle {
              radius: 3
              fill: Color.RED
            }, //Circle
            // the seconds hand
            Line {
              transforms: Rotate {
                angle: bind seconds * 6
              }
              endY: -radius - 3
              strokeWidth: 2
              stroke: Color.VIOLET
            },  //Line
            // the hour hand
            Path {
              transforms: Rotate {
                 angle: bind (hours + minutes / 60) * 30 - 90
              }
              fill: Color.YELLOW
              elements: [
                 MoveTo {
                    x: 4,
                    y: 4
                 },
                 ArcTo {
                    x: 4
                    y: -4
                    radiusX: 1
                    radiusY: 1
                 },
                 LineTo {
                    x: radius - 15
                    y: 0
                 },
              ] //elements
            },  // Path
            // the minutes hand
            Path {
              transforms: Rotate {
                 angle: bind minutes * 6 - 90
              }
              fill: Color.GREEN
              elements: [
                 MoveTo {
                    x: 4,
                    y: 4
                 },
                 ArcTo {
                    x: 4
                    y: -4
                    radiusX: 1
                    radiusY: 1
                 },
                 LineTo {
                    x: radius
                    y: 0
                 },
              ] // elements
            } // Path
       ] // 2. Group content
     } // Group
   ] // Group content
  };  // Group
 } // create()

} // class
</pre>
<p>Um nun das Drag-and-Drop des Applets zu ermöglichen, erweitert man den Stage um einen sogenannten <a href="http://java.sun.com/javafx/1/docs/api/javafx.stage/javafx.stage.AppletStageExtension.html" target="_blank" title="SUN JavaFX API: AppletStageExtension">AppletStageExtension</a>. </p>
<pre class="brush: java">
stage = Stage {
    title: &amp;amp;amp;amp;amp;quot;JavaFX Test Clock&amp;amp;amp;amp;amp;quot;
    width: 300
    height: 300
    style: StageStyle.TRANSPARENT
    onClose: function() {
        //System.exit(0);
    }
    visible: true
    scene: Scene {
        fill: bind if (inBrowser) Color.WHITE else Color.TRANSPARENT
        content: [
            Clock {},
            // drag controls
            dragArea,
            dragClosers,
            statusText
        ]
    }
    extensions: [
        AppletStageExtension {
            shouldDragStart: function(e): Boolean {
                return inBrowser and e.primaryButtonDown and dragArea.hover;
            }
            onDragStarted: function(): Void {
                inBrowser = false;
            }
            onAppletRestored: function(): Void {
                inBrowser = true;
            }
            useDefaultClose: false
        }
    ]
}
</pre>
<p>Die Funktion shoudDragStart() gibt an, ob die Drag-Drop-Funktionalität angeboten werden soll, oder nicht.<br />
Anzumerken ist, dass das Property AppletStageExtension.useDefaultClose = false ist, da ein eigenes Close-Symbol erstellt wurde. Beim Betätigen dieses Buttons schließt sich das Applet und kehrt zum Browser zurück &#8211; falls dieser noch vorhanden ist.</p>
<p>In dem oberen Listing beinhaltet stage.scene.content noch den Node &#8220;dragArea&#8221;:</p>
<pre class="brush: java">
var dragArea:Rectangle = Rectangle {
    x: 155
    y: 30
    width: 420
    height: 25
    fill: Color.RED
    onMouseDragged:function(e:MouseEvent):Void {
        stage.x += e.dragX;
        stage.y += e.dragY;
    }
};
</pre>
<p>Das ist der Bereich, in dem der Nutzer das Applet herum ziehen kann. In der onMouseDragged() Funktion wird immer die aktuelle Position der Stage gesetzt.</p>
<p>Was passiert, wenn ein Applet auf den Desktop verschoben wird und das Browser-Fenster geschlossen wird? Dann bietet Java die Möglichkeit eine Verknüpfung zu erstellen.<br />
Dabei speichert es ein paar XML-Daten im User-Verzeichnis und setzt eine Verlinkung, um die Daten per Java Webstart zu starten.</p>
<p>Der Inhalt der JNLP-XML-Datei sieht z.B. so aus:</p>
<pre class="brush: xml">
&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;
&lt;jnlp spec=&quot;1.0+&quot; codebase=&quot;http://example.net/JavaFXClock&quot; href=&quot;JavaFXClock_browser.jnlp&quot;&gt;
    &lt;information&gt;
        &lt;title&gt;JavaFXClock&lt;/title&gt;
        &lt;vendor&gt;Hafid Haddouti&lt;/vendor&gt;
        &lt;homepage href=&quot;http://example.net/JavaFXClock&quot;/&gt;
        &lt;description&gt;JavaFXClock&lt;/description&gt;
        &lt;offline-allowed/&gt;
        &lt;shortcut&gt;
            &lt;desktop/&gt;
        &lt;/shortcut&gt;
    &lt;/information&gt;
    &lt;resources&gt;
        &lt;j2se version=&quot;1.5+&quot;/&gt;
        &lt;extension name=&quot;JavaFX Runtime&quot; href=&quot;http://dl.javafx.com/javafx-rt.jnlp&quot;/&gt;
        &lt;jar href=&quot;JavaFXClockt.jar&quot; main=&quot;true&quot;/&gt;
    &lt;/resources&gt;
    &lt;applet-desc name=&quot;JavaFXClock&quot; main-class=&quot;com.sun.javafx.runtime.adapter.Applet&quot; width=&quot;350&quot; height=&quot;350&quot;&gt;
        &lt;param name=&quot;MainJavaFXScript&quot; value=&quot;javafxtest.Main&quot;&gt;
    &lt;/applet-desc&gt;
&lt;/jnlp&gt;
</pre>
<p>Ein Beispiel ist <a href="http://my.center-of.info/javafx-clock-example/">hier</a> zu finde.</p>
<p>Links:<br />
[1] JavaFX Tutorial: <a title="Building a JavaFX Application Using NetBeans IDE" href="http://java.sun.com/javafx/1/tutorials/build-javafx-nb-app/" target="_blank">http://java.sun.com/javafx/1/tutorials/build-javafx-nb-app/</a></p>
]]></content:encoded>
			<wfw:commentRss>http://my.center-of.info/2008/12/07/javafx-10-example/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>JavaFX 1.0</title>
		<link>http://my.center-of.info/2008/12/07/javafx-10/</link>
		<comments>http://my.center-of.info/2008/12/07/javafx-10/#comments</comments>
		<pubDate>Sun, 07 Dec 2008 11:11:59 +0000</pubDate>
		<dc:creator>Haf</dc:creator>
				<category><![CDATA[JEE]]></category>
		<category><![CDATA[Web]]></category>
		<category><![CDATA[java]]></category>
		<category><![CDATA[javafx]]></category>
		<category><![CDATA[ria]]></category>
		<category><![CDATA[web development]]></category>

		<guid isPermaLink="false">http://my.center-of.info/?p=82</guid>
		<description><![CDATA[Seit dem 04.12.2008 gibt es nun endlich die Version 1.0 von JavaFX. JavaFX ist eine Plattform um Rich Internet Applications für verschiedene End-Geräte zu erstellen. Im Idealfall realisiert man eine Anwendung, die dann später im Browser, auf dem Desktop und auf dem mobilen Gerät läuft. Für weitere Details sei auf die JavaFX-Seiten verwiesen [1] und [...]]]></description>
			<content:encoded><![CDATA[<p>Seit dem 04.12.2008 gibt es nun endlich die Version 1.0 von <a title="SUN JavaFX" href="http://www.javafx.com/" target="_blank">JavaFX</a>. JavaFX ist eine Plattform um Rich Internet Applications für verschiedene End-Geräte zu erstellen. Im Idealfall realisiert man eine Anwendung, die dann später im Browser, auf dem Desktop und auf dem mobilen Gerät läuft. Für weitere Details sei auf die JavaFX-Seiten verwiesen [1] und [2].</p>
<p><span id="more-82"></span></p>
<p><strong>Überblick</strong></p>
<p>Um JavaFX-Anwendung zu nutzen, braucht man standardmäßig nur die aktuelle Java Version. Hier ist Java 1.6.0_11 [3] passend, da diese Version die Fähigkeit anbietet, Applets auf den Desktop zu ziehen. Beim ersten Aufruf einer JavaFX-Anwendung werden die Runtime-Bibliotheken beim ersten Mal runtergeladen, wenn sie nicht vorhanden sind. Bei entsprechender Implimentierung der JavaFX-Anwendung (was ja ein Applet ist), kann man sich das Applet auf den Desktop ziehen. Schließt man dann den Browser, bekommt man die Möglichkeit ein Verweis auf den Desktop zu erstellen, um später das Applet &#8211; und nur das Applet, nicht auch den Browser &#8211; wieder zu nutzen.</p>
<p>JavaFX kommt auch mit einer neuen Script-Sprache, dem JavaFX Script. JavaFX Script ist eine deklarative kompilierbare Scriptsprache, was auch type inference &#8211; und somit implizit auch statische Typen &#8211; anbietet.</p>
<p><strong>Entwicklung</strong></p>
<p>Zur Entwicklung. Sun setzt ja bekanntlich auf Netbeans. Das bedeutet in dem Fall, es gibt ein Netbeans-Version [4] mit integriertem JavaFX. Diese Version beinhaltet das JavaFX Software Development Kit, Beispiele und bei Windows noch den JavaFX Mobile Emulator.</p>
<p>Zusätzlich gibt es Plugins für Photoshop und Adobe Illustrator. Mit JavaFX sollen ja auch schöne GUIs erstellt werden und hierfür bietet man Grafikern eine einfache Möglichkeit dies in ihren bekannten Umgebungen zu erstellen. Wie gut diese Plugins funktionieren, kann ich leider nicht sagen.</p>
<p>Für Eclipse-Nutzer gibt es ein veraltetes Plugin [5], hier ist zu hoffen, dass demnächst eine aktuellere Version veröffentlich wird.</p>
<p>Mit Netbeans kann man jedenfalls recht einfach erste JavaFX Anwendungen realisieren. Für die grafische Darstellung kann man eine Palette von vorhandenen Mustern, Transformationen etc nutzen. Jedoch gibt es hier keinen visuellen Designer. Die Palette beinhaltet nur Code-Fragmente, die in den existierenden Code eingefügt werden können. Ob es hier einen Designer geben wird, ist fraglich, da entsprechen Photoshop/Illustrator Plugins existieren.</p>
<p><strong>Features</strong></p>
<p>Die Features dürfen nun auch nicht vergessen werden:</p>
<ul>
<li>RIA Plattform für verschiedene Endgeräte</li>
<li>Einfache Integration für Grafiker</li>
<li>Gute Unterstützung von Grafiken, 2D, 3D, Video, Audio</li>
<li>Zugang zu Java-Bibliotheken</li>
</ul>
<p>Für weitere Details sei auf die Überblicks-Seite in [1] verwiesen.</p>
<p>Links:<br />
[1] JavaFX Überblick: <a title="SUN JavaFX Überblick" href="http://javafx.com/about/overview/" target="_blank">http://javafx.com/about/overview/ </a><br />
[2] JavaFX Getting Started with the Technology: <a title="Getting Started with JavaFX Technology" href="http://javafx.com/docs/gettingstarted/javafx/" target="_blank">http://javafx.com/docs/gettingstarted/javafx/</a><br />
[3] Java SE 6 Update Release Notes: <a title="SUN Java6 Changelogs" href="http://java.sun.com/javase/6/webnotes/6u11.html" target="_blank">http://java.sun.com/javase/6/webnotes/6u11.html</a><br />
[4] JavaFX Download (for Windows): <a title="SUN JavaFX Download page" href="http://javafx.com/downloads/windows.jsp" target="_blank">http://javafx.com/downloads/windows.jsp</a><br />
[5] OpenJFX Eclipse Plugin v0.0.2: <a title="Altes Eclipse JavaFX Plugin" href="http://download.java.net/general/openjfx/plugins/eclipse/" target="_blank">http://download.java.net/general/openjfx/plugins/eclipse/</a><br />
[6] JavaFX API: <a title="SUN JavaFX API" href="http://java.sun.com/javafx/1/docs/api/index.html" target="_blank">http://java.sun.com/javafx/1/docs/api/index.html</a><br />
[7] JavaFX Script Language: <a title="SUN JavaFX Script Language" href="http://java.sun.com/javafx/1/tutorials/core/" target="_blank">http://java.sun.com/javafx/1/tutorials/core/</a><br />
[8] JavaFX Language Reference: <a title="Openjfx: JavaFX Language Reference" href="http://openjfx.java.sun.com/current-build/doc/reference/JavaFXReference.html" target="_blank">http://openjfx.java.sun.com/current-build/doc/reference/JavaFXReference.html</a><br />
[9] JavaFX Blog: <a title="SUN JavaFX Blog" href="http://blogs.sun.com/javafx/" target="_blank">http://blogs.sun.com/javafx/</a></p>
]]></content:encoded>
			<wfw:commentRss>http://my.center-of.info/2008/12/07/javafx-10/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Firefox Add-on Pencil</title>
		<link>http://my.center-of.info/2008/11/13/firefox-add-on-pencil/</link>
		<comments>http://my.center-of.info/2008/11/13/firefox-add-on-pencil/#comments</comments>
		<pubDate>Wed, 12 Nov 2008 22:21:07 +0000</pubDate>
		<dc:creator>Haf</dc:creator>
				<category><![CDATA[Notes]]></category>
		<category><![CDATA[design]]></category>
		<category><![CDATA[firefox]]></category>
		<category><![CDATA[gui]]></category>
		<category><![CDATA[web development]]></category>

		<guid isPermaLink="false">http://my.center-of.info/?p=44</guid>
		<description><![CDATA[Um schnell Diagramme bzw. Screendesign zu erstellen, empfehlt es sich das Firefox Add-on &#8220;Pencil&#8221; zu nutzen. Pencil bietet die gängisten HTML-Elemente (Inputfeld, Tabellenstruktur, Select-Boxen etc.) und ein paar zusätzliche Elemente (Notizen, Pfeile etc.) um somit in kurzester Zeit schöne Screendesigns zusammen zu klicken. Die einzelnen Elemente können gruppiert werden und an andere Elemten ausgerichtet werden. [...]]]></description>
			<content:encoded><![CDATA[<p>Um schnell Diagramme bzw. Screendesign zu erstellen, empfehlt es sich das Firefox Add-on &#8220;<a title="Pencil Homepage" href="http://www.evolus.vn/Pencil/Home.html">Pencil</a>&#8221; zu nutzen. Pencil bietet die gängisten HTML-Elemente (Inputfeld, Tabellenstruktur, Select-Boxen etc.) und ein paar zusätzliche Elemente (Notizen, Pfeile etc.) um somit in kurzester Zeit schöne Screendesigns zusammen zu klicken. Die einzelnen Elemente können gruppiert werden und an andere Elemten ausgerichtet werden. Jedes Element beinhaltet ein paar Einstellungsmöglichkeiten wie Farbe, Schriftart und Größe.</p>
<p><span id="more-44"></span></p>
<p>Die erstellten Designs können dann als PNG exportiert werden.</p>
<p>Die zwei Abbildungen zeigen die Arbeitsfläche und die Shapes:</p>

<a href='http://my.center-of.info/2008/11/13/firefox-add-on-pencil/pencil_shapes/' title='Pencil Shapes'><img width="150" height="150" src="http://my.center-of.info/wp-content/uploads/2008/11/pencil_shapes-150x150.gif" class="attachment-thumbnail" alt="Pencil Shapes" title="Pencil Shapes" /></a>
<a href='http://my.center-of.info/2008/11/13/firefox-add-on-pencil/pencil/' title='Pencil Workspace'><img width="150" height="150" src="http://my.center-of.info/wp-content/uploads/2008/11/pencil-150x150.gif" class="attachment-thumbnail" alt="Pencil Workspace" title="Pencil Workspace" /></a>

<p>Ein paar Verbesserungen wären:</p>
<ul>
<li> Die Festlegung der konkreten Größe der Elemente (Width und Height)</li>
<li>Bessere Tabellenunterstützung (z.B. Definition der Spaltenränder)</li>
</ul>
<p>Links:</p>
<p>[1] <a title="Pencil Homepage" href="http://www.evolus.vn/Pencil/Home.html">Pencil</a></p>
<p>[2] <a title="Firefox Add-on Pencil" href="https://addons.mozilla.org/en-US/firefox/addon/8487">Firefox Add-on Pencil</a></p>
]]></content:encoded>
			<wfw:commentRss>http://my.center-of.info/2008/11/13/firefox-add-on-pencil/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
