Reportes con JasperReports e iReport: pasar parámetros con Datasources sin conexión a una BBDD - Netbeans 8



   En este post vamos a ver como se pasan parámetros desde java al reporte sin necesidad de una conexión a una BBDD, es decir, podemos pasar los parámetros que queramos.

   Vamos a comenzar creando un proyecto nuevo (File/New Project) y una clase en java que utilizaremos para instanciar objetos ( botón derecho en el paquete y New/java Class) y así pasar los datos al datasource. Para usar de ejemplo, hemos creado la clase Asistentes.

public class Asistentes {
    
    private Integer id;
    private String nombre;
    private String apellidos;
    private String dni;

    public Asistentes(){        
    }    
   
    public Asistentes(int id, String nombre, String apellidos, String dni) {
        this.id = id;
        this.nombre = nombre;
        this.apellidos = apellidos;
        this.dni = dni;
    }

    public int getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }
  
    public String getApellidos() {
        return apellidos;
    }
  
    public void setApellidos(String apellidos) {
        this.apellidos = apellidos;
    }
   
    public String getDni() {
        return dni;
    }

    public void setDni(String dni) {
        this.dni = dni;
    }

    public String getNombre() {
        return nombre;
    }

    public void setNombre(String nombre) {
        this.nombre = nombre;
    }
    
}

   Esta clase tiene cuatro atributos, constructor por defecto y constructor parametrizado. También debemos incluir los getters and setters ya que los atributos son privados y necesitaremos asignar esos valores.

   A continuación vamos a crear el reporte. Para ello botón derecho en el paquete y nuevo Empty report.


   Para editar el reporte vamos a utilizar el programa de iReport, que previamente lo tenemos que tener instalado ( a parte del plugin de iReport para netbeans). Os lo podéis descargar del siguiente enlace:



   En nuestro reporte vamos a asignar etiquetas para las columnas y para el nombre del reporte. Esto se hace con Static Text (Paleta que está a la derecha).


   Para asignar los valores que van a ir rellenando las diferentes columnas tenemos que crear unas variables y unos campos. Estos campos se crean pinchando botón derecho en Fields/Agregar Field. Hay que asignarles el tipo de dato (java.lang.String, java.lang.Integer o el que sea), y debe de coincidir con el tipo de dato que le pasemos en el programa principal, en este caso con el tipo de datos de las variables de nuestra clase Asistentes.



   Una vez creados todos, pinchamos y los arrastramos al reporte. Así quedaría el nuestro:



   Muy bien, ahora hay que crear la clase para pasar estos datos. Esta clase tiene que implementar la clase JRDataSource, y tiene dos métodos que son obligatorios sobreescribir, el método next() y getFieldValue(JRField jrf). En el método next incrementará el contador y JasperReport sabrá cuantos Asistentes van a existir. El método getFieldValue asignará los valores a los Fields correspondientes.

   A parte en esta clase vamos a crear una variable que será una lista de Asistentes y también un método para ir agregando cada asistente a la lista. La clase quedaría así:

public class AsistentesDataSource implements JRDataSource{

    private List<Asistentes> listaAsistentes = new ArrayList<Asistentes>();
    private int indiceParticipanteActual = -1;
 
    @Override
    public boolean next() throws JRException {
       return ++indiceParticipanteActual < listaAsistentes.size();
    }
 
    public void addAsistente(Asistentes Asistente){

        this.listaAsistentes.add(Asistente);

    }

    @Override
    public Object getFieldValue(JRField jrf) throws JRException {
       Object valor = null;

        if ("id".equals(jrf.getName())){

            valor = listaAsistentes.get(indiceParticipanteActual).getId();

        }
        else if ("nombre".equals(jrf.getName())){

            valor = listaAsistentes.get(indiceParticipanteActual).getNombre();

        }
        else if ("apellidos".equals(jrf.getName())){

            valor = listaAsistentes.get(indiceParticipanteActual).getApellidos();

        }
        else if ("dni".equals(jrf.getName())){
            valor = listaAsistentes.get(indiceParticipanteActual).getDni();
        }

        return valor;
    }
 
}

   En el main() tenemos que inicializar jasperreport y la clase Asistentes. También crear los objetos y pasarlos al datasource además de crear el reporte. El método main() quedaría de la siguiente forma:

public static void main(String[] args) {
        // TODO code application logic here
       
        InputStream inputStream = null;
        JasperPrint jasperPrint= null;
        AsistentesDataSource datasource = new AsistentesDataSource();
       
       
        for(int i = 0; i<=5; i++){
           
            Asistentes asist;
            asist = new Asistentes(i, "AsistenteNombre de "+i,"AsistenteApellidos de "+i, "Asistente dni de "+i);
            datasource.addAsistente(asist);
           
        }
       
       try {
            inputStream = new FileInputStream ("src/reportes/reporte01.jrxml");
        } catch (FileNotFoundException ex) {
           JOptionPane.showMessageDialog(null,"Error al leer el fichero de carga jasper report "+ex.getMessage());
        }
       
        try{
            JasperDesign jasperDesign = JRXmlLoader.load(inputStream);
            JasperReport jasperReport = JasperCompileManager.compileReport(jasperDesign);
            jasperPrint = JasperFillManager.fillReport(jasperReport, null, datasource);

            JasperExportManager.exportReportToPdfFile(jasperPrint, "src/reportes/reporte01.pdf");
           
         
        }catch (JRException e){
            JOptionPane.showMessageDialog(null,"Error al cargar fichero jrml jasper report "+e.getMessage());
        }
       

    }

      Ejecutamos el proyecto ya tenemos nuestro reporte:


   Hay problemas con la versión de iReport y Windows. Al ejecutar el proyecto  nos puede aparecer dos tipos de errores.

  • Error uuid: no está permitido que el atributo uuid aparezca en el elemento jasperreport
  • Error cast: can not cast from Integer to String.



   Para el error del uuid simplemente en la vista del xml del reporte hay que borrar todos los campos donde venga el uuid. Para el error del cast, hay que añadir en los <textFieldExpressions> la clase correspondiente (String, Integer,Float,...)


   Podéis descargaros el proyecto en GitHub -> Reportes GitHub

Oculus Rift DK2: no enciende LED Positional Tracking

   

   Mucha gente que se ha comprado las oculus rift tiene problemas con el positional tracking, es decir, no se les enciende el led por lo que no parece que no funciona o no lo detecta el ordenador. No tiene por que ser así, lo que ocurre es que ha habido algún tipo de problema en el registro y no la detecta.

   A mi me ha pasado. Al principio si se me encendía pero ha llegado un momento en el que dejó de hacerlo y no sé por qué. Buscando en internet encontré con una solución en el foro de las oculus rift (inglés) para windows, así que en esta entrada os lo voy a explicar en español.

   Podéis probar las Oculus en otro equipo por si queréis comprobar que el positional tracking funciona

      PASOS A SEGUIR      

1 - Desenchufar las oculus del equipo, desinstalar el runtime, los drivers y reiniciar el equipo.


2 - Reinstalar el runtime sin enchufar las oculus al equipo. Es importante que no las enchuféis todavía.

3 - Reiniciar el equipo de nuevo.

4 - Ir al siguiente directorio: C:\Windows\System32\DriverStore\FileRepository\riftenabler.inf_amd64_neutral_91395412451e34f6

5 - Click derecho en Riftenabler.inf y elegir instalar.


6 - Ir al registro y localizar: @ HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Class\{4D36E968-E325-11CE-BFC1-08002BE10318}
Ponemos en el inicio "regedit" y se nos abre el registro.


7 - Tiene que poner UpperFilters ... RiftEnabler y no tiene que venir ninguna clave con "LowerFilters". Si acaso pone algo con LowerFilters, hay que borrarlo.

8 - Reiniciar de nuevo.

9 - Conectar las Oculus Rift al equipo, pero sin conectar la cámara-tracking, es decir, el cable del tracking tiene que estar desconectado tanto de las Oculus como del equipo, únicamente hay que conectar las Oculus Rift al PC.

10 - Abrir Rift Display Mode de las Oculus Rift y elegir el modo de escritorio extendido. El ordenador debería de reconocerlas como otro monitor.


11 - En administrador de dispositivos (Propiedades-Equipo) expandimos Monitores y nos tiene que aparecer como Monitor PnP genérico. Le damos con el botón derecho/propiedades/Drivers y nos debería de aparecer el autor Microsoft. Si hay otro autor (por ejemplo logmein o teamviewer) hay que darle a Actualizar drivers/Buscar en el computador y elegir vosotros el de PnP genérico.


12 - En Configuration Utility de las Oculus os tiene que reconocer el número de serie de éstas. Si os pone HMD no conectado pueden pasar varias cosas. O bien no habéis hecho los pasos correctamente o hay que conectar las Oculus en otro puerto usb. Si no os las reconoce ahora no sigáis con las instrucciones.


13 - Una vez que las Oculus Rift están conectadas correctamente, tenemos que conectar la cámara-tracking en el equipo. Sólo en el ordenador, NO conectéis el cable sync en las Oculus.

14 - Volver al administrador de dispositivos, localizar la cámara en los dispositivos de imagen y pinchar con el botón derecho y elegir propiedades/administrador de energía. Hay que desmarcar la casilla que pone: permitir que el equipo apague este dispositivo para ahorrar energía.


15 - Si no os lo muestra como conectado (no confundir con que se encienda la luz), hay que reiniciar el servicio.


16 - Si sigue sin mostrarla como conectada, hay que probar en otro puerto usb o no se han seguido los pasos bien. Si no hay manera de que os la muestre como conectada, no podéis seguir los pasos que quedan.

17 - Lanzar la demo de las oculus dentro de Configuration Utility.

18 - Mientras estamos en la demo, enchufar el cable sync de la cámara-tracking en las Oculus. Positional tracking debería funcionar. Si no es así, hay que salir de la demo y volver a entrar. Si aún no se enciende, reiniciar los servicios y a probar otra vez.



Este es el enlace original del foro de las Oculus Rift:  Blue LED