Sigueme en Facebook Sigueme en Twitter Sigueme en Instagram Sigueme en Youtube
JC Mouse Bolivia
Index / Java / Crear ayuda HTML para programa con JavaFX Swing

Crear ayuda HTML para programa con JavaFX Swing

Autor jc mouse Lunes, Julio 18, 2016

En este post veremos como crear una aplicación de ayuda al usuario similar al extinto javahelp. Pero en esta oportunidad usaremos los componentes web de javafx mucho mejores en comparación con java swing. Los archivos de ayuda estarán en formato HTML y se cargaran en local, pero, podemos también hacer uso de archivos que estén en la red.

Necesitamos.

  • IDE Netbeans o Eclipse
  • Java 7 o Superior
  • Conocimientos sobre java, html y CSS
  • Herramienta online: Conversor de imágenes https://www.base64-image.de/

Tiempo: 30 minutos

Nivel: Intermedio – Avanzado

Paso 1. El Proyecto

Crea un nuevo proyecto “java application” con el nombre de “HelpFX” y añade los siguientes paquetes y archivos.

java help fx

 

Definiremos la clase HelpJFrame como Main Class.

Paso 2: Interfaz de usuario

Abre el archivo HelpJFrame.java en modo diseño y crea la siguiente interfaz:

interfaz fx

Paso 3: Clase Help.java

Creamos una clase que usaremos para cargar los archivos HTML en el browser y el texto en el JTree. La clase es la siguiente:

/**
 * Clase para manejar archivos de ayuda HTML
 * @see http://www.jc-mouse.net/
 * @author mouse
 */
public class Help {
    
    /**
     * Texto que se vera en el JTREE
     */
    private String text;
    /**
     * Archivo o direccion web a cargar
     */
    private String html;
    /**
     * Local true: archivo se carga en loca
     * Local false: se carga desde internet
     */
    private boolean local=true;
    
    /**
     * Contructor de clase
     * @param text
     * @param html
     */
    public Help(String text, String html) {
        this.text = text;
        this.html = html;
    }

    /**
     * Contructor de clase
     * @param text
     * @param html
     * @param local
     */
    public Help(String text, String html,boolean local) {
        this.text = text;
        this.html = html;
        this.local = local;
    }
    
    public String getText() {
        return text;
    }

    public String getHtml() {
        return html;
    }

    public boolean isLocal() {
        return local;
    }
    
    @Override
    public String toString() {
        return text;
    }
    
}//Help

Paso 4. Archivos de ayuda HTML

Java swing puede manejar etiquetas HTML pero tiene muchas limitaciones y se a quedado atrás con respecto a los componentes web de JavaFX, es por esto que es mucho mejor  usar FX para trabajar con HTML.

Creamos nuestro archivo de ayuda HTML como cualquier otra pagina web, teniendo en cuenta un par de detalles:

  • El CSS ira dentro el archivo HTML entre las etiquetas head
  • Para usar imágenes, primero los codificaremos en base64 usando esta herramienta online https://www.base64-image.de/

El contenido para el archivo index.html es el siguiente

<!DOCTYPE html>
<html>
    <head>
        <title></title>
        <meta charset="UTF-8">        
        <style type="text/css">
        body{ 
          background-image: url();
          font-family: Arial,Verdana,Sans-serif;
          color: #999; 
          font-size: 8pt;
          text-align:center;
        }
        #header{ 
            height:100px;
            width:750px;
            margin-left:auto;
            margin-right:auto;  
            border:#CCC 1px solid;
            background-color:#FFF;
            color:#FF9900;
        }
        #main{ 
            width: 750px;
            margin-top:20px;
            margin-left:auto;
            margin-right:auto;
            border:#CCC 1px solid;
            background-color: #FFF;  
            font-size:9pt;
            color:#666;
        }
        #content { 
            width:510px;
            float:left;
            padding:20px;
            text-align:justify;
        }
        .logo{ 
            width:200px;
            float:left;
            text-align:left;
            padding:15px 0 10px 15px;
            overflow: hidden;
        }
        h1{ 
            background-color: #FFF;
            color:#FF9900;
            font-size:12pt;
            font-weight:bold;
            margin-top:0;
            margin-bottom:10px;
        }
        h2{
            background-color: #fff;
            color:#FF9900;
            font-size:10pt;
            font-weight:normal;
            margin-top:0;
            margin-bottom:0;
        }
        #nav{ 
            width:180px;
            float:left;
            margin-right:5px;
            margin-top:20px;
        }    
        #footer{ 
            height:30px;
            width:750px;
            margin-top:20px;
            margin-left:auto;
            margin-right:auto;
            padding:10px 0;  
            border:#ccc 1px solid;
            background-color: #fff;
            font-size:8pt;
            color:#999;
            text-align:center;
        }
        #footer a:link, #footer a:visited, #footer a:active{ 
            background-color: #fff; text-decoration: none; color:#999;}
        #footer A:hover{ background-color: #fff; text-decoration: none; color:#ff9900;}
        .footer { 
            clear: both; 
            background:#fff;
            color:inherit;
            height:1px;
        }
        .menu { 
            width:auto;
            text-align:right;
            font-weight:bold;
            font-size:12pt;
            padding:35px 15px 0 0;
            float: right;
            overflow: hidden;
        }
        .left{ 
            width:250px;
            float:left;
            margin:10px 15px 10px 0;
            text-align:justify;  
            overflow: hidden;
        }
        .mid { 
            width:auto;
            padding:10px 0 0 10px;
            margin-left:auto;
            margin-top:0;
            overflow: hidden;
        }
        .navhead{ 
            width:170px;
            height:18px;
            padding: 3px 3px 0 5px;
            border:#ddd 1px solid;
            text-align: left;
            font-size:8pt;
            background-color:#eee;
            color:#666;
        }
        .navitem{ 
            width:172px;
            padding: 15px 3px 0 3px;
            border-bottom:#ddd 1px solid;
            border-right:#ddd 1px solid;
            border-left:#ddd 1px solid;  
            font-size:8pt;
            font-weight: normal;
            text-align:justify;
        }
        ul { 
            list-style:circle;
            margin:0 5px;
            padding:0 0 0 20px;
        }
        li{ 
            padding:0 4px 8px 10px;            
        }
        .img{ border:0; }
        </style>
    </head>
    <body>
        <div id="header">
            <div class="logo">&nbsp;Ayuda con JavaFX - HTML<br /><img src="" /></div>            
        </div>
        <div id="main">
<div id="content">
<h1>Header Using h1</h1>
<h2>Sub Header Using h2</h2>
	Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Fusce at velit ac neque scelerisque blandit. 
	Aenean malesuada. Suspendisse vestibulum orci. Quisque posuere vehicula justo. Integer sollicitudin ligula vitae tellus. 
	Vestibulum a nibh vel quam molestie hendrerit. Proin posuere magna vitae neque. Maecenas id ante. Etiam nec ante. Morbi 
	ultrices magna et neque. In hac habitasse platea dictumst. Quisque vehicula ultricies neque. Aenean volutpat varius lectus. 
	Morbi tempor justo at ante. Ut ac pede. Donec metus libero, aliquet id, dictum at, pharetra vel, odio. Maecenas ut erat. Nullam 
	urna ante, laoreet at, ornare vel, pulvinar ut, velit. 
	<div class="left"><h2>Sub Header</h2>In ullamcorper blandit nisl. Integer tempus rutrum mi. Donec nec risus. Duis accumsan. Vivamus id risus ut
	metus interdum tempus. Curabitur orci nulla, vulputate vitae, vestibulum at, aliquam id, risus. Sed placerat blandit sem. Cras
	lacinia, magna non facilisis congue, turpis massa vestibulum nibh, at tempor elit leo quis arcu. Duis ligula nulla, hendrerit eget,
	dapibus et, placerat vitae, urna. Maecenas interdum, augue ac pellentesque laoreet, lorem dui tempor ipsum, quis porta eros
	enim et erat. Nam a arcu sit amet dui iaculis tincidunt. Pellentesque vulputate nisi. Sed ligula velit, eleifend non, dapibus vitae,
	pretium eu, metus. </div>	
	<div class="mid"><h2>Sub Header</h2>Suspendisse posuere vulputate lacus. Sed congue, est quis malesuada condimentum, ante massa faucibus 
	erat, a imperdiet ipsum nibh sed augue. Fusce quis mi. Nam faucibus, lacus non posuere porttitor, enim quam rutrum dolor, vitae 
	convallis nulla velit ut enim. Aenean vitae nibh et felis aliquam adipiscing. Suspendisse eget est. Vestibulum feugiat. Pellentesque 
	feugiat malesuada turpis. Aliquam id lacus. Ut nonummy sapien. Maecenas pede risus, ultricies eget, congue sed, ullamcorper ac, 
	massa. Morbi venenatis. Proin sapien leo, iaculis a, hendrerit vitae, tempus eget, nisl. Vestibulum 
      condimentum. Proin leo mi, sodales ac, placerat porttitor, pharetra vitae, pede. </div>
	<h1>Another Header</h1><p>Etiam dapibus, tortor vitae dapibus nonummy, ante elit mollis ligula, sit amet pretium tellus eros ac lacus. Praesent enim risus, 
	feugiat in, viverra non, egestas pharetra, quam. Cras dolor eros, congue non, aliquet et, aliquam et, metus. Donec eros augue, faucibus 
	hendrerit, pharetra sed, viverra a, tortor. Integer malesuada nisi.</p>
	<p>Cras lobortis dolor ut purus. Phasellus nunc elit, laoreet vitae, 
	accumsan quis, lobortis venenatis, elit. Nam lobortis sapien. Vivamus hendrerit.  Quisque non felis ultricies odio venenatis vestibulum. 
	Sed interdum ultricies purus.  Quisque pharetra. Curabitur ut enim in purus mollis venenatis.</p>

</div>

<div id="nav">
	<div class="navhead">NEWS &amp; UPDATES</div>
	<div class="navitem">
		<ul><li>09.15.06  News item here. Curabitur ut erat nec augue suscipit placerat.</li>
		<li>09.01.06  Etiam eu ipsum. Quisque commodo tempor nisi.</li>
		<li>08.30.06  Cras lobortis dolor ut purus. Phasellus nunc elit, laoreet vitae, accumsan quis, lobortis venenatis, elit.
		Nam lobortis sapien.</li>
		<li>08.26.06  Fusce a purus id mi condimentum nonummy. Duis sed sem ac nulla tempor tincidunt.</li>		
		<li>08.25.06  Etiam tincidunt arcu non nunc. Donec elementum massa non purus. Duis ullamcorper lorem in mauris</li></ul>
	</div>
	<p></p>
	<div class="navhead">SITE DETAILS</div>
	<div class="navitem"><ul><li>Kindly retain the "Website by MLP Design" tag and link when you use this template. Thank you.</li></ul></div>
</div>
<div class="footer"></div>
</div>

        <div id="footer">
                Copyright &copy; 2016 jc-Mousee Bolivia. All Rights Reserved.  
                <br />Website by <a href="http://www.jc-mouse.net/" title="jc mouse">jc Mouse</a>.  	  
        </div>

    </body>
</html>

Al resto de los archivos HTML, los dejaremos tal cual están.

Paso 5:  Integrando todo el código y recursos

Abre el archivo HelpJFrame en modo código, lo primero que haremos es agregar las librerías que usaremos:

import java.awt.BorderLayout;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import javafx.application.Platform;
import javafx.embed.swing.JFXPanel;
import javafx.scene.Scene;
import javafx.scene.web.WebEngine;
import javafx.scene.web.WebView;
import javax.swing.tree.DefaultMutableTreeNode;
import javax.swing.tree.DefaultTreeModel;
import javax.swing.tree.TreePath;

A continuación definimos las variables que usaremos:

    /**
     * Contenedor para componente FX
     */
    private final JFXPanel jfxPanel = new JFXPanel();
    /**
     * Componentes FX
     */
    private WebView browser;
    private WebEngine webEngine;

Definimos un método que nos cree un browser y lo agregamos a nuestro jfxpanel. También cargamos el archivo index.html, que sera el que se vea primero.

    /**
     * Crea el escenario FX con el componente browser y webEngine
     */
    private void createScene(){
        Platform.runLater(() -> {
            browser = new WebView();
            webEngine = browser.getEngine();
            webEngine.load(HelpJFrame.class.getResource("/help/html/index.html").toExternalForm());            
            jfxPanel.setScene(new Scene((browser)));//añade al panel contenedor
        } //end run
        );             
    }

Creamos también un método que nos permita interactuar entre swing y fx para poder cargar los diferentes archivos HTML que compondrán nuestra aplicación de ayuda.

    /**
     * encargado de cargar un archivo HTML en el componente FX
     * @param file archivo HTML a cargar o direccion web
     * @param local true: el archivo se carga desde un archivo HTML
     *              false: el archivo se carga desde internet 
     */
    private void loadHelp(String file, boolean local){        
        Platform.runLater(() -> {
            if(webEngine!=null){
                if(local){
                    webEngine.load(HelpJFrame.class.getResource("/help/html/"+file+".html").toExternalForm());
                }else{
                    webEngine.load(file);
                }                
            }
                
        });
    }

Para terminar, nos ubicamos en el constructor de clase y después de initComponents(), añadimos el siguiente código:

        HelpJFrame.this.setTitle("Ayuda con JAVAFX - by Mouse Bolivia");
        HelpJFrame.this.setLocationRelativeTo(null);
        /**
         * Crea escenario FX 
         */
        createScene();
         
        /**
         * Crea el arbol y sus hojas
         */
        DefaultMutableTreeNode root = new DefaultMutableTreeNode(new Help("Ayuda","index"));   
        DefaultTreeModel modelo = new DefaultTreeModel( root ); 
        DefaultMutableTreeNode help1 = new DefaultMutableTreeNode( new Help("Tema 1","tema1"));
        root.add(help1);  
        DefaultMutableTreeNode help2 = new DefaultMutableTreeNode( new Help("Tema 2","tema2"));
        root.add(help2);  
        DefaultMutableTreeNode help3 = new DefaultMutableTreeNode( new Help("Tema 3","tema3"));
        root.add(help3);  
        DefaultMutableTreeNode help4 = new DefaultMutableTreeNode( new Help("Tema Online","http://www.google.com.bo",false));
        root.add(help4);  
        
        /**
         * añade el modelo aj JTREE
         */
        jTree1.setModel(modelo);
        jTree1.setCursor(new java.awt.Cursor(java.awt.Cursor.HAND_CURSOR));
        
        /**
         * Agrega el panel FX al panel swing
         */
        jPanel1.setLayout(new BorderLayout());
        jPanel1.add(jfxPanel,BorderLayout.CENTER); 
        
        /**
         * Listener para capturar en que hoja el usuario hace clic
         */
        jTree1.addMouseListener ( new MouseAdapter (){
            
            @Override
            public void mouseReleased(MouseEvent e){                                           
                TreePath path = jTree1.getSelectionPath();
                if (path != null){
                    DefaultMutableTreeNode NodoSeleccionado = (DefaultMutableTreeNode)path.getLastPathComponent();
                    if( NodoSeleccionado.getUserObject() instanceof  Help ){
                        /**
                         * Carga el archivo HTML correspondiente
                         */
                        loadHelp( ((Help)NodoSeleccionado.getUserObject()).getHtml(),((Help)NodoSeleccionado.getUserObject()).isLocal());    
                    }
                }
            }
        });

Si no tenemos ningún error ejecutamos.

ayuda al usuario

enjoy!!! 🙂

Tags

Si te ha gustado podrías compartirlo o dejar un comentario. ¡Muchas gracias!
Autor: JC Mouse

Yo soy yo :) JC Mouse, Soy orgullosamente boliviano soy fundador y CEO de la web jc-Mouse.net uno de las pocas web en emprendimiento y tecnología en Bolivia.

Toda la información que encuentres en este sitio es y sera completamente gratis siempre, puedes copiar, descargar y re-publicar si así lo deseas en otros blogs o sitios web, solo te pido a cambio que dejes una referencia a esta web. Esto nos ayuda a crecer y seguir aportando. Bye

Enjoy! :)

También Te Podría Interesar

Introducción a Scene Builder y MVC (Parte I)

Introducción a Scene Builder y MVC (Parte I)

En este tutorial realizaremos una introducción al diseño de interfaces gráficas en JavaFX y Scene Builder, así también v...

Descargar Doodle Google Pacman

Descargar Doodle Google Pacman

Hace un par de años atras google para el aniversario del juego de Pacman saco un doodle en su homenaje, ese doodle que s...

Animación de JProgressBar con hilos

Animación de JProgressBar con hilos

Si nuestra aplicación tiene que llevar a cabo un cierto trabajo que no sabemos cuanto durará y que a la vez consume much...

Google Circles en java

Google Circles en java

En este tutorial crearemos el botón de Google+ Google Circles para una interfaz de escritorio 🙂 si no sabes lo que son e...

Compartir imagen desde android – Share Image

Compartir imagen desde android – Share Image

En este post crearemos una aplicación android que nos permitirá compartir una imagen con Facebook, whatsapp, bluetooth,...

Crea tu propia aplicacion para realizar llamadas

Crea tu propia aplicacion para realizar llamadas

En este tutorial Android Bolivia 🙂 construiremos una sencilla aplicación para realizar llamadas por teléfono, aprenderem...

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

*

Comparte lo que sabes

Categorias

Últimas entradas

Desde java 7 esta disponible la interface ExecutorService que se extiende de Executor y nos proporciona los métodos nece...

En este post crearemos una app para utilizar el vibrador de nuestro dispositivo android usando para ello el IDE Android...

En un post anterior vimos como utilizar GSON para serializar un objeto java en JSON, en esta oportunidad se vera el proc...

Gson es una biblioteca de código abierto para Java desarrollado por Google Inc que permite la serialización y deserializ...

Android Bolivia

Bandera en Alto