Java tutorial
/* * To change this license header, choose License Headers in Project Properties. * To change this template file, choose Tools | Templates * and open the template in the editor. */ /************************************In the select statement, include condition periodo = periodo of professor******************************************/ package PDF; /** * * @author PsysacElrick */ import java.io.FileOutputStream; import com.itextpdf.text.Anchor; import com.itextpdf.text.BadElementException; import com.itextpdf.text.BaseColor; import com.itextpdf.text.Document; import com.itextpdf.text.DocumentException; import com.itextpdf.text.Element; import com.itextpdf.text.Font; import com.itextpdf.text.Paragraph; import com.itextpdf.text.Phrase; import com.itextpdf.text.pdf.PdfPCell; import com.itextpdf.text.pdf.PdfPTable; import com.itextpdf.text.pdf.PdfWriter; import com.itextpdf.text.Image; import java.io.IOException; import java.sql.ResultSet; public class GenerateReportActivities { private static String FILE; private static Font catFont = new Font(Font.FontFamily.TIMES_ROMAN, 17, Font.BOLD); private static Font redFont = new Font(Font.FontFamily.TIMES_ROMAN, 12, Font.NORMAL, BaseColor.RED); private static Font subFont = new Font(Font.FontFamily.TIMES_ROMAN, 16, Font.BOLD); private static Font smallBold = new Font(Font.FontFamily.TIMES_ROMAN, 13, Font.BOLD); private static Font encabezadost = new Font(Font.FontFamily.TIMES_ROMAN, 12, Font.NORMAL, BaseColor.WHITE); private String username;//employee number LoginBean lb = new LoginBean(); //lb.getConnection(); //private String destPath;//Path where the file will be saved //private static String FILE; public String execute() throws Exception { //FILE = "C:\\psf\\Home\\Documents\\Reporte_de_actividades_E-SIBE.pdf";/*Test route*/ //FILE = "C:\\psf\\Home\\Documents\\" + getUsername() + "\\Reporte_de_Actividades_E-SIBE_" + getUsername() + ".pdf";//Path where the file will be saved FILE = ".\\bin\\apache-tomcat-8.0.43\\webapps\\Usuarios\\" + getUsername() + "\\Reporte_de_Actividades_E-SIBE_" + getUsername() + ".pdf";//Path of server //FILE = "" lb.getConnection(); /*int i = 0; ResultSet ra; ra = lb.executeQuery("SELECT p.ruta_alm, pr.ruta_alm, t.ruta_alm, ob.ruta_alm, \n" + "ev.ruta_alm, pra.ruta_alumno, pu.ruta_alm\n" + "FROM\n" + "profesor_participa_en_plan p, profesor_tiene_proyecto pr, \n" + "profesor_tiene_tt t, profesor_tiene_obra ob, profesor_participa_ev ev, \n" + "profesor_tiene_proyecto pra, profesor_tiene_pub pu\n" + "WHERE \n" + "pu.id_usuario = " + getUsername() + " and \n" + "p.id_usuario = " + getUsername() + " and \n" + "pr.id_usuario = " + getUsername() + " and \n" + "t.id_usuario = " + getUsername() + " and \n" + "ob.id_usuario = " + getUsername() + " and \n" + "ev.id_usuario = " + getUsername() + " and \n" + "pra.id_usuario = " + getUsername()); while(ra.next()){ i++; } //lb.closeConnection(); if(i == 0){ lb.closeConnection(); System.out.println("Aquiiiiiii"); return "no_registro"; }*/ //System.out.println(i); try { Document document = new Document(); PdfWriter.getInstance(document, new FileOutputStream(FILE)); document.open(); addMetaData(document); //addImagenes(document); addEncabezado(document); addResumenProf(document); addPunto1(document); addPunto2(document); addPunto3(document); addPunto4(document); addPunto5(document); addPunto11(document); addPunto12(document); document.close(); } catch (Exception e) { e.printStackTrace(); lb.closeConnection(); return "error"; } lb.closeConnection(); digital_sign a = new digital_sign();//here we call the fuction to sign the file String execute = a.digital_sign(getUsername()); System.out.println(execute); return "success"; } private static void addMetaData(Document document) { document.addTitle("Reporte de Actividades General"); document.addSubject("Beca SIBE"); document.addKeywords("COFAA, SIBE, E-SIBE, Reporte de Actividades del Rubro 2"); document.addAuthor("Comisin de Operacin y Fomento de Actividades Acadmicas del IPN"); document.addCreator("E-SIBE"); } /*private static void addImagenes(Document document) throws BadElementException, IOException, DocumentException { //Image cofaa= Image.getInstance("C:\\psf\\Home\\Documents\\11111\\AlumnosBEIFI\\ipn.png"); //Image IPN= Image.getInstance("C:\\psf\\Home\\Documents\\11111\\AlumnosBEIFI\\cofaa.png"); Image cofaa= Image.getInstance(".\\bin\\apache-tomcat-8.0.43\\webapps\\Usuarios\\ipn.png");//images for the server Image IPN= Image.getInstance(".\\bin\\apache-tomcat-8.0.43\\webapps\\Usuarios\\cofaa.png"); cofaa.scalePercent(65); IPN.scalePercent(55); cofaa.setAbsolutePosition(480, 750); IPN.setAbsolutePosition(35,740); document.add(cofaa); document.add(IPN); }*/ private void addEncabezado(Document document) throws DocumentException { Paragraph preface = new Paragraph(); addEmptyLine(preface, 4); preface.setAlignment(Element.ALIGN_CENTER); preface.add(new Paragraph("Instituto Politcnico Nacional", catFont)); preface.add(new Paragraph("Comisin de Operacin y Fomento de Actividades" + " Acadmicas (COFAA)\n Direccin de Especializacin Docente e Investigacin Cientfica y " + "Tecnolgica\nE-SIBE", smallBold)); addEmptyLine(preface, 2); document.add(preface); } private void addResumenProf(Document document) throws DocumentException, Exception { Paragraph preface = new Paragraph(); preface.add(new Paragraph("Datos Generales del Profesor", smallBold)); preface.setAlignment(Element.ALIGN_CENTER); addEmptyLine(preface, 2); document.add(preface); document.add(TablaDatos()); } private void addPunto1(Document document) throws Exception { Paragraph preface = new Paragraph(); addEmptyLine(preface, 3); document.add(preface); document.add(dospuntouno()); } private void addPunto2(Document document) throws Exception { Paragraph preface = new Paragraph(); addEmptyLine(preface, 3); document.add(preface); document.add(dospuntodos()); } private void addPunto3(Document document) throws Exception { Paragraph preface = new Paragraph(); addEmptyLine(preface, 3); document.add(preface); document.add(dospuntotres()); } private void addPunto4(Document document) throws Exception { Paragraph preface = new Paragraph(); addEmptyLine(preface, 3); document.add(preface); document.add(dospuntocuatro()); } private void addPunto5(Document document) throws Exception { Paragraph preface = new Paragraph(); addEmptyLine(preface, 3); document.add(preface); document.add(dospuntocinco()); } private void addPunto11(Document document) throws Exception { Paragraph preface = new Paragraph(); addEmptyLine(preface, 3); document.add(preface); document.add(dospuntoonce()); } private void addPunto12(Document document) throws Exception { Paragraph preface = new Paragraph(); addEmptyLine(preface, 3); document.add(preface); document.add(dospuntodoce()); } private PdfPTable TablaDatos() throws Exception { PdfPTable Datos_prof = new PdfPTable(5); Datos_prof.setWidths(new int[] { 2, 3, 2, 2, 2 }); PdfPCell Titulo_tabla = new PdfPCell(new Phrase("Datos generales del Profesor", encabezadost)); PdfPCell Nombre = new PdfPCell(new Phrase("Nombre del Profesor")); PdfPCell Matricula = new PdfPCell(new Phrase("No. de Empleado")); PdfPCell UA = new PdfPCell(new Phrase("Unidad Acadmica")); PdfPCell Puntos = new PdfPCell(new Phrase("Puntos obtenidos")); PdfPCell Nivel = new PdfPCell(new Phrase("Nivel de Beca")); Titulo_tabla.setHorizontalAlignment(Element.ALIGN_CENTER); Titulo_tabla.setVerticalAlignment(Element.ALIGN_MIDDLE); Titulo_tabla.setBackgroundColor(new BaseColor(153, 0, 76)); Titulo_tabla.setColspan(5); Titulo_tabla.setExtraParagraphSpace(15f); Datos_prof.addCell(Titulo_tabla); Nombre.setHorizontalAlignment(Element.ALIGN_CENTER); Datos_prof.addCell(Nombre); Matricula.setHorizontalAlignment(Element.ALIGN_CENTER); Datos_prof.addCell(Matricula); UA.setHorizontalAlignment(Element.ALIGN_CENTER); Datos_prof.addCell(UA); Puntos.setHorizontalAlignment(Element.ALIGN_CENTER); Datos_prof.addCell(Puntos); Nivel.setHorizontalAlignment(Element.ALIGN_CENTER); Datos_prof.addCell(Nivel); /*Aqui van las consultas de los datos del profesor*/ ResultSet rn, rt; String nom_usuario = null, id_usuario = null, u_a = null, puntaje_final = null, nivel = null; //Datos_prof.addCell("Hola"); ResultSet rp = lb.executeQuery("SELECT * FROM usuario WHERE id_usuario = " + username); while (rp.next()) { nom_usuario = rp.getString("nom_usuario"); id_usuario = rp.getString("id_usuario"); u_a = rp.getString("u_a"); } System.out.println(getUsername()); rn = lb.executeQuery( "SELECT * FROM evaluador_evalua_profesor WHERE id_usuario_prof = '" + getUsername() + "'"); while (rn.next()) { puntaje_final = rn.getString("puntaje_final"); //Datos_prof.addCell(rn.getString("puntaje_final")); } rt = lb.executeQuery("SELECT * FROM profesor WHERE id_usuario = '" + getUsername() + "'"); while (rt.next()) { nivel = rt.getString("nivel"); } Datos_prof.addCell(nom_usuario); Datos_prof.addCell(id_usuario); Datos_prof.addCell(u_a); Datos_prof.addCell(puntaje_final); Datos_prof.addCell(nivel); return Datos_prof; } private PdfPTable dospuntouno() throws Exception { PdfPTable Dos_uno = new PdfPTable(6); Dos_uno.setWidths(new int[] { 2, 2, 3, 2, 2, 2 }); PdfPCell Titulo_tabla = new PdfPCell(new Phrase( "Actividad 2.1" + " - Formacin de Recursos Humanos para la Investigacin", encabezadost)); PdfPCell Nom_Proyecto = new PdfPCell(new Phrase("Nmero de proyecto SIP")); PdfPCell Num_Actividad = new PdfPCell(new Phrase("Nmero de Actividad")); PdfPCell Tipo_Actividad = new PdfPCell(new Phrase("Tipo de Actividad")); PdfPCell Ruta_alm = new PdfPCell(new Phrase("Evidencia")); PdfPCell Puntos = new PdfPCell(new Phrase("Puntos obtenidos")); PdfPCell Observaciones = new PdfPCell(new Phrase("Observaciones")); //PdfPCell celda=new PdfPCell(); Titulo_tabla.setHorizontalAlignment(Element.ALIGN_CENTER); Titulo_tabla.setVerticalAlignment(Element.ALIGN_MIDDLE); Titulo_tabla.setBackgroundColor(new BaseColor(153, 0, 76)); Titulo_tabla.setColspan(6); Titulo_tabla.setExtraParagraphSpace(15f); Dos_uno.addCell(Titulo_tabla); Nom_Proyecto.setHorizontalAlignment(Element.ALIGN_CENTER); Nom_Proyecto.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_uno.addCell(Nom_Proyecto); Num_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Num_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_uno.addCell(Num_Actividad); Tipo_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Tipo_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_uno.addCell(Tipo_Actividad); Ruta_alm.setHorizontalAlignment(Element.ALIGN_CENTER); Ruta_alm.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_uno.addCell(Ruta_alm); Puntos.setHorizontalAlignment(Element.ALIGN_CENTER); Puntos.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_uno.addCell(Puntos); Observaciones.setHorizontalAlignment(Element.ALIGN_CENTER); Observaciones.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_uno.addCell(Observaciones); /*Aqui van las consultas de las Actividades del profesor*/ /**Get actual period***/ int periodo = 0; ResultSet rperiodo = lb.executeQuery("SELECT * FROM profesor WHERE id_usuario = " + getUsername()); if (rperiodo.next()) periodo = rperiodo.getInt("periodo"); /**Get actual period***/ String id_al = null, tipo_alumno = null, puntaje = null, comen = null, nom_proyecto = null; ResultSet rb = lb .executeQuery("SELECT * FROM profesor_tiene_proyecto WHERE " + "id_usuario = " + getUsername() + " AND (validado_alumno = 1 OR validado_alumno = 0) AND " + "periodo = " + periodo); while (rb.next()) { nom_proyecto = rb.getString("id_proyecto"); Dos_uno.addCell(nom_proyecto); id_al = rb.getString("id_alumno"); Dos_uno.addCell(id_al); tipo_alumno = rb.getString("tipo_alumno"); Dos_uno.addCell(tipo_alumno); Anchor anchor = new Anchor("Constancia"); //anchor.setReference("file:///"+rb.getString("ruta_alm")); anchor.setReference(rb.getString("ruta_alumno")); Dos_uno.addCell(anchor); puntaje = rb.getString("puntaje_alumno"); Dos_uno.addCell(puntaje); comen = rb.getString("comentarios"); Dos_uno.addCell(comen); } return Dos_uno; } private PdfPTable dospuntodos() throws Exception { PdfPTable Dos_dos = new PdfPTable(5); Dos_dos.setWidths(new int[] { 2, 2, 3, 2, 3 }); PdfPCell Titulo_tabla = new PdfPCell( new Phrase("Actividad 2.2" + " - Publicaciones Cientficas y/o de Divulgacin", encabezadost)); PdfPCell Num_Actividad = new PdfPCell(new Phrase("Nmero de Actividad")); PdfPCell Tipo_Actividad = new PdfPCell(new Phrase("Tipo de Actividad* (Consultar parte de abajo)")); PdfPCell Ruta_alm = new PdfPCell(new Phrase("Evidencia")); PdfPCell Puntos = new PdfPCell(new Phrase("Puntos obtenidos")); PdfPCell Observaciones = new PdfPCell(new Phrase("Observaciones")); PdfPCell celda = new PdfPCell(); Titulo_tabla.setHorizontalAlignment(Element.ALIGN_CENTER); Titulo_tabla.setVerticalAlignment(Element.ALIGN_MIDDLE); Titulo_tabla.setBackgroundColor(new BaseColor(153, 0, 76)); Titulo_tabla.setColspan(5); Titulo_tabla.setExtraParagraphSpace(15f); Dos_dos.addCell(Titulo_tabla); Num_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Num_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_dos.addCell(Num_Actividad); Tipo_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Tipo_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_dos.addCell(Tipo_Actividad); Ruta_alm.setHorizontalAlignment(Element.ALIGN_CENTER); Ruta_alm.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_dos.addCell(Ruta_alm); Puntos.setHorizontalAlignment(Element.ALIGN_CENTER); Puntos.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_dos.addCell(Puntos); Observaciones.setHorizontalAlignment(Element.ALIGN_CENTER); Observaciones.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_dos.addCell(Observaciones); /*Aqui van las consultas de las Actividades del profesor*/ int periodo = 0; ResultSet rperiodo = lb.executeQuery("SELECT * FROM profesor WHERE id_usuario = " + getUsername()); if (rperiodo.next()) periodo = rperiodo.getInt("periodo"); /**Get actual period***/ String id_pub = null, id_tipo = null, puntaje = null, coment = null; ResultSet rb = lb.executeQuery("SELECT * FROM profesor_tiene_pub WHERE " + "id_usuario = '" + getUsername() + "' AND (validado = 1 OR validado = 0) AND (id_tipo_pub = 1 " + "OR id_tipo_pub = 2 OR id_tipo_pub = 3 OR id_tipo_pub = 4 OR id_tipo_pub = 5) AND " + "periodo = " + periodo); while (rb.next()) { id_pub = rb.getString("id_publicacion"); Dos_dos.addCell(id_pub); id_tipo = rb.getString("id_tipo_pub"); Dos_dos.addCell(id_tipo);//Add the type of every type pub Anchor anchor = new Anchor("Constancia"); anchor.setReference(rb.getString("ruta_alm")); //anchor.setReference("file:///"+rb.getString("ruta_alm")); Dos_dos.addCell(anchor); puntaje = rb.getString("puntaje"); Dos_dos.addCell(puntaje); coment = rb.getString("comentarios"); Dos_dos.addCell(coment); } return Dos_dos; } private PdfPTable dospuntotres() throws Exception { PdfPTable Dos_tres = new PdfPTable(5); Dos_tres.setWidths(new int[] { 2, 2, 3, 2, 3 }); PdfPCell Titulo_tabla = new PdfPCell(new Phrase("Actividad 2.3" + " - Eventos Acadmicos", encabezadost)); PdfPCell Num_Actividad = new PdfPCell(new Phrase("Nmero de Actividad")); PdfPCell Ruta_alm = new PdfPCell(new Phrase("Evidencia")); PdfPCell Puntos = new PdfPCell(new Phrase("Puntos obtenidos")); PdfPCell Observaciones = new PdfPCell(new Phrase("Observaciones")); PdfPCell Tipo_Actividad = new PdfPCell(new Phrase("Nombre del evento")); PdfPCell celda = new PdfPCell(); Titulo_tabla.setHorizontalAlignment(Element.ALIGN_CENTER); Titulo_tabla.setVerticalAlignment(Element.ALIGN_MIDDLE); Titulo_tabla.setBackgroundColor(new BaseColor(153, 0, 76)); Titulo_tabla.setColspan(5); Titulo_tabla.setExtraParagraphSpace(15f); Dos_tres.addCell(Titulo_tabla); Num_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Num_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_tres.addCell(Num_Actividad); Tipo_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Tipo_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_tres.addCell(Tipo_Actividad); Ruta_alm.setHorizontalAlignment(Element.ALIGN_CENTER); Ruta_alm.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_tres.addCell(Ruta_alm); Puntos.setHorizontalAlignment(Element.ALIGN_CENTER); Puntos.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_tres.addCell(Puntos); Observaciones.setHorizontalAlignment(Element.ALIGN_CENTER); Observaciones.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_tres.addCell(Observaciones); /*Aqui van las consultas de las Actividades del profesor*/ /**Get actual period***/ int periodo = 0; String id_evento = null, even = null, puntaje = null, comentarios = null; ResultSet rperiodo = lb.executeQuery("SELECT * FROM profesor WHERE id_usuario = " + getUsername()); if (rperiodo.next()) periodo = rperiodo.getInt("periodo"); /**Get actual period***/ ResultSet rb = lb.executeQuery("SELECT * FROM profesor_tiene_pub WHERE " + "id_usuario = '" + getUsername() + "' AND (validado = 1 OR validado = 0) AND periodo = " + periodo + " AND " + "(id_tipo_pub = 6 OR id_tipo_pub = 7 OR id_tipo_pub = 8)"); while (rb.next()) { id_evento = rb.getString("id_evento"); Dos_tres.addCell(id_evento); Dos_tres.addCell("Evento acadmico"); Anchor anchor = new Anchor("Constancia"); anchor.setReference(rb.getString("ruta_alm")); //anchor.setReference("file:///"+rb.getString("ruta_alm")); Dos_tres.addCell(anchor); puntaje = rb.getString("puntaje"); Dos_tres.addCell(puntaje); comentarios = rb.getString("comentarios"); Dos_tres.addCell(comentarios); } return Dos_tres; } private PdfPTable dospuntocuatro() throws Exception { PdfPTable Dos_cuatro = new PdfPTable(5); Dos_cuatro.setWidths(new int[] { 2, 2, 3, 2, 3 }); PdfPCell Titulo_tabla = new PdfPCell( new Phrase("Actividad 2.4" + " - Investigacin y/o Desarrollo Satisfactorio", encabezadost)); PdfPCell Num_Actividad = new PdfPCell(new Phrase("Nmero de Actividad")); PdfPCell Tipo_Actividad = new PdfPCell(new Phrase("ID del proyecto SIP")); PdfPCell Ruta_alm = new PdfPCell(new Phrase("Evidencia")); PdfPCell Puntos = new PdfPCell(new Phrase("Puntos obtenidos")); PdfPCell Observaciones = new PdfPCell(new Phrase("Observaciones")); PdfPCell celda = new PdfPCell(); Titulo_tabla.setHorizontalAlignment(Element.ALIGN_CENTER); Titulo_tabla.setVerticalAlignment(Element.ALIGN_MIDDLE); Titulo_tabla.setBackgroundColor(new BaseColor(153, 0, 76)); Titulo_tabla.setColspan(5); Titulo_tabla.setExtraParagraphSpace(15f); Dos_cuatro.addCell(Titulo_tabla); Num_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Num_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_cuatro.addCell(Num_Actividad); Tipo_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Tipo_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_cuatro.addCell(Tipo_Actividad); Ruta_alm.setHorizontalAlignment(Element.ALIGN_CENTER); Ruta_alm.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_cuatro.addCell(Ruta_alm); Puntos.setHorizontalAlignment(Element.ALIGN_CENTER); Puntos.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_cuatro.addCell(Puntos); Observaciones.setHorizontalAlignment(Element.ALIGN_CENTER); Observaciones.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_cuatro.addCell(Observaciones); /*Aqui van las consultas de las Actividades del profesor*/ int periodo = 0; ResultSet rperiodo = lb.executeQuery("SELECT * FROM profesor WHERE id_usuario = " + getUsername()); if (rperiodo.next()) periodo = rperiodo.getInt("periodo"); /**Get actual period***/ String id_pr = null, puntaje = null, comenta = null; ResultSet rb = lb.executeQuery("SELECT count(*), id_proyecto, ruta_alm, puntaje, comentarios " + "FROM profesor_tiene_proyecto " + "WHERE id_usuario = " + getUsername() + " AND " + "(validado = 1 OR validado = 0) AND periodo = " + periodo + " GROUP BY id_proyecto " + "HAVING COUNT(*) > 0"); /* SELECT count(*), id_proyecto, ruta_alm, puntaje, comentarios FROM profesor_tiene_proyecto WHERE id_usuario = 11014 AND aceptado = 1 AND validado = 1 GROUP BY id_proyecto HAVING COUNT(*) > 1; */ while (rb.next()) { Dos_cuatro.addCell("2.4.2"); id_pr = rb.getString("id_proyecto"); Dos_cuatro.addCell(id_pr); Anchor anchor = new Anchor("Constancia"); //anchor.setReference("file:///"+rb.getString("ruta_alm")); anchor.setReference(rb.getString("ruta_alm")); Dos_cuatro.addCell(anchor); puntaje = rb.getString("puntaje"); Dos_cuatro.addCell(puntaje); comenta = rb.getString("comentarios"); Dos_cuatro.addCell(comenta); } return Dos_cuatro; } private PdfPTable dospuntocinco() throws Exception { PdfPTable Dos_cinco = new PdfPTable(5); Dos_cinco.setWidths(new int[] { 2, 2, 3, 2, 3 }); PdfPCell Titulo_tabla = new PdfPCell(new Phrase("Actividad 2.5.2" + " - Derechos de Autor", encabezadost)); PdfPCell Num_Actividad = new PdfPCell(new Phrase("Nmero de Actividad")); PdfPCell Tipo_Actividad = new PdfPCell(new Phrase("Identificador de obra")); PdfPCell Ruta_alm = new PdfPCell(new Phrase("Evidencia")); PdfPCell Puntos = new PdfPCell(new Phrase("Puntos obtenidos")); PdfPCell Observaciones = new PdfPCell(new Phrase("Observaciones")); PdfPCell celda = new PdfPCell(); Titulo_tabla.setHorizontalAlignment(Element.ALIGN_CENTER); Titulo_tabla.setVerticalAlignment(Element.ALIGN_MIDDLE); Titulo_tabla.setBackgroundColor(new BaseColor(153, 0, 76)); Titulo_tabla.setColspan(5); Titulo_tabla.setExtraParagraphSpace(15f); Dos_cinco.addCell(Titulo_tabla); Num_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Num_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_cinco.addCell(Num_Actividad); Tipo_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Tipo_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_cinco.addCell(Tipo_Actividad); Ruta_alm.setHorizontalAlignment(Element.ALIGN_CENTER); Ruta_alm.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_cinco.addCell(Ruta_alm); Puntos.setHorizontalAlignment(Element.ALIGN_CENTER); Puntos.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_cinco.addCell(Puntos); Observaciones.setHorizontalAlignment(Element.ALIGN_CENTER); Observaciones.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_cinco.addCell(Observaciones); /*Aqui van las consultas de las Actividades del profesor*/ int periodo = 0; ResultSet rperiodo = lb.executeQuery("SELECT * FROM profesor WHERE id_usuario = " + getUsername()); if (rperiodo.next()) periodo = rperiodo.getInt("periodo"); /**Get actual period***/ String id_obra = null, puntaje = null, comenta = null; ResultSet rb = lb.executeQuery("SELECT * FROM profesor_tiene_obra WHERE " + "id_usuario = '" + getUsername() + "' AND (validado = 1 OR validado=0 ) AND periodo = " + periodo); while (rb.next()) { Dos_cinco.addCell("2.5"); id_obra = rb.getString("id_obra"); Dos_cinco.addCell(id_obra); Anchor anchor = new Anchor("Constancia"); //anchor.setReference("file:///"+rb.getString("ruta_alm")); anchor.setReference(rb.getString("ruta_alm")); Dos_cinco.addCell(anchor); puntaje = rb.getString("puntaje"); Dos_cinco.addCell(puntaje); comenta = rb.getString("comentarios"); Dos_cinco.addCell(comenta); } return Dos_cinco; } private PdfPTable dospuntoonce() throws Exception { PdfPTable Dos_once = new PdfPTable(5); Dos_once.setWidths(new int[] { 2, 2, 3, 2, 3 }); PdfPCell Titulo_tabla = new PdfPCell( new Phrase("Actividad 2.11" + " - Direcciones y Codirecciones", encabezadost)); PdfPCell Num_Actividad = new PdfPCell(new Phrase("Nmero de Actividad")); PdfPCell Tipo_Actividad = new PdfPCell(new Phrase("Identificador de TT o tesis")); PdfPCell Ruta_alm = new PdfPCell(new Phrase("Evidencia")); PdfPCell Puntos = new PdfPCell(new Phrase("Puntos obtenidos")); PdfPCell Observaciones = new PdfPCell(new Phrase("Observaciones")); PdfPCell celda = new PdfPCell(); Titulo_tabla.setHorizontalAlignment(Element.ALIGN_CENTER); Titulo_tabla.setVerticalAlignment(Element.ALIGN_MIDDLE); Titulo_tabla.setBackgroundColor(new BaseColor(153, 0, 76)); Titulo_tabla.setColspan(5); Titulo_tabla.setExtraParagraphSpace(15f); Dos_once.addCell(Titulo_tabla); Num_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Num_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_once.addCell(Num_Actividad); Tipo_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Tipo_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_once.addCell(Tipo_Actividad); Ruta_alm.setHorizontalAlignment(Element.ALIGN_CENTER); Ruta_alm.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_once.addCell(Ruta_alm); Puntos.setHorizontalAlignment(Element.ALIGN_CENTER); Puntos.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_once.addCell(Puntos); Observaciones.setHorizontalAlignment(Element.ALIGN_CENTER); Observaciones.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_once.addCell(Observaciones); /*Aqui van las consultas de las Actividades del profesor*/ int periodo = 0; ResultSet rperiodo = lb.executeQuery("SELECT * FROM profesor WHERE id_usuario = " + getUsername()); if (rperiodo.next()) periodo = rperiodo.getInt("periodo"); /**Get actual period***/ String id_tt = null, puntaje = null, comenta = null; ResultSet rb = lb.executeQuery("SELECT * FROM profesor_tiene_tt WHERE " + "id_usuario = '" + getUsername() + "' AND (validado = 1 OR validado = 0) AND periodo = " + periodo); while (rb.next()) { Dos_once.addCell("2.11"); id_tt = rb.getString("id_TT"); Dos_once.addCell(id_tt); Anchor anchor = new Anchor("Constancia"); //anchor.setReference("file:///"+rb.getString("ruta_alm")); anchor.setReference(rb.getString("ruta_alm")); Dos_once.addCell(anchor); puntaje = rb.getString("puntaje"); Dos_once.addCell(puntaje); comenta = rb.getString("comentarios"); Dos_once.addCell(comenta); } return Dos_once; } private PdfPTable dospuntodoce() throws Exception { PdfPTable Dos_doce = new PdfPTable(5); Dos_doce.setWidths(new int[] { 2, 2, 3, 2, 3 }); PdfPCell Titulo_tabla = new PdfPCell(new Phrase( "Actividad 2.12" + " - Coordinacin o Participacin en la elaboracin o actualizacin" + "de un plan de estudios", encabezadost)); //PdfPCell Num_Actividad = new PdfPCell(new Phrase("Nmero de Actividad")); PdfPCell Tipo_Actividad = new PdfPCell(new Phrase("Identificador de Plan de estudios")); PdfPCell Tipo_parti = new PdfPCell(new Phrase("Tipo de participacin** (Ver parte de abajo)")); PdfPCell Ruta_alm = new PdfPCell(new Phrase("Evidencia")); PdfPCell Puntos = new PdfPCell(new Phrase("Puntos obtenidos")); PdfPCell Observaciones = new PdfPCell(new Phrase("Observaciones")); //PdfPCell celda=new PdfPCell(); Titulo_tabla.setHorizontalAlignment(Element.ALIGN_CENTER); Titulo_tabla.setVerticalAlignment(Element.ALIGN_MIDDLE); Titulo_tabla.setBackgroundColor(new BaseColor(153, 0, 76)); Titulo_tabla.setColspan(5); Titulo_tabla.setExtraParagraphSpace(15f); Dos_doce.addCell(Titulo_tabla); /*Num_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Num_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_doce.addCell(Num_Actividad);*/ Tipo_Actividad.setHorizontalAlignment(Element.ALIGN_CENTER); Tipo_Actividad.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_doce.addCell(Tipo_Actividad); Tipo_parti.setHorizontalAlignment(Element.ALIGN_CENTER); Tipo_parti.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_doce.addCell(Tipo_parti); Ruta_alm.setHorizontalAlignment(Element.ALIGN_CENTER); Ruta_alm.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_doce.addCell(Ruta_alm); Puntos.setHorizontalAlignment(Element.ALIGN_CENTER); Puntos.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_doce.addCell(Puntos); Observaciones.setHorizontalAlignment(Element.ALIGN_CENTER); Observaciones.setVerticalAlignment(Element.ALIGN_MIDDLE); Dos_doce.addCell(Observaciones); /*Aqui van las consultas de las Actividades del profesor*/ int periodo = 0; ResultSet rperiodo = lb.executeQuery("SELECT * FROM profesor WHERE id_usuario = " + getUsername()); if (rperiodo.next()) periodo = rperiodo.getInt("periodo"); /**Get actual period***/ String id_part = null, id_tipo = null, puntaje = null, comenta = null; ResultSet rb = lb.executeQuery("SELECT * FROM profesor_participa_en_plan WHERE " + "id_usuario = '" + getUsername() + "' AND (validado = 1 OR validado = 0) AND periodo = " + periodo /*AND periodo = que el que tiene registrado el profesor*/); while (rb.next()) { //Dos_doce.addCell("2.12"); id_part = rb.getString("id_part"); Dos_doce.addCell(id_part); id_tipo = rb.getString("id_tipo_part"); Dos_doce.addCell(id_tipo);//Agregar a la parte de abajo el tipo de prticicin Anchor anchor = new Anchor("Constancia"); //anchor.setReference("file:///"+rb.getString("ruta_alm")); anchor.setReference("file:///" + rb.getString("ruta_alm")); anchor.setReference("Constancia"); Dos_doce.addCell(anchor); puntaje = rb.getString("puntaje"); Dos_doce.addCell(puntaje); comenta = rb.getString("comentarios"); Dos_doce.addCell(comenta); } return Dos_doce; } private void addEmptyLine(Paragraph paragraph, int number) { for (int i = 0; i < number; i++) { paragraph.add(new Paragraph(" ")); } } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } }