Título: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 12 Marzo 2015, 19:35 pm
Hola, tengo que crear una aplicacion que de informacion sobre el tiempo y necesito crear esto: (http://i.imgur.com/qYU47hP.png?1)
y necesito esto:
(http://i.imgur.com/vy2qGvd.png?1)
la organizacion del frame es borderlayout y habia pensado en poner en la parte izquierda otro layout divido en 2 pero no se como hacerlo
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 12 Marzo 2015, 19:43 pm
No es buena práctica que un JFrame sea hijo de otro JFrame. Usa JDialogs que para eso están, para mostrar ventanas de diálogo, para mostrar las opciones del software, mostrar información de algún evento, realizar una venta, etc. Así indicas que el JFrame (ventana principal) será padre de un diálogo: new JDialog(TU_INSTANCIA_DE_FRAME );
Al hacer esto, cuando abras un JDialog no podrás tocar el JFrame mientras no hayas cerrado el JDialog, que siempre es una buena práctica. Por ejemplo, si vas a mostrar información meterorológica de X ciudad, la muestras en un JDialog y ésta bloqueará el JFrame. Hasta que se cierre el JDialog no se podrá seguir revisando información meteorológicas de otras ciudades.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 13 Marzo 2015, 17:11 pm
no puedo utilizar jframe por que estamos haciendo uso de la libreria awt y no se de que manera colocar el layout a la izquierda, y no tiene que abrirse ninguna ventana a no ser que pulse en añadir provincia o añadir poblacion, tiene que quedar como en la fotografia, se como poner cada cosa, pero a la hora de poner 2 textArea, uno para provincia y otro para poblacion no puedo ubicarlos a la zquierda debido a la disposicion del borderlayout por lo que por eso queria añadir otro layout a la izquierda y dentro de este meter 2 textArea
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 13 Marzo 2015, 17:44 pm
AWT también tiene Frame y Dialog. El procedimiento es el mismo. El de la izquierda puede ser un GridLayout, especificas una columna y dos filas y el margen (distancia) vertical.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 13 Marzo 2015, 17:59 pm
a vale, pensaba que jdialog era de swing, si, eso era lo que queria pero no se sintacticamente como poner el gridlayout dentro del borderlayout en la izquierda
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 13 Marzo 2015, 18:45 pm
Agrega un Panel en la parte izquierda, y a ese Panel le asignas el layout GridLayout. Lee la documentación de Oracle, tutoriales, para que veas ejemplos reales.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 14 Marzo 2015, 18:53 pm
He probado con el panel, y si funciona pero tengo un problema no se alinear los elementos, he creado un box layout: izquierda.add(lProvincia); izquierda.add(tProvincias); izquierda.add(lPoblacion); izquierda.add(tPoblaciones);
(http://i.imgur.com/grZqu7l.png)
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 14 Marzo 2015, 21:21 pm
Cuando tengas una duda, primero consulta la documentación. Para eso está, para que los programadores la consulten ante cualquier duda. Aquí tienes la documentación de GridLayout: GridLayout (http://docs.oracle.com/javase/7/docs/api/java/awt/GridLayout.html).
Como se puede observar tiene sobrecarga de constructores. El otro constructor acepta 4 parámetros, siendo los últimos el espaciado horizontal y el espaciado vertical. Juega con éstos valores a ver si consigues lo que deseas hacer.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 15 Marzo 2015, 08:53 am
estuve mirando ayer pero cambiando valores me seguia saliendo igual, y otra cosa, al pulsar el boton crear provincia me tiene que saltar una ventanita para que indique nombre de provincia y le de a crear o cancelar, pero no se el orden que debo de seguir, creo el action listener del boton crear provincia y luego para el boton del dialogo crear, el action listener lo tengo que crear dentro del primero o en una clase independiente?, muchas gracias
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 15 Marzo 2015, 18:27 pm
Yo siempre recomiendo aislar la lógica, el dominio de las vistas. Aplicar el patrón MVC para desacoplar tu aplicación te ahorrará muchos problemas. Por ejemplo, supongamos que tienes tu Frame o JFrame (Dile con todo respeto a tu profesor que no enseñe tecnologías obsoletas): MainWindow.javapackage com.company.app.views; import java.awt.BorderLayout; import java.awt.Color; import java.awt.FlowLayout; import java.awt.GridBagConstraints; import java.awt.GridBagLayout; import java.awt.GridLayout; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JList; import javax.swing.JMenu; import javax.swing.JMenuBar; import javax.swing.JMenuItem; import javax.swing.JPanel; import javax.swing.JScrollPane; import javax.swing.JTextArea; import javax.swing.UIManager; import javax.swing.UnsupportedLookAndFeelException; import com.company.app.controllers.MainWindowController; import com.company.app.model.entities.Population; public class MainWindow extends JFrame { private static final long serialVersionUID = -2973563217322489640L; private JButton btnUpdatePrediction ; private JList<String> provinceList; private JList<Population> populationList; private MainWindowController controller; public MainWindow() { super(); controller = new MainWindowController(this); initComponents(); } private void initComponents() { top.add(addMenuBar()); top.add(addToolbar()); this.setDefaultCloseOperation(EXIT_ON_CLOSE); JFrame. setDefaultLookAndFeelDecorated(true); this.setTitle("Sistema metereológico"); this.setSize(800,600); try { e.printStackTrace(); e.printStackTrace(); e.printStackTrace(); e.printStackTrace(); } } menubar. setBackground(new Color(50, 50, 50)); menuFile. setForeground(Color. WHITE); iOpen.addActionListener(controller); iExit.addActionListener(controller); menuFile.add(iOpen); menuFile.add(iExit); menuProvince. setForeground(Color. WHITE); iNewProvince = new JMenuItem("Nueva provincia"); iNewProvince.addActionListener(controller); iUpdateProvince = new JMenuItem("Actualizar provincia"); iUpdateProvince.addActionListener(controller); menuProvince.add(iNewProvince); menuProvince.add(iUpdateProvince); menuPopulation. setForeground(Color. WHITE); iNewPopulation = new JMenuItem("Nueva población"); iNewPopulation.addActionListener(controller); iUpdatePopulation = new JMenuItem("Actualizar población"); iUpdatePopulation.addActionListener(controller); menuPopulation.add(iNewPopulation); menuPopulation.add(iUpdatePopulation); menuAbout. setForeground(Color. WHITE); iAbout.addActionListener(controller); menuAbout.add(iAbout); menubar.add(menuFile); menubar.add(menuProvince); menubar.add(menuPopulation); menubar.add(menuAbout); return menubar; } toolbar. setBackground(new Color(0, 184, 255)); toolbar.setSize(50,100); btnUpdatePrediction = new JButton("Actualizar predicción"); btnUpdatePrediction.setFocusable(false); btnUpdatePrediction.addActionListener(controller); btnNewProvince = new JButton("Nueva provincia"); btnNewProvince.setFocusable(false); btnNewProvince.addActionListener(controller); btnNewPopulation = new JButton("Nueva población"); btnNewPopulation.setFocusable(false); btnNewPopulation.addActionListener(controller); toolbar.add(btnUpdatePrediction); toolbar.add(btnNewProvince); toolbar.add(btnNewPopulation); return toolbar; } private JPanel addProvincesPanel () { provinceList = new JList<>(); populationList = new JList<>(); constraints.gridx = 0; constraints.gridy = 0; constraints.gridwidth = 1; constraints.gridheight = 1; panel. add(new JLabel("Provincias"), constraints ); constraints.gridx = 0; constraints.gridy = 1; constraints.gridwidth = 2; constraints.gridheight = 1; constraints.weighty = 1.0; constraints.gridx = 0; constraints.gridy = 2; constraints.gridwidth = 1; constraints.gridheight = 1; panel. add(new JLabel("Poblaciones"), constraints ); constraints.gridx = 0; constraints.gridy = 3; constraints.gridwidth = 2; constraints.gridheight = 1; constraints.weighty = 1.0; panel. add(new JScrollPane(populationList ), constraints ); return panel; } private JPanel addPredictionsPanel () { textArea.setEditable(false); return panel; } private JPanel addFooterPanel () { panel. setBackground(new Color(80, 80, 80)); lblFooter = new JLabel("Sistema metereológico"); lblFooter. setForeground(new Color(200, 200, 200)); panel.add(lblFooter); return panel; } }
MainWindowController.javapackage com.company.app.controllers; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import com.company.app.views.MainWindow; import com.company.app.views.NewProvinceDialog; private MainWindow gui; public MainWindowController(MainWindow gui) { this.gui = gui; } @Override if(e.getActionCommand().equals("Nueva provincia")) { NewProvinceDialog dialog = new NewProvinceDialog(gui); dialog.setVisible(true); } } }
NewProvinceDialog.javapackage com.company.app.views; import java.awt.GridBagConstraints; import java.awt.GridBagLayout; import javax.swing.JButton; import javax.swing.JDialog; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JPanel; import javax.swing.JTextField; public class NewProvinceDialog extends JDialog { private static final long serialVersionUID = -3369879094143739366L; public NewProvinceDialog (JFrame parent ) { super(parent); initComponents(parent); } private void initComponents (JFrame parent ) { btnAddProvince = new JButton("Agregar"); constraints.gridx = 0; constraints.gridy = 0; constraints.gridwidth = 1; constraints.gridheight = 1; constraints.weighty = 1.0; panel.add(label, constraints); constraints.gridx = 1; constraints.gridy = 0; constraints.gridwidth = 3; constraints.gridheight = 1; constraints.weightx = 1.0; panel.add(txtProvince, constraints); constraints.gridx = 3; constraints.gridy = 1; constraints.gridwidth = 1; constraints.gridheight = 1; panel.add(btnAddProvince, constraints); this.add(panel); this.setTitle("Agregar nueva provincia"); this.setSize(280,100); this.setModal(true); this.setLocationRelativeTo(parent); this.setResizable(false); } }
Imágenes: (http://i.imgur.com/qTmH2VD.png) (http://i.imgur.com/Pgd6jlm.png) Sólo es cosa de jugar con los layouts y delegar responsabilidades correctamente. Cualquier duda, comentas.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 16 Marzo 2015, 18:10 pm
esta practica la tenemos que hacer en awt para familiarizarnos y la siguiente es pasar esta a swing, voy a mirar ahora lo que me has puesto ya que lo he mirado por encima y me ha resuelto varias dudas, muchas gracias :)
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 16 Marzo 2015, 18:15 pm
una cosa, yo en mi constructor creo todo el frame con todos los botones, por que tu solo pones esto: public MainWindow() { super(); controller = new MainWindowController(this); initComponents(); }
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 16 Marzo 2015, 18:40 pm
Buenas tardes, La razón de ello es porque estoy usando el patrón MVC como ya dije en mi respuesta anterior. El patrón MVC consiste en dividir tu aplicación en 3 capas: - Modelo: Aquí estará toda la lógica de tu aplicación. Entidades y todo tipo de objetos que colaboran entre sí para cumplir con las reglas del negocio.
- Vista: Esta capa solo contiene las vistas (sean HTML, Frame, JFrame, Stage de JavaFX, WinForms, etc).
- Controlador: Esta capa es la que está entre la Vista y el Modelo. El controlador detecta la acción que ha elegido el usuario y de acuerdo a ello se dirige al modelo para realizar el proceso demandado o también puede acceder a la Vista para devolver una nueva vista. Por ejemplo, cuando registras algo y se muestra una ventana para los datos.
Una vez entendidos éstos conceptos podrás entender el código que te he puesto. De todas maneras, te explicaré cómo funciona. MainWindowControllerEsta es una clase que actúa como controlador, en concreto, es controlador de la vista MainWindow (JFrame). Como se puede observar en su constructor, recibe como parámetro una instancia de MainWindow para que pueda manejar a ella. public MainWindowController(MainWindow gui) { this.gui = gui; }
Al recibir éste controlador una referencia de la vista MainWindow, la puede manejar desde aquí y ya no tenemos que mezclar la lógica de negocio con las vistas. Esto es sumamente importante en el desarrollo de software. El software debe ser fácil de mantener, por que el software una vez que se termina no es todo, siempre se seguirá manteniendo, actualizando, corrigiendo bugs, etc. La referencia se la pasamos desde la vista MainWindow con el uso de this. this es una palabra reservada que hace referencia a "la clase donde se encuentra", por lo que, al pasarle al hacer: new MainWindowController(this);
Lo que hacemos es pasarle la referencia de esa clase, MainWindow, a MainWindowController. De ésta manera, desacoplamos la aplicación, haciéndola mucho más modular y fácil de entender y mantener. Es importante aclarar que para acceder a los controles de la vista (botones, tablas, etc), vas a tener que: - Hacer todos los controles public (mala idea).
- Hacer getters/setters para los controles.
La decisión para dejar los controles private y hacer los getters/setters para acceder a ellos es un concepto de Programación orientada a objetos, y se llama Encapsulamiento, que consiste en aislar las propiedades de un objeto para el exterior, con el propósito de protegerlas y ocultarlas al resto de objetos. sobre esto, ya entenderás más adelante (aunque ya deberías si ya estás por aplicaciones gráficas).
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 16 Marzo 2015, 19:17 pm
tienes que crear una clase nueva para cada evento o los puedes poner como clases propias?
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 16 Marzo 2015, 19:33 pm
¿Una clase para cada evento?. Una clase puede implementar un número ilimitado de interfaces, por lo que tus controladores, por ejemplo el controlador MainWindowController que implementa ActionListener, puede implementar también KeyListener entre otras.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 17 Marzo 2015, 10:06 am
he modificado el codigo para hacerlo por modulos: interfaz principalimport java.awt.*; import java.awt.event.*; import java.io.*; import java.util.Date; import java.text.SimpleDateFormat; import paa.provincias.GestorAEMET; import paa.provincias.GestorAEMETException; /** * Fichero: InterfazAWT_AEMET.java * Clase que implementa la Interfaz Gráfica AEMET con awt. * @author PAA * @version 1.0 */ public class InterfazAWT_AEMET extends Frame { /** * */ private static final long serialVersionUID = 502635761186556414L; private static final String FICHERO = "almacen.dat"; // private IAlmacenPoblaciones almacenPoblaciones; // private List listaPoblaciones; // private List listaPredicciones; /** * Constructor. */ public InterfazAWT_AEMET (String titulo, int ancho, int alto ){ super(titulo); setSize(ancho,alto); setLocationRelativeTo(null); setLayout ( new BorderLayout() ); // Layout de la aplicación, podría ser otro initComponents(); }//Constructor //List<IPrediccion> lista = null; /*try { lista = gestor.getPredicciones( poblacion ); poblacion.lista = lista; } catch( GestorAEMETException gae ) { System.out.println( gae.getMessage() ); }*/ private void initComponents(){ // Recuperamos el almacén AlmacenPoblaciones almacenPoblaciones = new AlmacenPoblaciones(); if (almacenPoblaciones.recuperar(FICHERO)) System. out. println("Recuperado el almacen del fichero " + FICHERO ); else System. out. println("No se pudo recuperar el almacen del fichero " + FICHERO ); //Boton salir por defecto guardarAntesDeSalir (); } }); setMenuBar(addMenuBar()); } //Sitúo los menús desplegables // Creo el menú Archivo crearCargar.addActionListener(new CargarArchivo()); crearGuardar.addActionListener(new GuardarArchivo()); salir.addActionListener(new Salir()); menuArchivo.add(crearCargar); menuArchivo.add(crearGuardar); menuArchivo.add(salir); // Creo el menú Provincias Menu menuProvincias = new Menu("Provincias"); crearProvincias.addActionListener(new CrearProvincia()); borrarProvincias.addActionListener(new BorrarProvincia()); menuProvincias.add(crearProvincias); menuProvincias.add(borrarProvincias); // Creo el menu Poblaciones Menu menuPoblaciones = new Menu("Poblaciones"); crearPoblacion.addActionListener(new CrearPoblacion()); borrarPoblacion.addActionListener(new BorrarPoblacion()); ordenarNombre.addActionListener(new OrdenarNombre()); ordenarHabitantes.addActionListener(new OrdenarHabitantes()); modPoblacion.addActionListener(new ModPoblacion()); movPoblacion.addActionListener(new MovPoblacion()); menuPoblaciones.add(crearPoblacion); menuPoblaciones.add(borrarPoblacion); menuPoblaciones.add(ordenarNombre); menuPoblaciones.add(ordenarHabitantes); menuPoblaciones.add(modPoblacion); menuPoblaciones.add(movPoblacion); // Creo el menú de ayuda acercaDe.addActionListener(new AcercaDe()); ayuda.add(acercaDe); //Crea el barraDeMenu.add(menuArchivo); barraDeMenu.add(menuProvincias); barraDeMenu.add(menuPoblaciones); // Sitúo el menú de ayuda en su sitio barraDeMenu.setHelpMenu(ayuda); return barraDeMenu; } private Panel addToolBar (){ //Sitúo la línea de botones lineaDeBotones. setBackground (Color. lightGray); //Boton crear provincia proCrear.addActionListener(new CrearProvincia()); //Boton crear poblacion poCrear.addActionListener(new CrearPoblacion()); //Boton actualizar prediccion aPrediccion.addActionListener(new ActualizarPrediccion()); // Añadir los botones a la barra lineaDeBotones.add(proCrear); lineaDeBotones.add(poCrear); lineaDeBotones.add(aPrediccion); return lineaDeBotones; } private Panel addPanelIzquierda (){ //Creamos panel para mostrar provincias y poblaciones y lo colocamos a la izquierda izquierda.add(lProvincia); izquierda.add(tProvincias); izquierda.add(lPoblacion); izquierda.add(tPoblaciones); return izquierda; } private Panel addpredicciones (){ //Creamos el panel de las predicciones Label lPrediccion = new Label("Predicciones de :"); return predicciones; } private Panel addlineaEstado (){ //Sitúo la línea de estado lineaDeEstado. setBackground (Color. lightGray); Label ventanaDeeventos = new Label("Gestor AEMET v1.0 (PAA)"); lineaDeEstado.add (ventanaDeeventos); return lineaDeEstado; } private void guardarAntesDeSalir () { // Guardar almacen System. out. println ("Gracias por utilizar nuestro programa"); } /** * Clase que implementa la acción del menú "acerca de". */ VentanaAcercaDe ventanaAcercaDe = new VentanaAcercaDe(InterfazAWT_AEMET.this); ventanaAcercaDe.setVisible(true); } }//Acerca de //****Acciones menu archivo**** } }//Guardar en un fichero } }//Cargar desde un archivo } }//Salir de la aplicacion //****Acciones menu provincia**** // Crea una provincia e.getActionCommand(); } } VentanaCrearProvincia dialog = new VentanaCrearProvincia(); dialog.setVisible(true); } } //Elimina una provincia Aviso aviso = new Aviso(InterfazAWT_AEMET.this,"Provincia:"); aviso.setTitle("Eliminar Provincia"); aviso.setSize(300, 100); aviso.add(textField); aviso.add(eliminar); aviso.add(cancelar); aviso.setVisible(true); } } //****Acciones menu poblacion**** //Crear una poblacion //Aviso aviso = new Aviso(InterfazAWT_AEMET.this,"Nueva provincia"); Aviso dialog = new Aviso(InterfazAWT_AEMET.this); dialog.setSize(300, 400); texto.add(nombre); texto.add(nombreP); texto.add(habitantes); texto.add(codigo); panel.add(crear); panel.add(cancelar); dialog.pack(); dialog.setVisible(true); } } //Eliminar una poblacion Aviso aviso = new Aviso(InterfazAWT_AEMET.this,"Poblacion:"); aviso.setTitle("Eliminar Poblacion"); aviso.setSize(300, 100); aviso.add(textField); aviso.add(eliminar); aviso.add(cancelar); aviso.setVisible(true); } } //Ordena por nombre las poblaciones } } //Ordena por numero de habitantes las poblaciones } } //Modifica los valores de una poblacion } } //Mueve una poblacion de provincia } } //Accion actualizar prediccion } } /** * Método main. */ public static void main (String[] args ) { InterfazAWT_AEMET mimarco = new InterfazAWT_AEMET("Gestor AEMET",1000,500); mimarco.setVisible(true); } // Main }
ventana crear provinciaimport java.awt.Button; import java.awt.Dialog; import java.awt.Frame; import java.awt.GridLayout; import java.awt.TextField; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; public class VentanaCrearProvincia extends Dialog { /** * */ private static final long serialVersionUID = -2530069431684593677L; public VentanaCrearProvincia (Frame f ) { super(f,"Nueva provincia",true); setLocationRelativeTo(f); this.setTitle("Crear Provincia"); this.setSize(300, 100); crear.addActionListener(new BotonCrear()); cancelar.addActionListener(new BotonCancelar()); this.add(textField); this.add(crear); this.add(cancelar); VentanaCrearProvincia.this.dispose(); } }); } @Override // TODO Auto-generated method stub } } @Override } } }
pero tengo varios errores en el metodo initcomponents: at AlmacenPoblaciones.recuperar(AlmacenPoblaciones.java:357) at InterfazAWT_AEMET.initComponents(InterfazAWT_AEMET.java:54) at InterfazAWT_AEMET.<init>(InterfazAWT_AEMET.java:37) at InterfazAWT_AEMET.main(InterfazAWT_AEMET.java:373)
lo de que no encuentra el archivo, es por que no lo tengo creado, ese no me preocupa de momento, se abre la ventana principal pero al pulsar en crear provincia no sale la siguiente ventana
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 17 Marzo 2015, 17:31 pm
Me has mal entendido. Eso no es modular, eso es repetitivo y viola el principio KISS (Keep it simple stupid). Ya te di las pautas para que lo hagas correctamente, depende de ti si las usas o no. 245. VentanaCrearProvincia dialog = new VentanaCrearProvincia(); 246. dialog.setVisible(true); 247. } 248. 249. }
¿La clase VentanaCrearProvincia no aceptaba un Frame en el constructor para utilizarlo como padre?
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 18 Marzo 2015, 18:24 pm
vale, ya he conseguido que me funcione, mira: clase principalimport java.awt.*; import java.awt.event.*; import java.io.*; import java.util.Date; import java.text.SimpleDateFormat; import paa.provincias.GestorAEMET; import paa.provincias.GestorAEMETException; /** * Fichero: InterfazAWT_AEMET.java * Clase que implementa la Interfaz Gráfica AEMET con awt. * @author PAA * @version 1.0 */ public class InterfazAWT_AEMET extends Frame { /** * */ private static final long serialVersionUID = 502635761186556414L; private static final String FICHERO = "almacen.dat"; private VentanaCrearProvinciaController controllerCrearProvincia; // private IAlmacenPoblaciones almacenPoblaciones; // private List listaPoblaciones; // private List listaPredicciones; /** * Constructor. */ public InterfazAWT_AEMET (String titulo, int ancho, int alto ){ super(titulo); controllerCrearProvincia = new VentanaCrearProvinciaController(this); setSize(ancho,alto); setLocationRelativeTo(null); setLayout ( new BorderLayout() ); // Layout de la aplicación, podría ser otro initComponents(); }//Constructor //List<IPrediccion> lista = null; /*try { lista = gestor.getPredicciones( poblacion ); poblacion.lista = lista; } catch( GestorAEMETException gae ) { System.out.println( gae.getMessage() ); }*/ private void initComponents(){ // Recuperamos el almacén AlmacenPoblaciones almacenPoblaciones = new AlmacenPoblaciones(); if (almacenPoblaciones.recuperar(FICHERO)) System. out. println("Recuperado el almacen del fichero " + FICHERO ); else System. out. println("No se pudo recuperar el almacen del fichero " + FICHERO ); //Boton salir por defecto guardarAntesDeSalir (); } }); setMenuBar(addMenuBar()); } //Sitúo los menús desplegables // Creo el menú Archivo crearCargar.addActionListener(new CargarArchivo()); crearGuardar.addActionListener(new GuardarArchivo()); salir.addActionListener(new Salir()); menuArchivo.add(crearCargar); menuArchivo.add(crearGuardar); menuArchivo.add(salir); // Creo el menú Provincias Menu menuProvincias = new Menu("Provincias"); crearProvincias.addActionListener(controllerCrearProvincia); borrarProvincias.addActionListener(new BorrarProvincia()); menuProvincias.add(crearProvincias); menuProvincias.add(borrarProvincias); // Creo el menu Poblaciones Menu menuPoblaciones = new Menu("Poblaciones"); crearPoblacion.addActionListener(new CrearPoblacion()); borrarPoblacion.addActionListener(new BorrarPoblacion()); ordenarNombre.addActionListener(new OrdenarNombre()); ordenarHabitantes.addActionListener(new OrdenarHabitantes()); modPoblacion.addActionListener(new ModPoblacion()); movPoblacion.addActionListener(new MovPoblacion()); menuPoblaciones.add(crearPoblacion); menuPoblaciones.add(borrarPoblacion); menuPoblaciones.add(ordenarNombre); menuPoblaciones.add(ordenarHabitantes); menuPoblaciones.add(modPoblacion); menuPoblaciones.add(movPoblacion); // Creo el menú de ayuda acercaDe.addActionListener(new AcercaDe()); ayuda.add(acercaDe); //Crea el barraDeMenu.add(menuArchivo); barraDeMenu.add(menuProvincias); barraDeMenu.add(menuPoblaciones); // Sitúo el menú de ayuda en su sitio barraDeMenu.setHelpMenu(ayuda); return barraDeMenu; } private Panel addToolBar (){ //Sitúo la línea de botones lineaDeBotones. setBackground (Color. lightGray); //Boton crear provincia proCrear.addActionListener(controllerCrearProvincia); //Boton crear poblacion poCrear.addActionListener(new CrearPoblacion()); //Boton actualizar prediccion aPrediccion.addActionListener(new ActualizarPrediccion()); // Añadir los botones a la barra lineaDeBotones.add(proCrear); lineaDeBotones.add(poCrear); lineaDeBotones.add(aPrediccion); return lineaDeBotones; } private Panel addPanelIzquierda (){ //Creamos panel para mostrar provincias y poblaciones y lo colocamos a la izquierda izquierda.add(lProvincia); izquierda.add(tProvincias); izquierda.add(lPoblacion); izquierda.add(tPoblaciones); return izquierda; } private Panel addpredicciones (){ //Creamos el panel de las predicciones Label lPrediccion = new Label("Predicciones de :"); return predicciones; } private Panel addlineaEstado (){ //Sitúo la línea de estado lineaDeEstado. setBackground (Color. lightGray); Label ventanaDeeventos = new Label("Gestor AEMET v1.0 (PAA)"); lineaDeEstado.add (ventanaDeeventos); return lineaDeEstado; } private void guardarAntesDeSalir () { // Guardar almacen System. out. println ("Gracias por utilizar nuestro programa"); } /** * Clase que implementa la acción del menú "acerca de". */ VentanaAcercaDe ventanaAcercaDe = new VentanaAcercaDe(InterfazAWT_AEMET.this); ventanaAcercaDe.setVisible(true); } }//Acerca de //****Acciones menu archivo**** } }//Guardar en un fichero } }//Cargar desde un archivo } }//Salir de la aplicacion //****Acciones menu provincia**** // Crea una provincia e.getActionCommand(); } } //Elimina una provincia Aviso aviso = new Aviso(InterfazAWT_AEMET.this,"Provincia:"); aviso.setTitle("Eliminar Provincia"); aviso.setSize(300, 100); aviso.add(textField); aviso.add(eliminar); aviso.add(cancelar); aviso.setVisible(true); } } //****Acciones menu poblacion**** //Crear una poblacion //Aviso aviso = new Aviso(InterfazAWT_AEMET.this,"Nueva provincia"); Aviso dialog = new Aviso(InterfazAWT_AEMET.this); dialog.setSize(300, 400); texto.add(nombre); texto.add(nombreP); texto.add(habitantes); texto.add(codigo); panel.add(crear); panel.add(cancelar); dialog.pack(); dialog.setVisible(true); } } //Eliminar una poblacion Aviso aviso = new Aviso(InterfazAWT_AEMET.this,"Poblacion:"); aviso.setTitle("Eliminar Poblacion"); aviso.setSize(300, 100); aviso.add(textField); aviso.add(eliminar); aviso.add(cancelar); aviso.setVisible(true); } } //Ordena por nombre las poblaciones } } //Ordena por numero de habitantes las poblaciones } } //Modifica los valores de una poblacion } } //Mueve una poblacion de provincia } } //Accion actualizar prediccion } } /** * Método main. */ public static void main (String[] args ) { InterfazAWT_AEMET mimarco = new InterfazAWT_AEMET("Gestor AEMET",1000,500); mimarco.setVisible(true); } // Main }
clase controllerimport java.awt.event.ActionEvent; import java.awt.event.ActionListener; public class VentanaCrearProvinciaController implements ActionListener { private InterfazAWT_AEMET gui; public VentanaCrearProvinciaController(InterfazAWT_AEMET gui) { this.gui = gui; } @Override if(e.getActionCommand().equals("Crear provincia")){ VentanaCrearProvinciaDialog dialog = new VentanaCrearProvinciaDialog(gui); dialog.setVisible(true); } } }
clase ventana provinciaimport java.awt.Button; import java.awt.Dialog; import java.awt.Frame; import java.awt.GridLayout; import java.awt.Label; import java.awt.TextField; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; public class VentanaCrearProvinciaDialog extends Dialog { /** * */ private static final long serialVersionUID = -2530069431684593677L; public VentanaCrearProvinciaDialog (Frame gui ) { super(gui); setLocationRelativeTo(gui); this.setTitle("Crear Provincia"); this.setSize(300, 100); crear.addActionListener(new BotonCrear()); cancelar.addActionListener(new BotonCancelar()); this.add(label); this.add(textField); this.add(crear); this.add(cancelar); VentanaCrearProvinciaDialog.this.dispose(); } }); } // TODO Auto-generated method stub } } dispose(); } } }
me abre la ventana de crear provincia y el boton cancelar la cierra, ahora tengo que agregar el boton crear, pero tengo una duda, he de pasarle almacenPoblaciones como parametro, pero el que debe de recibir como parametro es el metodo BotonCrear de CrearProvinciaDialog, que a su vez a de recibirlo de crearprovinciaController lo recoge de interfazAemet, por tanto quedaria asi la cosa BotonCrear(se le pasa AlmacenPoblaciones como parametro)--CrearProvinciaDialog--CrearProvinciaController--InterfazAemet, pero no se como hacer todo el recorrido. Y otra pregunta por que en el codigo de tu clase principal el objeto controller de tipo mainWindowController lo llamas en todos los action listener, ¿por que? incluso en los de poblacion, yo solo lo he puesto en los de provincia. Muchas gracias por ayudarme, me esta siendo de gran ayuda
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 18 Marzo 2015, 21:14 pm
Debes de colocar un getter estático para el Map que contiene las provincias y poblaciones, de tal modo que puedes obtener el Map fácil como: Map<String, Set<Population>> provinces = ProvinceService.getProvinces();
Otra opción es que ProvincesService en lugar de tener el Map como propiedad, sea el mismo un Map. Esto se logra muy fácilmente extendiendo a alguna implementación de Map: public class ProvinveService extends LinkedHashMap<String, Set<Population>> { private static ProvinceService instance = null; static { instance = new ProvinceService(); } private ProvinceService() {} public static ProvinceService getInstance() { return instance; } }
Olvidemos que Singleton no sea muy recomendado. Aquí te sirve y punto. Recuerda que se usaría LinkedHashMap porque HashMap no respeta orden de inserción, cosa que sería un problema cuando haya que ordenarlo. Los métodos como ordenar, obtenerPoblacion, etc quedarían igual. La única difefencia es que en lugar de hacer referencia al Map (que estaba como propiedad) hariamos referencia a this, porque ahora se hereda de LinkedHashMap. Haciendo lo anterior puedes obtener el Map muy facilmente: ProvinceService provinceService = ProvinceService.getInstance(); provinceService.addProvince("Madrid"); ...
Ademas al hacer uso de un constructor privado evitas que se creen instancias de ProvinceService por lo que te aseguras que solo exista una instancia que será compartida entre todos los objetos. Y otra pregunta por que en el codigo de tu clase principal el objeto controller de tipo mainWindowController lo llamas en todos los action listener, ¿por que? ActionListener es una interface cuyo propósito es escuchar por eventos de acción (sea Enter o Clic). Al escuchar de forma general por eventos de acción puede escuchar un número ilimitado de controles cuya acción sea compatible (Button, TextField, entre otras). En mi respuesta anterior te indiqué que hacer una clase que inplemente ActionListener para cada botón no tiene ningún sentido. MainWindowController, que implementa ActionListener escuchará todo control de MainWindow por eventos de acción: btnCreateProvince, btnCreatePopulation, btnUpdatePredictions, y todo control que sea escuchable por ActionListener. Te preguntarás cómo identificar qué botón se ha clickeado. Bien, el objeto ActionEvent contiene información acerca del origen del desencadenamiento de la acción, origen del cual podemos saber su nombre (etiqueta del control) y de acuerdo al nombre realizar la acción deseada: String targetLabel = e. getActionCommand(); if(targetLabel.equals("Crear Provincia")) { new NewProvinceDialog(gui).setVisible(true); } else if(targetLabel.equals("Nueva población")) { new NewPopulationDialog(gui).setVisible(true); } else if(targetLabel.equals("Actualizar predicciones
En resumen: - El Map que contiene las provincias y poblaciones al ser un objeto único que será usado en distintos contextos debe ser estático o heredar de LinkedHashMap y ser un singleton que pueda obtenerse desde todo contexto.
- No es necesario usar una clase que implemente a un Listener por cada control a escuchar. Es repetitivo e inútil.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 19 Marzo 2015, 13:13 pm
lo que me has puesto de skleton es algo que no he utilizado nunca, no se como se hace por lo que la solucion tiene que ser otra ya debemos de utilizar cosas que hemos dado previamente. he pensado en esto: import java.awt.*; import java.awt.event.*; import java.io.*; import java.util.Date; import java.util.Iterator; import java.util.LinkedHashMap; import java.util.Set; import java.text.SimpleDateFormat; import paa.provincias.GestorAEMET; import paa.provincias.GestorAEMETException; import paa.provincias.IPoblacion; /** * Fichero: InterfazAWT_AEMET.java * Clase que implementa la Interfaz Gráfica AEMET con awt. * @author PAA * @version 1.0 */ public class InterfazAWT_AEMET extends Frame { /** * */ private static final long serialVersionUID = 502635761186556414L; private static final String FICHERO = "almacen.dat"; private Controller controller; private AlmacenPoblaciones almacen; // private IAlmacenPoblaciones almacenPoblaciones; // private List listaPoblaciones; // private List listaPredicciones; /** * Constructor. * @throws GestorAEMETException */ public InterfazAWT_AEMET (String titulo, int ancho, int alto ) throws GestorAEMETException { super(titulo); controller = new Controller(this,true); setSize(ancho,alto); setLocationRelativeTo(null); setLayout ( new BorderLayout() ); // Layout de la aplicación, podría ser otro initComponents(); almacen = RecuperaAlmacenPoblaciones(); }//Constructor //List<IPrediccion> lista = null; /*try { lista = gestor.getPredicciones( poblacion ); poblacion.lista = lista; } catch( GestorAEMETException gae ) { System.out.println( gae.getMessage() ); }*/ public AlmacenPoblaciones RecuperaAlmacenPoblaciones() { // Recuperamos el almacén AlmacenPoblaciones almacenPoblaciones1 = new AlmacenPoblaciones(); if (almacenPoblaciones1.recuperar(FICHERO)) System. out. println("Recuperado el almacen del fichero " + FICHERO ); else System. out. println("No se pudo recuperar el almacen del fichero " + FICHERO ); return almacenPoblaciones1; } private void initComponents() throws GestorAEMETException{ //Boton salir por defecto guardarAntesDeSalir (); } }); setMenuBar(addMenuBar()); } public static class almacenPoblaciones extends LinkedHashMap<String, Set<IPoblacion>>{ /** * */ private static final long serialVersionUID = 1L; private static almacenPoblaciones instance = null; static { instance = new almacenPoblaciones(); } private almacenPoblaciones(){} public static almacenPoblaciones getInstance(){ return instance; } } //Sitúo los menús desplegables // Creo el menú Archivo crearCargar.addActionListener(controller); crearGuardar.addActionListener(controller); salir.addActionListener(controller); menuArchivo.add(crearCargar); menuArchivo.add(crearGuardar); menuArchivo.add(salir); // Creo el menú Provincias Menu menuProvincias = new Menu("Provincias"); crearProvincias.addActionListener(controller); borrarProvincias.addActionListener(controller); menuProvincias.add(crearProvincias); menuProvincias.add(borrarProvincias); // Creo el menu Poblaciones Menu menuPoblaciones = new Menu("Poblaciones"); crearPoblacion.addActionListener(controller); borrarPoblacion.addActionListener(controller); ordenarNombre.addActionListener(controller); ordenarHabitantes.addActionListener(controller); modPoblacion.addActionListener(controller); movPoblacion.addActionListener(controller); menuPoblaciones.add(crearPoblacion); menuPoblaciones.add(borrarPoblacion); menuPoblaciones.add(ordenarNombre); menuPoblaciones.add(ordenarHabitantes); menuPoblaciones.add(modPoblacion); menuPoblaciones.add(movPoblacion); // Creo el menú de ayuda acercaDe.addActionListener(new AcercaDe()); ayuda.add(acercaDe); //Crea el barraDeMenu.add(menuArchivo); barraDeMenu.add(menuProvincias); barraDeMenu.add(menuPoblaciones); // Sitúo el menú de ayuda en su sitio barraDeMenu.setHelpMenu(ayuda); return barraDeMenu; } private Panel addToolBar (){ //Sitúo la línea de botones lineaDeBotones. setBackground (Color. lightGray); //Boton crear provincia proCrear.addActionListener(controller); //Boton crear poblacion poCrear.addActionListener(controller); //Boton actualizar prediccion aPrediccion.addActionListener(controller); // Añadir los botones a la barra lineaDeBotones.add(proCrear); lineaDeBotones.add(poCrear); lineaDeBotones.add(aPrediccion); return lineaDeBotones; } private Panel addPanelIzquierda (){ //Creamos panel para mostrar provincias y poblaciones y lo colocamos a la izquierda Iterator<String> i = almacen.getProvincias().iterator(); while(i.hasNext()){ tProvincias.add(i.next().toString()); } izquierda.add(lProvincia); izquierda.add(tProvincias); izquierda.add(lPoblacion); izquierda.add(tPoblaciones); return izquierda; } private Panel addpredicciones (){ //Creamos el panel de las predicciones Label lPrediccion = new Label("Predicciones de :"); return predicciones; } private Panel addlineaEstado (){ //Sitúo la línea de estado lineaDeEstado. setBackground (Color. lightGray); Label ventanaDeeventos = new Label("Gestor AEMET v1.0 (PAA)"); lineaDeEstado.add (ventanaDeeventos); return lineaDeEstado; } private void guardarAntesDeSalir () { // Guardar almacen System. out. println ("Gracias por utilizar nuestro programa"); } /** * Clase que implementa la acción del menú "acerca de". */ VentanaAcercaDe ventanaAcercaDe = new VentanaAcercaDe(InterfazAWT_AEMET.this); ventanaAcercaDe.setVisible(true); } }//Acerca de //****Acciones menu archivo**** } }//Guardar en un fichero } }//Cargar desde un archivo } }//Salir de la aplicacion //Ordena por nombre las poblaciones } } //Ordena por numero de habitantes las poblaciones } } //Modifica los valores de una poblacion } } //Mueve una poblacion de provincia } } //Accion actualizar prediccion } } /** * Método main. * @throws GestorAEMETException */ public static void main (String[] args ) throws GestorAEMETException { InterfazAWT_AEMET mimarco = new InterfazAWT_AEMET("Gestor AEMET",1000,500); mimarco.setVisible(true); } // Main }
lo que hago es leer el almacenpoblaciones del archivo, almacenarlo en una variable y posteriormente se me habia ocurrido para mostar en las listas de poblacion y provincia hacer un iterator con los metodos de almacenPoblaciones getPoblaciones y getProvincias, (los cuales devuelven un set cada uno) e ir añadiendo a ambas listas las corresponsientes provincias y poblaciones. Pero claro si hago todo esto cuando inicio el programa, en el momento que cree una nueva poblacion o provincia he de refrescar las listas por lo que deberia de utilizar un metodo que sea llamado desde los actionlistener de los botones correspondientes no?. en el programa de arriba me da error aqui: Iterator<String> i = almacen.getProvincias().iterator();
NullPointerException, no se por que me dice que no hay nada si previamente he utilizado la primera practica para añadir 4 provincias.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 19 Marzo 2015, 21:29 pm
Te repito por tercera vez. Esto no debe ir: 242. VentanaAcercaDe ventanaAcercaDe = new VentanaAcercaDe(InterfazAWT_AEMET.this); 243. ventanaAcercaDe.setVisible(true); 244. } 245. }//Acerca de 246. 247. 248. //****Acciones menu archivo**** 251. 252. } 253. }//Guardar en un fichero 254. 257. 258. } 259. }//Cargar desde un archivo 260. 263. 264. } 265. }//Salir de la aplicacion 266. 267. 268. 269. 270. 271. //Ordena por nombre las poblaciones 274. 275. } 276. } 277. 278. //Ordena por numero de habitantes las poblaciones 281. 282. } 283. } 284. 285. //Modifica los valores de una poblacion 288. 289. } 290. } 291. 292. //Mueve una poblacion de provincia 295. 296. } 297. } 298. 299. 300. 301. 302. 303. 304. 305. //Accion actualizar prediccion 308. 309. } 310. }
Esto es reemplazado por el MainWindowController: @Override String targetLabel = evt. getActionCommad(); evaluateAction(targetLabel); } private void evaluateAction (String targetLabel ) { switch(targetLabel) { case "Nueva Provincia": new NewProvinceDialog(gui).setVisible(true); break; case "Nueva Población": new NewPopulationDialog(gui).setVisible(true); break; case "Salir": gui.dispose(); // asi con todos los botones } }
AlmacenProvincias (ProvinceService)Vuelvo a repetir, NO mezclar la lógica de negocio con la vistas. Aplica el patrón MVC que es mucho más sencillo, si te empeñas en seguir mezclando las cosas así, llegarás a un punto donde te estanques porque simplemente no hay arquitectura en tu aplicación, se convertirá en un montón de código sin sentido. Veamos como puedes realizar lo que deseas. Primero, ProvinceService será un Map: import java.util.HashMap; import java.util.HashSet; import java.util.Map; import java.util.Set; public class ProvinceService extends LinkedHashMap<String, Set<Population>> { private static ProvinceService instance; static { instance = new ProvinceService(); } private ProvinceService() {} public ProvinceService getInstance() { return instance; } if(this.containsKey(provinceName)) throw new IlegalArgumentException("La provincia ya existe"); else { this.put(provinceName, null); response = "Provinca añadida correctamente"; } return response; } if(!this.containsKey(provinceName)) { throw new IlegalArgumentException("La provincia no existe, primero créela"); } else { Set<Population> provincePopulation = getPopulationByProvinceName(provinceName); provincePopulation.add(population); response = "Provincia añadida correctamente"; } return response; } if(!this.containsKey(provinceName)) { Set<Population> provincePopulation = new HashSet<>(); provincePopulation.add(population); provincesAndPopulations.put(provinceName, provincePopulation); response = "Provincia y población añadida correctamente"; } else { throw new IlegalArgumentException("La provincia ya existe. Agregue solo la población"); } return response; } private Set <Population > getPopulationByProvinceName (String provinceName ) { Set<Population> population = null; for(Map. Entry<String, Set <Population >> entry : this. entrySet()) { if(entry.getKey().equals(provinceName)) population = entry.getValue(); } return population; } }
MainWindowController.javaimport java.awt.event.ActionEvent; import java.awt.event.ActionListener; private MainWindow gui; public MainWindowController(MainWindow gui) { this.gui = gui; } @Override String targetLabel = evt. getActionCommad(); evaluateAction(targetLabel); } private void evaluateAction (String targetLabel ) { switch(targetLabel) { case "Nueva Provincia": new NewProvinceDialog(gui).setVisible(true); break; case "Nueva Población": new NewPopulationDialog(gui).setVisible(true); break; case "Salir": gui.dispose(); // asi con todos los botones } } }
NewProvinceDialog.javaimport java.awt.GridBagConstraints; import java.awt.GridBagLayout; import javax.swing.JButton; import javax.swing.JDialog; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JPanel; import javax.swing.JTextField; public class NewProvinceDialog extends JDialog { private static final long serialVersionUID = -3369879094143739366L; public NewProvinceDialog (JFrame parent ) { super(parent); initComponents(parent); } private void initComponents (JFrame parent ) { btnAddProvince = new JButton("Agregar"); constraints.gridx = 0; constraints.gridy = 0; constraints.gridwidth = 1; constraints.gridheight = 1; constraints.weighty = 1.0; panel.add(label, constraints); constraints.gridx = 1; constraints.gridy = 0; constraints.gridwidth = 3; constraints.gridheight = 1; constraints.weightx = 1.0; panel.add(txtProvince, constraints); constraints.gridx = 3; constraints.gridy = 1; constraints.gridwidth = 1; constraints.gridheight = 1; panel.add(btnAddProvince, constraints); this.add(panel); this.setTitle("Agregar nueva provincia"); this.setSize(280,100); this.setModal(true); this.setLocationRelativeTo(parent); this.setResizable(false); } // getters de los controles public JTextField getTxtProvince () { return txtProvince ; } }
NewProvinceDialogController.javaimport java.awt.event.ActionEvent; import java.awt.event.ActionListener; private NewProvinceDialog gui; public NewProvinceDialogController(NewProvinceDialog gui) { this.gui = gui; } @Override String targetLabel = evt. getActionCommand(); if(targetLabel.equals("Añadir")) { try { ProvinceService provinceService = ProvinceService.getInstance(); String provinceName = gui. getTxtProvince(). getText(); String response = provinceService. addProvince(provinceName ); // muestra 'La provinca ya existe' } } else { gui.dispose(); } } }
ProvinceService la he transformado para que sea un LinkedHashMap. Como te dije será un Singleton (No es nada de extraordinario, es una clase normal solo que su constructor es privado evitando que sea creen instancias de ella) que será compartida por todos los objetos. En NewProvinceDialogController hacemos uso de ProvinceService: @Override String targetLabel = evt. getActionCommand(); if(targetLabel.equals("Añadir")) { try { ProvinceService provinceService = ProvinceService.getInstance(); String provinceName = gui. getTxtProvince(). getText(); String response = provinceService. addProvince(provinceName ); // muestra 'La provinca ya existe' } } else { gui.dispose(); } }
Si se ha clickeado "Añadir" en el JDialog para añadir una nueva provincia, se obtiene la única instancia de ProvinceService que como ya dijimos es un LinkedHashMap. Así mismo, sigue teniendo los mismos métodos por lo que todo sigue funcionando como antes. Obtenemos el JTextField txtProvince de NewProvinceDialog y usamos el método getText() para obtener lo que el usuario ha escrito. Luego, llamamos al método addProvince que se encargará de verificar si existe o si no existe y tomar la acción adecuada. Si la provincia existe mostrará un mensaje que es el que se le asocia a la Exception lanzada desde el método addProvince:
Que luego recojemos en el controlador de NewProvinceDialogController: // muestra 'La provinca ya existe' }
Si la provincia se añadió correctamente, el mensaje de éxito retornado se muestra: String response = provinceService. addProvince(provinceName );
Sigue el mismo patrón. De ésta manera modularizas bien tu aplicación y le das una arquitectura sólida, claves para un diseño escalable ;)
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 20 Marzo 2015, 13:00 pm
la clase principal tiene tantos listener por que aun no los he quitado, segun voy creando las clases los voy eliminando para que quede como MWC: he intentado hacer lo que me has dicho creando otra clase controller para la ventana provincia,me dibuja la ventana pero no me deja cerrarla por lo que el codigo gui.dispose(); no lo ejecuta: package Provincia; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; public class VentanaCrearProvinciaController implements ActionListener { private VentanaCrearProvincia gui; public VentanaCrearProvinciaController(VentanaCrearProvincia gui){ this.gui = gui; } String label = e. getActionCommand(); if(label.equals("Crear")){ }else{ gui.dispose(); } } }
ventana crearprovincia package Provincia; import java.awt.Button; import java.awt.Dialog; import java.awt.Frame; import java.awt.GridLayout; import java.awt.Label; import java.awt.Panel; import java.awt.TextField; public class VentanaCrearProvincia extends Dialog { private static final long serialVersionUID = -2530069431684593677L; public VentanaCrearProvincia (Frame gui ) { super(gui); initComponents(gui); } public void initComponents (Frame gui ){ cancelar = new Button("Cancelar"); setLocationRelativeTo(gui); this.setTitle("Crear Provincia"); this.setSize(300, 100); panel.add(label); panel.add(textField); panel.add(crear); panel.add(cancelar); this.add(panel); } return textField; } }
respecto al almacenpoblaciones, este es mi codigo, que es el correspondiente a la primera practica y funciona perfectamente, como implementa las interfaces iAlmacenpoblaciones e IPoblacionAEMET, no tengo que hacer extends de linkedhashmap ni de set no? por que esas interfaces ya lo tendran implementado, las interfaces nos las han dado en un paquete .jar import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.Serializable; import java.util.Comparator; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Set; import java.util.SortedSet; import java.util.TreeSet; import paa.provincias.IAlmacenPoblaciones; import paa.provincias.IPoblacion; import paa.provincias.IPoblacionAEMET; /** * Clase que modela un almacen de poblaciones * @author kikian * */ public class AlmacenPoblaciones implements IAlmacenPoblaciones, Serializable,IPoblacionAEMET { /** * */ private static final long serialVersionUID = 1L; private Map<String, SortedSet<IPoblacion>> Aprovincias = new HashMap<String, SortedSet<IPoblacion>>(); /**Ordenación principal en orden alfabético por el campo nombre de la población. */ final static int ORDENARPORNOMBRE = 2; /**Ordenación principal por el número de habitantes en sentido ascendente, en segundo lugar, en caso de igualdad, por * el orden alfabético del campo nombre. */ final static int ORDENARPORHABITANTES = 3; /** * Constructor de la clase AlmacenPoblaciones */ public AlmacenPoblaciones(){ Aprovincias = new HashMap<String, SortedSet<IPoblacion>>(); } /** * Añade una población a la provincia correspondiente si la población no existe ya en ella, o sea, no hay ya otra población con el mismo nombre. Las poblaciones se almacenarán ordenadas según el criterio de ordenación definido. @param provincia - Provincia en la que se añadira la poblacion @param poblacion - Poblacion a añadir */ public boolean addPoblacion (String provincia, IPoblacion poblacion ) { boolean res = false; if(provincia == null || poblacion == null || !Aprovincias.containsKey(provincia)){ res = false; System. out. println("La Provincia no existe, creela antes de añadir poblacion"); }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); sPoblacion.add(poblacion); Aprovincias.put(provincia, sPoblacion); res = true; } return res; } /** * Añade una nuevo provincia al almacén de poblaciones si no está ya presente en el almacén. Si ya había una del mismo nombre no se realiza ningún cambio en el almacén y la llamada devuelve false. @param provincia - La provincia que queremos añadir */ public boolean addProvincia (String provincia ) { boolean res = false; if(Aprovincias.containsKey(provincia)){ System. out. println("Ya existe la provincia"); }else{ Aprovincias.put(provincia, new TreeSet<IPoblacion>()); res = true; } return res; } /** * Indica si ya existe en la provincia una población con ese nombre. * @param provincia - Nombre de la provincia en la que vamos a buscar * @param poblacion - Nombre de la poblacion que queremos buscar */ public boolean containsPoblacion (String provincia, String poblacion ) { boolean res = false; if(provincia == null || !Aprovincias.containsKey(provincia)){ System. out. println("La provincia no existe, creela antes de eliminar poblacion"); }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); for(IPoblacion p:sPoblacion){ if(p.getNombre()==poblacion){ res = true; } } } return res; } /** * Indica si ya existe en la provincia una población. * @param provincia - La provincia en la que buscaremos * @param poblacion - La poblacion que queremos buscar */ public boolean containsPoblacion (String provincia, IPoblacion poblacion ) { boolean res = false; if(provincia == null || !Aprovincias.containsKey(provincia)){ System. out. println("La provincia no existe, creela antes de eliminar poblacion"); }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); if(sPoblacion.contains(poblacion)){ res = true; } } return res; } /** * Indica si ya existe en el almacén la provincia correspondiente. * @param provincia - La provincia que queremos comprobar */ public boolean containsProvincia (String provincia ) { boolean res = false; if(Aprovincias.containsKey(provincia)){ res = true; System. out. println("La provincia esta en el almacen"); }else{ System. out. println("La provincia no esta en el almacen"); } return res; } /** * Borra la población situada en la posición correspondiente dentro de la provincia. La posición es un * entero entre 1 y el número de poblaciones que contiene la provincia. La posición de una * población es variable, puesto que cambia si se borran poblaciones de la provincia o se reordena. * @param provincia - Provincia en la que buscaremos la poblacion * @param posicion - posicion de la poblacion que sera borrada */ public boolean delPoblacion (String provincia, int posicion ) { if(!Aprovincias.containsKey(provincia)){ System. out. println("No existe la provincia"); return false; }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); Iterator<IPoblacion> ite = sPoblacion.iterator(); int contador = 1; while(ite.hasNext() && contador < posicion){ ite.next(); contador++; } if(ite.hasNext() && contador == posicion){ ite.next(); ite.remove(); Aprovincias.put(provincia, sPoblacion); return true; } } return false; } /** * Borra de la provincia la población que se pasa como parámetro. * @param provincia - La provincia donde buscaremos * @param poblacion - La poblacion que se eliminara */ public boolean delPoblacion (String provincia, IPoblacion poblacion ) { boolean res = false; if(!Aprovincias.containsKey(provincia)){ System. out. print("La provincia no existe"); }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); sPoblacion.remove(poblacion); Aprovincias.put(provincia, sPoblacion); } return res; } /** * Borra de la provincia la población cuyo nombre se pasa como parámetro. * @param provincia - La provincia de donde eliminaremos la poblacion * @param poblacion - El nombre de la poblacion */ public boolean delPoblacion (String provincia, String poblacion ) { if(!Aprovincias.containsKey(provincia)){ System. out. print("La provincia no existe"); return false; }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); for(IPoblacion s : sPoblacion){ if(s.getNombre().equals(poblacion)){ sPoblacion.remove(s); return true; } } return false; } } /** * Borra un provincia del almacén de poblaciones si está presente en el almacén. Si no hay una del mismo nombre no se realiza ningún cambio en el almacén y la llamada devuelve false. @param provincia - La provincia que queremos eliminar */ public boolean delProvincia (String provincia ) { if(Aprovincias.containsKey(provincia)){ Aprovincias.remove(provincia); return true; }else{ System. out. println("La provincia no esta en el almacen"); return false; } } /** * Devuelve el número de poblaciones que contiene la provincia cuyo nombre se indica. * @param provincia - La provincia de la que obtendremos el numero de poblaciones */ public int getNumPoblaciones (String provincia ) { SortedSet<IPoblacion> spoblacion = Aprovincias.get(provincia); return spoblacion.size(); } /** * Devuelve la población situada en la posición correspondiente dentro de la provincia. La posición es un * entero entre 1 y el número de poblaciones que contiene la provincia. La posición de una población es variable, puesto * que cambia si se borran poblaciones de la provincia o se reordenan. * @param provincia - la provincia en la que se buscara * @param posicion - la posicion que se eliminara */ public IPoblacion getPoblacion (String provincia, int posicion ) { IPoblacion pBuscada = null; if(!Aprovincias.containsKey(provincia)){ System. out. println("No existe la provincia"); }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); Iterator<IPoblacion> ite = sPoblacion.iterator(); int contador = 1; while(ite.hasNext() && contador < posicion){ ite.next(); contador++; } if(ite.hasNext() && contador == posicion){ pBuscada = ite.next(); ite.remove(); } } return pBuscada; } /**Devuelve de la provincia la población que posee el nombre que se pasa como parámetro. * */ public IPoblacion getPoblacion (String provincia, String poblacion ) { SortedSet<IPoblacion> spoblacion = Aprovincias.get(provincia); IPoblacion p = null; for(IPoblacion s : spoblacion){ if(s.getNombre().equals(poblacion)){ p = s; } } return p; } /** * Devuelve todas las poblaciones de la provincia correspondiente ordenadas según el criterio actual. * @param provincia - La provincia de la que obtendremos el Set con las poblaciones */ public SortedSet <IPoblacion > getPoblaciones (String provincia ) { SortedSet<IPoblacion> spoblacion = null; if(!Aprovincias.containsKey(provincia)){ System. out. println("No existe la provincia"); }else{ spoblacion = Aprovincias.get(provincia); } return spoblacion; } /** * Devuelve un conjunto con los nombres de los provincias que existen en el almacén de poblaciones. */ public Set<String> getProvincias() { Set<String> provincias = Aprovincias.keySet(); return provincias; } /**Guarda el almacén de poblaciones en el fichero cuyo nombre se pasa como parámetro. Devuelve true si se ha guardado * correctamente y false si hay algún tipo de error o excepción. * @param escritura - nombre del fichero */ public boolean guardar (String escritura ) { try{ salida.writeObject(Aprovincias); e.printStackTrace(); } finally{ if(salida!=null) try{ salida.close(); return true; e.printStackTrace(); } } return false; } /**Permite cambiar el criterio de ordenación de la correspondiente provincia, las poblaciones almacenadas * serán reordenadas según el nuevo criterio de ordenación que se indica como parámetro utilizando las constantes * predefinidas: ORDENARPORNOMBRE ú ORDENARPORHABITANTES (ver su descripción en fields). * @param provincia - Provincia en la que se reordenaran las poblaciones * @param ordenarPor - Metodo para ordenar las poblaciones */ public boolean ordenarPor (String provincia, int ordenarPor ) { if(provincia != null || ordenarPor != ORDENARPORNOMBRE || ordenarPor != ORDENARPORHABITANTES ){ if(ordenarPor == ORDENARPORNOMBRE){ //Metemos en un Set las poblaciones de la provincia asociada Set<IPoblacion> spoblacion = Aprovincias.get(provincia); //Creamos un nuevo Set de tipo TreeSet y le aplicamos el criterio de ordenacion //de la clase porNombre, luego le añadimos todas las poblaciones para que se ordenen TreeSet<IPoblacion> n1Poblacion = new TreeSet<IPoblacion>(new porNombre()); n1Poblacion.addAll(spoblacion); Aprovincias.put(provincia, n1Poblacion); }else if(ordenarPor == ORDENARPORHABITANTES){ //Mismo procedimiento que ORDENARPORNOMBRE pero ahora utilizamos el criterio de ordenacion //de la clase CompareHabitantes Set<IPoblacion> spoblacion = Aprovincias.get(provincia); TreeSet<IPoblacion> n2Poblacion = new TreeSet<IPoblacion>(new CompareHabitantes()); n2Poblacion.addAll(spoblacion); Aprovincias.put(provincia, n2Poblacion); } return true; } return false; } /**Recupera un almacén de poblaciones del fichero cuyo nombre se pasa como parámetro. Si el fichero no existe o * hay algún tipo de excepción devuelve false y crea un almacén vacío. Si lo recupera, devuelve true. * @param lectura - Nombre del archivo que leeremos */ public boolean recuperar (String lectura ) { try{ @SuppressWarnings("unchecked") Map<String, SortedSet<IPoblacion>> Aprovincias2 = (Map<String, SortedSet<IPoblacion>>) entrada.readObject(); System. out. println(Aprovincias2. entrySet()); e.printStackTrace(); } finally{ if(entrada!=null) try{ entrada.close(); return true; e.printStackTrace(); } } return false; } /** * Clase para comparar las poblaciones por nombre * @author kikian * */ class porNombre implements Comparator<IPoblacion>{ @Override public int compare(IPoblacion o1, IPoblacion o2) { return o1.getNombre().compareTo(o2.getNombre()); } } @Override public String getCodigoAEMET () { // TODO Auto-generated method stub return null; } }
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 20 Marzo 2015, 15:50 pm
Olvidaba que es AWT. Reemplaza gui.dispose por: window.dispose();
Respecto a lo otro, si el docente les ha dado esas interfaces en un JAR pues debes usarlas y no hacerme caso cuando te dije que extendieras de LinkedHashMap.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 21 Marzo 2015, 11:01 am
pero si es awt no puedo utilizar Swing utilities por que esta incluido dentro de Swing.
tengo que crear un metodo que actualize las listas de las predicciones cada vez que borre o añada poblacion o provincia no?
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 21 Marzo 2015, 11:05 am
Cuando se dice que no utilices Swing se hace referencia a que no utilices controles gráficos de Swing. SwingUtilities es simplemente una clase utilitaria.
Tampoco hay que irse por los extremos xD
Respecto a lo otro, sí hay que hay que hacer un método que actualice las provincias y poblaciones.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 21 Marzo 2015, 11:50 am
sigue sin cerrar la ventana, los botones crear y cancelar no hacen nada, y el de cerrar la ventana hace que se cierre por que puse el window adapter sino tampoco se cerraria: package Provincia; import java.awt.Window; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import javax.swing.SwingUtilities; import Provincia.VentanaCrearProvincia; public class VentanaCrearProvinciaController implements ActionListener { private VentanaCrearProvincia gui; public VentanaCrearProvinciaController(VentanaCrearProvincia gui){ this.gui = gui; } String label = e. getActionCommand(); if(label.equals("Crear")){ try{ Aviso aviso = new Aviso(gui,e1.getMessage()); } }else{ window.dispose(); } } }
package Provincia; import java.awt.Button; import java.awt.Dialog; import java.awt.Frame; import java.awt.GridLayout; import java.awt.Label; import java.awt.Panel; import java.awt.TextField; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; public class VentanaCrearProvincia extends Dialog { private static final long serialVersionUID = -2530069431684593677L; public VentanaCrearProvincia (Frame gui ) { super(gui); initComponents(gui); } public void initComponents (Frame gui ){ cancelar = new Button("Cancelar"); setLocationRelativeTo(gui); this.setTitle("Crear Provincia"); this.setSize(300, 100); panel.add(label); panel.add(textField); panel.add(crear); panel.add(cancelar); this.add(panel); VentanaCrearProvincia.this.dispose(); } }); } return textField; } }
respecto al almacen poblaciones lo he dejado asi: import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.Serializable; import java.util.Comparator; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Set; import java.util.SortedSet; import java.util.TreeSet; import paa.provincias.IAlmacenPoblaciones; import paa.provincias.IPoblacion; import paa.provincias.IPoblacionAEMET; /** * Clase que modela un almacen de poblaciones * @author kikian * */ public class AlmacenPoblaciones implements IAlmacenPoblaciones, Serializable,IPoblacionAEMET { /** * */ private static final long serialVersionUID = 1L; private Map<String, SortedSet<IPoblacion>> Aprovincias = new HashMap<String, SortedSet<IPoblacion>>(); /**Ordenación principal en orden alfabético por el campo nombre de la población. */ final static int ORDENARPORNOMBRE = 2; /**Ordenación principal por el número de habitantes en sentido ascendente, en segundo lugar, en caso de igualdad, por * el orden alfabético del campo nombre. */ final static int ORDENARPORHABITANTES = 3; /** * Constructor de la clase AlmacenPoblaciones */ public AlmacenPoblaciones(){ Aprovincias = new HashMap<String, SortedSet<IPoblacion>>(); } private static AlmacenPoblaciones instance = null; static { instance = new AlmacenPoblaciones(); } public static AlmacenPoblaciones getInstance(){ return instance; } /** * Añade una población a la provincia correspondiente si la población no existe ya en ella, o sea, no hay ya otra población con el mismo nombre. Las poblaciones se almacenarán ordenadas según el criterio de ordenación definido. @param provincia - Provincia en la que se añadira la poblacion @param poblacion - Poblacion a añadir */ public boolean addPoblacion (String provincia, IPoblacion poblacion ) { boolean res = false; if(provincia == null || poblacion == null || !Aprovincias.containsKey(provincia)){ res = false; System. out. println("La Provincia no existe, creela antes de añadir poblacion"); }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); sPoblacion.add(poblacion); Aprovincias.put(provincia, sPoblacion); res = true; } return res; } /** * Añade una nuevo provincia al almacén de poblaciones si no está ya presente en el almacén. Si ya había una del mismo nombre no se realiza ningún cambio en el almacén y la llamada devuelve false. @param provincia - La provincia que queremos añadir */ public boolean addProvincia (String provincia ) { boolean res = false; if(Aprovincias.containsKey(provincia)){ System. out. println("Ya existe la provincia"); }else{ Aprovincias.put(provincia, new TreeSet<IPoblacion>()); res = true; } return res; } /** * Indica si ya existe en la provincia una población con ese nombre. * @param provincia - Nombre de la provincia en la que vamos a buscar * @param poblacion - Nombre de la poblacion que queremos buscar */ public boolean containsPoblacion (String provincia, String poblacion ) { boolean res = false; if(provincia == null || !Aprovincias.containsKey(provincia)){ System. out. println("La provincia no existe, creela antes de eliminar poblacion"); }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); for(IPoblacion p:sPoblacion){ if(p.getNombre()==poblacion){ res = true; } } } return res; } /** * Indica si ya existe en la provincia una población. * @param provincia - La provincia en la que buscaremos * @param poblacion - La poblacion que queremos buscar */ public boolean containsPoblacion (String provincia, IPoblacion poblacion ) { boolean res = false; if(provincia == null || !Aprovincias.containsKey(provincia)){ System. out. println("La provincia no existe, creela antes de eliminar poblacion"); }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); if(sPoblacion.contains(poblacion)){ res = true; } } return res; } /** * Indica si ya existe en el almacén la provincia correspondiente. * @param provincia - La provincia que queremos comprobar */ public boolean containsProvincia (String provincia ) { boolean res = false; if(Aprovincias.containsKey(provincia)){ res = true; System. out. println("La provincia esta en el almacen"); }else{ System. out. println("La provincia no esta en el almacen"); } return res; } /** * Borra la población situada en la posición correspondiente dentro de la provincia. La posición es un * entero entre 1 y el número de poblaciones que contiene la provincia. La posición de una * población es variable, puesto que cambia si se borran poblaciones de la provincia o se reordena. * @param provincia - Provincia en la que buscaremos la poblacion * @param posicion - posicion de la poblacion que sera borrada */ public boolean delPoblacion (String provincia, int posicion ) { if(!Aprovincias.containsKey(provincia)){ System. out. println("No existe la provincia"); return false; }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); Iterator<IPoblacion> ite = sPoblacion.iterator(); int contador = 1; while(ite.hasNext() && contador < posicion){ ite.next(); contador++; } if(ite.hasNext() && contador == posicion){ ite.next(); ite.remove(); Aprovincias.put(provincia, sPoblacion); return true; } } return false; } /** * Borra de la provincia la población que se pasa como parámetro. * @param provincia - La provincia donde buscaremos * @param poblacion - La poblacion que se eliminara */ public boolean delPoblacion (String provincia, IPoblacion poblacion ) { boolean res = false; if(!Aprovincias.containsKey(provincia)){ System. out. print("La provincia no existe"); }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); sPoblacion.remove(poblacion); Aprovincias.put(provincia, sPoblacion); } return res; } /** * Borra de la provincia la población cuyo nombre se pasa como parámetro. * @param provincia - La provincia de donde eliminaremos la poblacion * @param poblacion - El nombre de la poblacion */ public boolean delPoblacion (String provincia, String poblacion ) { if(!Aprovincias.containsKey(provincia)){ System. out. print("La provincia no existe"); return false; }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); for(IPoblacion s : sPoblacion){ if(s.getNombre().equals(poblacion)){ sPoblacion.remove(s); return true; } } return false; } } /** * Borra un provincia del almacén de poblaciones si está presente en el almacén. Si no hay una del mismo nombre no se realiza ningún cambio en el almacén y la llamada devuelve false. @param provincia - La provincia que queremos eliminar */ public boolean delProvincia (String provincia ) { if(Aprovincias.containsKey(provincia)){ Aprovincias.remove(provincia); return true; }else{ System. out. println("La provincia no esta en el almacen"); return false; } } /** * Devuelve el número de poblaciones que contiene la provincia cuyo nombre se indica. * @param provincia - La provincia de la que obtendremos el numero de poblaciones */ public int getNumPoblaciones (String provincia ) { SortedSet<IPoblacion> spoblacion = Aprovincias.get(provincia); return spoblacion.size(); } /** * Devuelve la población situada en la posición correspondiente dentro de la provincia. La posición es un * entero entre 1 y el número de poblaciones que contiene la provincia. La posición de una población es variable, puesto * que cambia si se borran poblaciones de la provincia o se reordenan. * @param provincia - la provincia en la que se buscara * @param posicion - la posicion que se eliminara */ public IPoblacion getPoblacion (String provincia, int posicion ) { IPoblacion pBuscada = null; if(!Aprovincias.containsKey(provincia)){ System. out. println("No existe la provincia"); }else{ SortedSet<IPoblacion> sPoblacion = Aprovincias.get(provincia); Iterator<IPoblacion> ite = sPoblacion.iterator(); int contador = 1; while(ite.hasNext() && contador < posicion){ ite.next(); contador++; } if(ite.hasNext() && contador == posicion){ pBuscada = ite.next(); ite.remove(); } } return pBuscada; } /**Devuelve de la provincia la población que posee el nombre que se pasa como parámetro. * */ public IPoblacion getPoblacion (String provincia, String poblacion ) { SortedSet<IPoblacion> spoblacion = Aprovincias.get(provincia); IPoblacion p = null; for(IPoblacion s : spoblacion){ if(s.getNombre().equals(poblacion)){ p = s; } } return p; } /** * Devuelve todas las poblaciones de la provincia correspondiente ordenadas según el criterio actual. * @param provincia - La provincia de la que obtendremos el Set con las poblaciones */ public SortedSet <IPoblacion > getPoblaciones (String provincia ) { SortedSet<IPoblacion> spoblacion = null; if(!Aprovincias.containsKey(provincia)){ System. out. println("No existe la provincia"); }else{ spoblacion = Aprovincias.get(provincia); } return spoblacion; } /** * Devuelve un conjunto con los nombres de los provincias que existen en el almacén de poblaciones. */ public Set<String> getProvincias() { Set<String> provincias = Aprovincias.keySet(); return provincias; } /**Guarda el almacén de poblaciones en el fichero cuyo nombre se pasa como parámetro. Devuelve true si se ha guardado * correctamente y false si hay algún tipo de error o excepción. * @param escritura - nombre del fichero */ public boolean guardar (String escritura ) { try{ salida.writeObject(Aprovincias); e.printStackTrace(); } finally{ if(salida!=null) try{ salida.close(); System. out. println("Guardado"); return true; e.printStackTrace(); } } return false; } /**Permite cambiar el criterio de ordenación de la correspondiente provincia, las poblaciones almacenadas * serán reordenadas según el nuevo criterio de ordenación que se indica como parámetro utilizando las constantes * predefinidas: ORDENARPORNOMBRE ú ORDENARPORHABITANTES (ver su descripción en fields). * @param provincia - Provincia en la que se reordenaran las poblaciones * @param ordenarPor - Metodo para ordenar las poblaciones */ public boolean ordenarPor (String provincia, int ordenarPor ) { if(provincia != null || ordenarPor != ORDENARPORNOMBRE || ordenarPor != ORDENARPORHABITANTES ){ if(ordenarPor == ORDENARPORNOMBRE){ //Metemos en un Set las poblaciones de la provincia asociada Set<IPoblacion> spoblacion = Aprovincias.get(provincia); //Creamos un nuevo Set de tipo TreeSet y le aplicamos el criterio de ordenacion //de la clase porNombre, luego le añadimos todas las poblaciones para que se ordenen TreeSet<IPoblacion> n1Poblacion = new TreeSet<IPoblacion>(new porNombre()); n1Poblacion.addAll(spoblacion); Aprovincias.put(provincia, n1Poblacion); }else if(ordenarPor == ORDENARPORHABITANTES){ //Mismo procedimiento que ORDENARPORNOMBRE pero ahora utilizamos el criterio de ordenacion //de la clase CompareHabitantes Set<IPoblacion> spoblacion = Aprovincias.get(provincia); TreeSet<IPoblacion> n2Poblacion = new TreeSet<IPoblacion>(new CompareHabitantes()); n2Poblacion.addAll(spoblacion); Aprovincias.put(provincia, n2Poblacion); } return true; } return false; } /**Recupera un almacén de poblaciones del fichero cuyo nombre se pasa como parámetro. Si el fichero no existe o * hay algún tipo de excepción devuelve false y crea un almacén vacío. Si lo recupera, devuelve true. * @param lectura - Nombre del archivo que leeremos */ public boolean recuperar (String lectura ) { try{ @SuppressWarnings("unchecked") Map<String, SortedSet<IPoblacion>> Aprovincias2 = (Map<String, SortedSet<IPoblacion>>) entrada.readObject(); System. out. println(Aprovincias2. entrySet()); e.printStackTrace(); } finally{ if(entrada!=null) try{ entrada.close(); System. out. println("Recuperado"); return true; e.printStackTrace(); } } return false; } /** * Clase para comparar las poblaciones por nombre * @author kikian * */ class porNombre implements Comparator<IPoblacion>{ @Override public int compare(IPoblacion o1, IPoblacion o2) { return o1.getNombre().compareTo(o2.getNombre()); } } /** * Obtiene el codigo AEMET asociado a la poblacion */ public String getCodigoAEMET () { // TODO Auto-generated method stub return null; } }
y para ver si funcionaba en la clase principal tengo esto: import java.awt.*; import java.awt.event.*; import java.io.*; import java.util.Date; import java.util.Iterator; import java.util.LinkedHashMap; import java.util.Set; import java.text.SimpleDateFormat; import paa.provincias.GestorAEMET; import paa.provincias.GestorAEMETException; import paa.provincias.IPoblacion; /** * Fichero: InterfazAWT_AEMET.java * Clase que implementa la Interfaz Gráfica AEMET con awt. * @author PAA * @version 1.0 */ public class InterfazAWT_AEMET extends Frame { /** * */ private static final long serialVersionUID = 502635761186556414L; private static final String FICHERO = "almacen.dat"; private Controller controller; private AlmacenPoblaciones almacen; // private IAlmacenPoblaciones almacenPoblaciones; // private List listaPoblaciones; // private List listaPredicciones; /** * Constructor. * @throws GestorAEMETException */ public InterfazAWT_AEMET (String titulo, int ancho, int alto ) throws GestorAEMETException { super(titulo); controller = new Controller(this); setSize(ancho,alto); setLocationRelativeTo(null); setLayout ( new BorderLayout() ); // Layout de la aplicación, podría ser otro initComponents(); almacen = AlmacenPoblaciones.getInstance(); almacen.recuperar(FICHERO); System. out. println(almacen. getProvincias()); }//Constructor //List<IPrediccion> lista = null; /*try { lista = gestor.getPredicciones( poblacion ); poblacion.lista = lista; } catch( GestorAEMETException gae ) { System.out.println( gae.getMessage() ); }*/ public AlmacenPoblaciones RecuperarAlmacenPoblaciones() { // Recuperamos el almacén AlmacenPoblaciones almacenPoblaciones1 = new AlmacenPoblaciones(); if (almacenPoblaciones1.recuperar(FICHERO)) System. out. println("Recuperado el almacen del fichero " + FICHERO ); else System. out. println("No se pudo recuperar el almacen del fichero " + FICHERO ); return almacenPoblaciones1; } private void initComponents() throws GestorAEMETException{ //Boton salir por defecto guardarAntesDeSalir (); } }); setMenuBar(addMenuBar()); } //Sitúo los menús desplegables // Creo el menú Archivo crearCargar.addActionListener(controller); crearGuardar.addActionListener(controller); salir.addActionListener(controller); menuArchivo.add(crearCargar); menuArchivo.add(crearGuardar); menuArchivo.add(salir); // Creo el menú Provincias Menu menuProvincias = new Menu("Provincias"); crearProvincias.addActionListener(controller); borrarProvincias.addActionListener(controller); menuProvincias.add(crearProvincias); menuProvincias.add(borrarProvincias); // Creo el menu Poblaciones Menu menuPoblaciones = new Menu("Poblaciones"); crearPoblacion.addActionListener(controller); borrarPoblacion.addActionListener(controller); ordenarNombre.addActionListener(controller); ordenarHabitantes.addActionListener(controller); modPoblacion.addActionListener(controller); movPoblacion.addActionListener(controller); menuPoblaciones.add(crearPoblacion); menuPoblaciones.add(borrarPoblacion); menuPoblaciones.add(ordenarNombre); menuPoblaciones.add(ordenarHabitantes); menuPoblaciones.add(modPoblacion); menuPoblaciones.add(movPoblacion); // Creo el menú de ayuda acercaDe.addActionListener(new AcercaDe()); ayuda.add(acercaDe); //Crea el barraDeMenu.add(menuArchivo); barraDeMenu.add(menuProvincias); barraDeMenu.add(menuPoblaciones); // Sitúo el menú de ayuda en su sitio barraDeMenu.setHelpMenu(ayuda); return barraDeMenu; } private Panel addToolBar (){ //Sitúo la línea de botones lineaDeBotones. setBackground (Color. lightGray); //Boton crear provincia proCrear.addActionListener(controller); //Boton crear poblacion poCrear.addActionListener(controller); //Boton actualizar prediccion aPrediccion.addActionListener(controller); // Añadir los botones a la barra lineaDeBotones.add(proCrear); lineaDeBotones.add(poCrear); lineaDeBotones.add(aPrediccion); return lineaDeBotones; } private Panel addPanelIzquierda (){ //Creamos panel para mostrar provincias y poblaciones y lo colocamos a la izquierda for(int i =0; i==20;i++){ tProvincias.add("i"); } /*Iterator<String> i = almacen.getProvincias().iterator(); while(i.hasNext()){ tProvincias.add(i.next().toString()); }*/ izquierda.add(lProvincia); izquierda.add(tProvincias); izquierda.add(lPoblacion); izquierda.add(tPoblaciones); return izquierda; } private Panel addpredicciones (){ //Creamos el panel de las predicciones Label lPrediccion = new Label("Predicciones de :"); return predicciones; } private Panel addlineaEstado (){ //Sitúo la línea de estado lineaDeEstado. setBackground (Color. lightGray); Label ventanaDeeventos = new Label("Gestor AEMET v1.0 (PAA)"); lineaDeEstado.add (ventanaDeeventos); return lineaDeEstado; } private void guardarAntesDeSalir () { // Guardar almacen System. out. println ("Gracias por utilizar nuestro programa"); } /** * Clase que implementa la acción del menú "acerca de". */ VentanaAcercaDe ventanaAcercaDe = new VentanaAcercaDe(InterfazAWT_AEMET.this); ventanaAcercaDe.setVisible(true); } }//Acerca de //****Acciones menu archivo**** } }//Guardar en un fichero } }//Cargar desde un archivo //Ordena por nombre las poblaciones } } //Ordena por numero de habitantes las poblaciones } } //Modifica los valores de una poblacion } } //Mueve una poblacion de provincia } } //Accion actualizar prediccion } } /** * Método main. * @throws GestorAEMETException */ public static void main (String[] args ) throws GestorAEMETException { InterfazAWT_AEMET mimarco = new InterfazAWT_AEMET("Gestor AEMET",1000,500); mimarco.setVisible(true); } // Main }
y al ejecutarlo se abre la ventana del programa y en eclipse me aparece esto: [Madrid=[Getafe,0,Madrid], Galicia=[], Gralicia=[], Graliscia=[], Garlicia=[]] Recuperado [] Gracias por utilizar nuestro programa por lo que si se recupera el archivo pero luego cuando hago System.out.println(almacen.getProvincias()); para ver si realmente esta ahi metido el almacen me dice que esta vacio, ya que el metodo recuperar solo muestra el que se ha recuperado y no lo mete en ningun sitio, ¿Como meto lo que leo del archivo a la instacia de almacenPoblaciones?
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 21 Marzo 2015, 13:12 pm
Investiga por tu cuenta tambié... Un poco más abajo en otros temas he puesto códigos para leer ficheros. Échales un vistazo y aplícalo a tu aplicación.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 22 Marzo 2015, 13:42 pm
Investiga por tu cuenta tambié... Un poco más abajo en otros temas he puesto códigos para leer ficheros. Échales un vistazo y aplícalo a tu aplicación.
tambien investigo por mi cuenta pero no entiendo la forma de hacerlo, el profesor nos dijo que habia que pasar los parametros por referencia para que el almacen de poblaciones se guardara correctamente pero he mirado y en java no se pueden pasar parametros por referencia, todos son por valor. Tambien sigo sin poder acceder a los botones crear y cancelar de provincias, se crea la ventana pero no hace nada al presionar.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 22 Marzo 2015, 21:09 pm
En Java, NO EXISTE EL PASO DE PARÁMETROS POR REFERENCIA, TODO PASO ES POR VALOR, pero un "paso por valor" muy especial y es muy confuso entenderlo. Intentaré explicártelo ;) (disculpa si lo hago más confuso :xD). Imaginemos el siguiente escenario: Tenemos una clase Dog: public class Dog { public Dog() { } this.name = name; } return name; } public void setName (String name ) { this.name = name; } }
Y el main: public class DogMain { public static void main (String[] args ) { Dog aDog = new Dog(); aDog.setName("Rex"); System. out. println("Nombre del perro: "+aDog. getName()); changeDogName(aDog); System. out. println("Nombre del perro: "+aDog. getName()); changeDogReference(aDog); System. out. println("Nombre del perro al terminar las operaciones: "+aDog. getName()); } public static void changeDogName(Dog sameDog) { sameDog.setName("Brutus"); System. out. println("Cambiado el nombre del perro a 'Brutus'"); } public static void changeDogReference(Dog sameDog) { sameDog = new Dog("Fury"); System. out. println("Nuevo nombre del perro: "+sameDog. getName()); } }
Ahora, analicemos que hace el código. 1. Crea un objeto tipo Dog llamado aDog. 2. Establece el nombre de aDog a "Rex". 3. Imprime el nombre del perro (Rex). 4. Llama al método changeDogName y se le pasa aDog. Dentro de changeDogName: 4.1 Cambia el nombre a aDog a "Brutus". 4.2 Informa que se ha cambiado el nombre de aDog a "Brutus". 5. Imprime el nombre de aDog (Brutus). 6. Llama al método changeDogReference y se le pasa aDog. Dentro de changeDogReference: 6.1 Instancia nuevamente aDog pasándole el nuevo nombre "Fury". 6.2 Informa que se ha cambiado el nombre de aDog a "Fury". 7. Imprime el nombre final del aDog. El resultado es "Brutus". Cuando le pasas un objeto por parámetro a un método, el objeto no pasa al método. Cuando pasas un objeto por parámetro a un método lo que ocurre es que se pasa es una copia de la dirección de memoria de dicho objeto. Por ende, no se puede modificar la referencia (dirección) no puede modificarse, pero sí se puede modificar los valores que engloba dicha referencia. Es por eso que cuando hacemos: public static void changeDogName(Dog sameDog) { sameDog.setName("Brutus"); System. out. println("Cambiado el nombre del perro a 'Brutus'"); }
Cambia el nombre de aDog sin problema alguno, porque puede acceder a los valores por medio de la copia de la dirección de memoria de aDog. Pero, ¿Qué pasa si volvemos a instanciar aDog dentro de un método? El resultado es que esa copia de la dirección de memoria de aDog recibe una nueva dirección de memoria al instanciar Dog, por lo que ahora es otro objeto tipo Dog. public static void changeDogReference(Dog sameDog) { sameDog = new Dog("Fury"); System. out. println("Nuevo nombre del perro: "+sameDog. getName()); }
Para comprobarlo, ejecutemos la prueba: Nombre del perro: Rex Cambiado el nombre del perro a 'Brutus' Nombre del perro: Brutus Nuevo nombre del perro: Fury Nombre del perro al terminar las operaciones: Brutus
Como ves, el paso de variables en Java es por VALOR y NO POR REFERENCIA. Puedes llevarle éste ejemplo a tu profesor, para que vea que está equivocado. Saludos.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 27 Marzo 2015, 18:29 pm
hola, ya he resuelto bastantes errores, puedo añadir y eliminar provincias perfectamente, ahora lo que necesito es que en la lista de provincias al pinchar en una, por ejemplo en madrid y darle al boton crear poblacion,me salga un frame en el que me diga que voy a añadir en la provincia madrid la poblacion xxxx, estoy utilizando el metodo lista.getSelectedItem() para saber que elemtno esta pinchado pero me salta null pointer exception y no se porque, mira: package Poblacion; import java.awt.BorderLayout; import java.awt.Button; import java.awt.Dialog; import java.awt.FlowLayout; import java.awt.Frame; import java.awt.GridLayout; import java.awt.Label; import java.awt.List; import java.awt.Panel; import java.awt.TextField; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; import principal.AlmacenPoblaciones; import principal.Aviso; public class VentanaCrearPoblacion extends Dialog { private AlmacenPoblaciones almacen; private List listaPoblaciones ; private List listaPredicciones ; private List listaProvincias ; private static final long serialVersionUID = 1434307119439314094L; public VentanaCrearPoblacion (Frame gui, AlmacenPoblaciones almacen, List listaPoblaciones, List listaProvincias, List listaPredicciones ) { super(gui); initComponents(gui); this.almacen = almacen; this.listaPoblaciones = listaPoblaciones; this.listaProvincias = listaProvincias; this.listaPredicciones = listaPredicciones; } public void initComponents (Frame gui ){ setLocationRelativeTo(gui); this.setTitle("Crear Poblacion"); this.setSize(300, 200); cancelar = new Button("Cancelar"); Label nombreP = new Label(listaProvincias. getSelectedItem()); crear.addActionListener(new Controller()); cancelar.addActionListener(new Controller()); texto.add(textField); texto.add(nombreP); texto.add(habitantes); texto.add(codigo); panel.add(crear); panel.add(cancelar); VentanaCrearPoblacion.this.dispose(); } }); } private VentanaCrearPoblacion gui; String label = e. getActionCommand(); if(label.equals("Crear")){ try{ Aviso aviso = new Aviso(gui,e1.getMessage()); } }else{ VentanaCrearPoblacion.this.dispose(); } } } }
he metido el controller dentro de la clase ventana por que me lo ha dicho el profesor
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 27 Marzo 2015, 19:00 pm
Necesitas hacer algunos cambios. Por ejemplo: @Override String target = evt. getActionCommand(); switch(target.toLowerCase()) { case "crear población": createPopulation(evt); break; case "añadir provincia": createProvince(evt); break; } } // listProvinces viene a ser el JList que contiene las provincias Province province = (Province) listProvinces.getSelectedItem(); NewPopulationDialog dialog = new NewPopulationDialog(); // obtiene el controlador de la vista NewPopulationDialog NewPopulationDialogCtrl controller = dialog.getController(); // le pasa al controlador la provincia a la cual se le // agregará la población controller.setProvinceTargered(province); dialog.setVisible(true); }
Y en el controlador de NewPopulationDialog: public class NewPopulationDialogCtrl { private NewPopulationDialog gui; public NewPopulationDialogCtrl(NewPopulationDialog gui) { this.gui = gui; } public String getProvinceTarget () { return province; } public setProvinceTarget (String province ) { this.province = province; } /* En la vista obtenemos los datos de la nueva población y los asignamos a un objeto Population que se le pasa por parámetro a addPopulation para que lo guarde en el Map */ public void addPopulation(Population) { } // otros métodos... }
La vista NewPopulationDialog, debe asignar el nombre de la provincia en el label así: label.setText(controller.getProvinceTarget());
Saludos.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 27 Marzo 2015, 19:24 pm
(http://i.imgur.com/fSB2k1T.png) eso es lo que debe de salir, me sale todo menos donde estan los guiones que tiene que ir la provincia seleccionada esta es la clase principal: package principal; import java.awt.*; import java.awt.event.*; import Poblacion.VentanaBorrarPoblacion; import Poblacion.VentanaCrearPoblacion; import Provincia.VentanaBorrarProvincia; import Provincia.VentanaCrearProvincia; import paa.provincias.GestorAEMET; import paa.provincias.GestorAEMETException; import paa.provincias.IPoblacion; /** * Fichero: InterfazAWT_AEMET.java Clase que implementa la Interfaz Gráfica * AEMET con awt. * * @author PAA * @version 1.0 */ public class InterfazAWT_AEMET extends Frame { /** * */ private static final long serialVersionUID = 502635761186556414L; private static final String FICHERO = "almacen.dat"; private AlmacenPoblaciones almacen; // private IAlmacenPoblaciones almacenPoblaciones; private List listaPoblaciones = new List(); private List listaPredicciones = new List(); private List listaProvincias = new List(); private InterfazAWT_AEMET gui; /** * Constructor. * * @throws GestorAEMETException */ public InterfazAWT_AEMET (String titulo, int ancho, int alto ) { super(titulo); setSize(ancho, alto); setLocationRelativeTo(null); setLayout (new BorderLayout()); // Layout de la aplicación, podría ser otro almacen = RecuperarAlmacenPoblaciones(); System. out. println(almacen. getProvincias()); initComponents(); for(String provincia : almacen. getProvincias()){ listaProvincias.add(provincia); } //Imprimimos provincias y poblaciones en las listas } public AlmacenPoblaciones RecuperarAlmacenPoblaciones() { // Recuperamos el almacén AlmacenPoblaciones almacenPoblaciones1 = new AlmacenPoblaciones(); if (almacenPoblaciones1.recuperar(FICHERO)) System. out. println("Recuperado el almacen del fichero " + FICHERO ); else System. out. println("No se pudo recuperar el almacen del fichero "+ FICHERO ); return almacenPoblaciones1; } private void initComponents() { // Boton salir por defecto guardarAntesDeSalir(); } }); setMenuBar(addMenuBar()); } // Sitúo los menús desplegables // Creo el menú Archivo crearCargar.addActionListener(new Controller()); crearGuardar.addActionListener(new Controller()); salir.addActionListener(new Controller()); menuArchivo.add(crearCargar); menuArchivo.add(crearGuardar); menuArchivo.add(salir); // Creo el menú Provincias Menu menuProvincias = new Menu("Provincias"); crearProvincias.addActionListener(new Controller()); borrarProvincias.addActionListener(new Controller()); menuProvincias.add(crearProvincias); menuProvincias.add(borrarProvincias); // Creo el menu Poblaciones Menu menuPoblaciones = new Menu("Poblaciones"); crearPoblacion.addActionListener(new Controller()); borrarPoblacion.addActionListener(new Controller()); ordenarNombre.addActionListener(new Controller()); ordenarHabitantes.addActionListener(new Controller()); modPoblacion.addActionListener(new Controller()); movPoblacion.addActionListener(new Controller()); menuPoblaciones.add(crearPoblacion); menuPoblaciones.add(borrarPoblacion); menuPoblaciones.add(ordenarNombre); menuPoblaciones.add(ordenarHabitantes); menuPoblaciones.add(modPoblacion); menuPoblaciones.add(movPoblacion); // Creo el menú de ayuda acercaDe.addActionListener(new AcercaDe()); ayuda.add(acercaDe); // Crea el barraDeMenu.add(menuArchivo); barraDeMenu.add(menuProvincias); barraDeMenu.add(menuPoblaciones); // Sitúo el menú de ayuda en su sitio barraDeMenu.setHelpMenu(ayuda); return barraDeMenu; } private Panel addToolBar () { // Sitúo la línea de botones lineaDeBotones. setBackground(Color. lightGray); // Boton crear provincia proCrear.addActionListener(new Controller()); // Boton crear poblacion poCrear.addActionListener(new Controller()); // Boton actualizar prediccion aPrediccion.addActionListener(new Controller()); // Añadir los botones a la barra lineaDeBotones.add(proCrear); lineaDeBotones.add(poCrear); lineaDeBotones.add(aPrediccion); return lineaDeBotones; } private Panel addPanelIzquierda () { // Creamos panel para mostrar provincias y poblaciones y lo colocamos a // la izquierda izquierda.add(lProvincia); izquierda.add(listaProvincias); izquierda.add(lPoblacion); izquierda.add(listaPoblaciones); return izquierda; } private Panel addpredicciones () { // Creamos el panel de las predicciones Label lPrediccion = new Label("Predicciones de :"); return predicciones; } private Panel addlineaEstado () { // Sitúo la línea de estado lineaDeEstado. setBackground(Color. lightGray); Label ventanaDeeventos = new Label("Gestor AEMET v1.0 (PAA)"); lineaDeEstado.add(ventanaDeeventos); return lineaDeEstado; } private void guardarAntesDeSalir() { // Guardar almacen almacen.guardar(FICHERO); System. out. println("Gracias por utilizar nuestro programa"); } String nombre = e. getActionCommand(); EvaluarAccion(nombre); } public void EvaluarAccion (String accion ) { switch (accion) { case "Guardar": almacen.guardar(FICHERO); Aviso guardar = new Aviso(gui, "Archivo guardado"); break; case "Salir": break; case "Crear provincia": new VentanaCrearProvincia(gui,almacen,listaPoblaciones,listaProvincias,listaPredicciones).setVisible(true); break; case "Borrar provincia": new VentanaBorrarProvincia(gui,almacen,listaPoblaciones,listaProvincias,listaPredicciones).setVisible(true); break; case "Crear poblacion": new VentanaCrearPoblacion(gui,almacen,listaPoblaciones,listaProvincias,listaPredicciones).setVisible(true); break; case "Borrar poblacion": new VentanaBorrarPoblacion(gui,almacen,listaPoblaciones,listaProvincias,listaPredicciones).setVisible(true); break; case "Ordenar por nombre": break; case "Ordenar por habitantes": break; case "Modificar poblacion": break; case "Mover poblacion": break; } } } /** * Clase que implementa la acción del menú "acerca de". */ VentanaAcercaDe ventanaAcercaDe = new VentanaAcercaDe( InterfazAWT_AEMET.this); ventanaAcercaDe.setVisible(true); } }// Acerca de /** * Método main. * @throws GestorAEMETException */ public static void main (String[] args ) throws GestorAEMETException { InterfazAWT_AEMET mimarco = new InterfazAWT_AEMET("Gestor AEMET", 1000, 500); mimarco.setVisible(true); } // Main }
y esta la que se encarga de crear poblacion: package Poblacion; import java.awt.BorderLayout; import java.awt.Button; import java.awt.Dialog; import java.awt.FlowLayout; import java.awt.Frame; import java.awt.GridLayout; import java.awt.Label; import java.awt.List; import java.awt.Panel; import java.awt.TextField; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.ItemEvent; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; import principal.AlmacenPoblaciones; import principal.Aviso; public class VentanaCrearPoblacion extends Dialog { private AlmacenPoblaciones almacen; private List listaPoblaciones ; private List listaPredicciones ; private List listaProvincias ; private static final long serialVersionUID = 1434307119439314094L; public VentanaCrearPoblacion (Frame gui, AlmacenPoblaciones almacen, List listaPoblaciones, List listaProvincias, List listaPredicciones ) { super(gui); initComponents(gui); this.almacen = almacen; this.listaPoblaciones = listaPoblaciones; this.listaProvincias = listaProvincias; this.listaPredicciones = listaPredicciones; } public void initComponents (Frame gui ){ setLocationRelativeTo(gui); this.setTitle("Crear Poblacion"); this.setSize(300, 200); cancelar = new Button("Cancelar"); String textoProvincia = listaProvincias. getSelectedItem(); System. out. println(textoProvincia ); nombreP.setText(""); crear.addActionListener(new Controller()); cancelar.addActionListener(new Controller()); texto.add(textField); texto.add(nombreP); texto.add(habitantes); texto.add(codigo); panel.add(crear); panel.add(cancelar); VentanaCrearPoblacion.this.dispose(); } }); } private VentanaCrearPoblacion gui; String label = e. getActionCommand(); if(label.equals("Crear")){ try{ Aviso aviso = new Aviso(gui,e1.getMessage()); } }else{ VentanaCrearPoblacion.this.dispose(); } } } if((ev.getItem()).equals("Desayuno")){ } } }
este es el error que genera: at Poblacion.VentanaCrearPoblacion.initComponents(VentanaCrearPoblacion.java:51) at Poblacion.VentanaCrearPoblacion.<init>(VentanaCrearPoblacion.java:34) at principal.InterfazAWT_AEMET$Controller.EvaluarAccion(InterfazAWT_AEMET.java:231) at principal.InterfazAWT_AEMET$Controller.actionPerformed(InterfazAWT_AEMET.java:211) at java. awt. Button. processActionEvent(Unknown Source ) at java. awt. Button. processEvent(Unknown Source ) at java. awt. Component. dispatchEventImpl(Unknown Source ) at java. awt. Component. dispatchEvent(Unknown Source ) at java. awt. EventQueue. dispatchEventImpl(Unknown Source ) at java. awt. EventQueue. dispatchEvent(Unknown Source ) at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source) at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source) at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source) at java.awt.EventDispatchThread.pumpEvents(Unknown Source) at java.awt.EventDispatchThread.pumpEvents(Unknown Source) at java.awt.EventDispatchThread.run(Unknown Source)
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 27 Marzo 2015, 19:36 pm
El error es porque listaProvincias aún está null, ya que el método initComponents es ejecutado antes que se establezcan las propiedades con los valores de los parámetros. El constructor debería ser así: public VentanaCrearPoblacion (Frame gui, AlmacenPoblaciones almacen, List listaPoblaciones, List listaProvincias, List listaPredicciones ) { super(gui); this.almacen = almacen; this.listaPoblaciones = listaPoblaciones; this.listaProvincias = listaProvincias; this.listaPredicciones = listaPredicciones; initComponents(gui); }
Saludos.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: Usuario Invitado en 27 Marzo 2015, 21:02 pm
Perdón por el doble post, pero creo que así hay más probabilidades que el autor del tema me lea a que edite mi respuesta anterior.
Creo que ya es hora de cerrar éste tema, se ha desvirtuado mucho. Cualquier nueva duda kikian94, por favor abrirla en un nuevo tema. No olvides marcar este tema como solucionado.
Saludos.
Título: Re: Meter un Frame dentro de otro Frame
Publicado por: kikian94 en 28 Marzo 2015, 12:47 pm
si, tienes toda la razon, ya he conseguido solucionar el error, era por lo que decias :), muchas gracias por todo,que paciencia has tenido jeje
|