Código de Java - Usar AbstractListModel

Imágen de perfil
Val: 492
Bronce
Ha aumentado 1 puesto en Java (en relación al último mes)
Gráfica de Java

Usar AbstractListModelgráfica de visualizaciones


Java

Publicado el 26 de Mayo del 2019 por Rafael Angel (81 códigos)
2.032 visualizaciones desde el 26 de Mayo del 2019
Se demuestra en forma simple el uso de la clase AbstractListModel.
Sirve para cargar una lista de datos.
Esta misma implementación se usará en otro proyecto futuro para demostrar el uso de Tablas de prioridad (PriorityQueue).

AbstractListModel

Requerimientos

Cualquier compilador Java.

1.0

Publicado el 26 de Mayo del 2019gráfica de visualizaciones de la versión: 1.0
2.033 visualizaciones desde el 26 de Mayo del 2019
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

Es un formulario en el cual se ven los efectos de AbstractListModel en la forma visual de un JList.
Este class ya implementado se pasa por propiedad con JList.setModel(new AbstractListModel(){...});
En mi ejemplo yo no realizo la implementación en forma anónima sino que creo un class real.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.AbstractListModel;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JList;
import javax.swing.JScrollPane;
import javax.swing.JTextField;
 
/**
 * 
 * @author Rafael Angel montero Fernández
 * Correo: Sharkyc12@gmail.com
 */
public class UsandoAbstractListModel {
 
    private Formulario frm=new Formulario();
 
    public void ver(){
        frm.setVisible(true);
    }
    public static void main(String args[]){
        UsandoAbstractListModel ejemplo=new UsandoAbstractListModel();
        ejemplo.ver();
    }
 
    public UsandoAbstractListModel(){
 
    }
 
    public class Formulario extends JFrame{
        /**
         * Recordar que a la lista hay que agregarle un JScroll...
         */
        private JList<String> jlstDatos= new JList<>();
        private JScrollPane jScrollPaneDatos=new JScrollPane();
        private JTextField jtCampo=new JTextField();
        private JLabel jlTexto_a_Agregar=new JLabel("Escriba datos"), jlLista=new JLabel("Lista de datos");
        private JButton jbAdd=new JButton("Add");
        private ModeloList modelo_list=new ModeloList();
        private Eventos evt=new Eventos();
 
        public Formulario(){
            inicio();
        }
 
 
        public void inicio(){
            setDefaultCloseOperation(EXIT_ON_CLOSE);
            this.setTitle("Ejemplo AbstractListModel");
            this.setBounds(100, 100, 350, 250);
            getContentPane().setLayout(null);
            setResizable(false);
////            jlstDatos.setBounds(150, 100, 155, 100); No es necesario, ya el ScrollPane tiene el setBounds.
            jScrollPaneDatos.setBounds(10, 100, 155, 100);
            jlstDatos.setModel(new ModeloList());
            this.add(jlstDatos);
            jlLista.setBounds(10, 70, 100, 25);
            jlstDatos.setAutoscrolls(true);
            jlTexto_a_Agregar.setBounds(10, 0, 100, 25);
            jtCampo.setBounds(10, 30,150, 30);
            jbAdd.setBounds(165, 30,150, 30);
            jbAdd.addActionListener(evt);
            add(jlTexto_a_Agregar);
            add(jbAdd);
            add(jtCampo);
            add(jlLista);
            jScrollPaneDatos.setViewportView(jlstDatos);
 
            add(jScrollPaneDatos);
        }
        public class Eventos implements ActionListener{
            /**
             * Se guardan los datos ceparados con un espacio.
             */
            private String datos_planos="";
            /**
             * Se usa split para cargar el vector desde datos_planos.
             */
            private String mDatos[]={};
 
            public void click_add(ActionEvent e) {
//                jtCampo.setText(e.getActionCommand());
                if(e.getActionCommand().equalsIgnoreCase(jbAdd.getText())==true){
                    if(datos_planos.isEmpty()==true){
                        this.datos_planos=jtCampo.getText();
                    }else{
                        datos_planos+=" " + jtCampo.getText();
                    }
                    this.mDatos=this.datos_planos.split(" ");
                    modelo_list=new ModeloList(mDatos);
                    jlstDatos.setModel(modelo_list);
                    jtCampo.setText("");
                }
            }
 
            @Override
            public void actionPerformed(ActionEvent e) {
                this.click_add(e);
            }
 
        }
 
    }
 
    /**
     * Class que implementa AbstractListModel; en su parametro de la plantilla se puede poner cualquier objeto:
     * String, int, double, Object...
     */
    public class ModeloList extends AbstractListModel<String>{
 
        public ModeloList(){
            super();
            String m[]={"Hola", "Usando", "AbstractListModel"};
            add(m);
        }
        /**
         * Constructor para cargar el vector de una vez.
         * @param mNuevos_datos Acepta un vector String.
         */
        public ModeloList(String mNuevos_datos[]){
            super();
            add(mNuevos_datos);
        }
 
        /**
         * Vector local de datos.
         */
        private String mDatos[]={};
 
        /**
         * Para agregar un vector externo cargado de datos.
         * @param mNuevos_datos 
         */
        public void add(String mNuevos_datos[]){
            mDatos=mNuevos_datos;
 
        }
        @Override
        public int getSize() {
            return mDatos.length;
        }
 
        @Override
        public String getElementAt(int index) {
            return mDatos[index];
        }
    }
}



Comentarios sobre la versión: 1.0 (0)


No hay comentarios
 

Comentar la versión: 1.0

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad

http://lwp-l.com/s5329