elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Únete al Grupo Steam elhacker.NET


  Mostrar Mensajes
Páginas: [1] 2 3
1  Programación / Programación C/C++ / Lectura ext3 con ext2fs en: 8 Agosto 2010, 23:52 pm
He logrado conseguir bastante informacion del superbloque, sin embargo, necesito identificar si el sistema de archivos es realmente ext3, ademas necesito leer el journaling. Si alguien tiene idea de como hacerlo se los agradecira.
2  Programación / Java / Re: imagen desde zip en: 25 Mayo 2009, 02:37 am
bueno, alli les va la solucion que encontre:

Código:
import javax.imageio.ImageIO;
import java.awt.Image;
import java.net.URL;
import java.net.MalformedURLException;
import java.io.IOException;

private static ImageIcon cargarImagen(String zip,String archivo){
try{
URL url = new URL("jar:file:/"+zip+"!/"+archivo);
Image img = ImageIO.read(url);
return new ImageIcon(img);
}
catch(MalformedURLException mue){
}
catch(IOException ioe){
}
return null;
}
3  Programación / Java / imagen desde zip en: 23 Mayo 2009, 07:02 am
buenas!!

Ya se como puedo ingresar a los zip pero al momento de usar una URL
Código:
jLabel.setIcon(new ImageIcon(new URL("jar:file:/pred.zip!/fondo.png")));

no me funciona, podria alguien decirme como hacer esto??

muchas gracias!!
4  Programación / Java / redimensionar video en JMF en: 18 Mayo 2009, 20:47 pm
buenas!!

para obtener el video lo hago de esta manera:
Código:
Component video = player.getVisualComponent();

como puedo redimensionar el video???
5  Programación / Java / jscrollpane y jpanel en: 6 Mayo 2009, 02:03 am
buenas!!  :D

Tengo un conjunto de botones en un JPanel, ademas un JList ambos los tengo agregados a un segundo JPanel y este lo coloco como jScrollPane.setViewportview(jPanel2), pero cuando a este ultimo le coloco jPanel2.setLayout(null); los scrolls del JScrollPane deja de aparecer...

tienen alguna solucion para esto??
6  Programación / Java / JList cambiando color a items en: 2 Mayo 2009, 20:25 pm
buenas!!

ahora mi problema es el siguiente:

Necesito poder cambiar el color de una fila especifica en un JList.

Para agregar a la lista utilizo ListCellRenderer asi coloco varias columnas, entonces tengo 2 JLabel agregados a 1 JPanel. Necesito cambiar el color del panel que se encuentra en la posicion indice dentro del JList.

alguna idea??
7  Programación / Java / Re: lista dinamica en: 2 Mayo 2009, 20:16 pm
 :laugh: gracias por la informacion seguramente en el futuro me servira.

En realidad tuve que hacerlo de esta manera pues me pedian como requisito de programacion que yo creara mi propia lista dinamica.
8  Programación / Java / informacion multimedia con JMF en: 2 Mayo 2009, 11:07 am
como puedo obtener la informacion de multimedia, por ejemplo el titulo, interprete, duracion, genero,etc. ya sea con JMF o cualquier otra cosa???
9  Programación / Java / Re: lista dinamica en: 2 Mayo 2009, 07:17 am
muchas gracias por sus respuestas...al final he entendido esto de crear nodos.

bueno he aqui el codigo que he generado

Lista.java
Código:
/**
 *@author Brian Estrada - USAC Guatemala
 */
import java.util.*;

public class Lista{
private Nodo lista;
private int tamano;

public Lista(){
lista = new Nodo();
tamano = 0;
}

public int getTamano(){
return tamano;
}

public void agregar(Object objeto){
Nodo padre = lista;
Nodo nuevo = new Nodo();

for (int i = 0;i<tamano;i++)
padre = padre.getHijo();

nuevo.setObjeto(objeto);
nuevo.setPadre(padre);
nuevo.getPadre().setHijo(nuevo);
tamano++;
}

public void agregar(Object objeto, int indice) throws NullPointerException{
Nodo padre = lista;
Nodo nuevo = new Nodo();

for (int i = 0;i<indice;i++)
padre = padre.getHijo();

nuevo.setObjeto(objeto);
nuevo.setPadre(padre);
nuevo.setHijo(padre.getHijo());
nuevo.getHijo().setPadre(nuevo);
nuevo.getPadre().setHijo(nuevo);
tamano++;
}

public void agregar(Lista lista){
if (lista.getTamano()>0){
Nodo padre = this.lista;

for (int i = 0;i<tamano;i++)
padre = padre.getHijo();

padre.setHijo(lista.getLista().getHijo());
padre.getHijo().setPadre(padre);

tamano += lista.getTamano();
}
}

public void agregar(Lista lista, int indice){
if (lista.getTamano()>0){
Nodo padre1 = this.lista;
Nodo padre2 = lista.getLista();

for (int i=0;i<indice;i++)
padre1 = padre1.getHijo();

for (int i=0;i<lista.getTamano();i++)
padre2 = padre2.getHijo();

padre2.setHijo(padre1.getHijo());
padre1.setHijo(lista.getLista().getHijo());
tamano += lista.getTamano();
}
}

public Object getObjeto(int indice) throws NullPointerException{
Nodo padre = lista;
for (int i=0;i<indice;i++)
padre = padre.getHijo();

return padre.getHijo().getObjeto();
}

public Nodo getLista(){
return lista;
}

public void setLista(Nodo lista, int tamano){
this.lista = lista;
this.tamano = tamano;
}

public Lista getSubLista(int indice, int tamano)throws Exception{
Lista lista = new Lista();
Nodo padre = this.lista;
Nodo aux;

for (int i = 0;i<indice;i++)
padre = padre.getHijo();

aux = (Nodo)padre.clone();
aux.setPadre(null);

padre = aux;

for (int i=0;i<tamano;i++)
padre = padre.getHijo();

padre.setHijo(null);

lista.setLista(aux,tamano);
return lista;
}

public void remover(int indice){
Nodo padre = lista;

for (int i = 0;i<indice;i++)
padre = padre.getHijo();

if (indice<(tamano-1)){
padre.getHijo().setObjeto(padre.getHijo().getHijo().getObjeto());
padre.getHijo().setHijo(padre.getHijo().getHijo().getHijo());
}
else
padre.setHijo(null);
--tamano;
}
public void remover(int indice,int tamano){
Nodo padre1 = lista;
Nodo padre2;

for (int i = 0;i<indice;i++)
padre1 = padre1.getHijo();

padre2 = padre1;

for (int i=0;i<tamano;i++)
padre2  = padre2.getHijo();

padre1.setHijo(padre2.getHijo());
this.tamano -= tamano;
}
public void removerTodo(){
lista.setHijo(null);
tamano = 0;
}
public void barajar(){
Random rnd = new Random();
Lista nuevaLista = new Lista();
int i;
while(tamano>0){
i = rnd.nextInt(tamano);
nuevaLista.agregar(getObjeto(i));
remover(i);
}
agregar(nuevaLista);
}


public void setOrden(Lista orden){
int posicion;
Lista lista = new Lista();
for (int i = 0;i<tamano;i++){
posicion = ((OrdenLista)orden.getObjeto(i)).getIndice();
lista.agregar(getObjeto(posicion));
}
removerTodo();
setLista(lista.getLista(),lista.getTamano());
}
}


class OrdenLista{
private int indice;
private int valor;
public OrdenLista(int valor,int indice){
this.indice =indice;
this.valor = valor;
}
public int getIndice(){
return indice;
}
public int getValor(){
return valor;
}

public static void ordenar(Lista lista,int inicio,int fin){
//quicksort
int i = inicio - 1;
int j = fin;
OrdenLista aux;

if (i>=j)
return;

int pivote = ((OrdenLista)lista.getObjeto(fin)).getValor();
while (true){
while (i<fin && ((OrdenLista)lista.getObjeto(++i)).getValor() < pivote);
while (j>inicio && ((OrdenLista)lista.getObjeto(--j)).getValor() > pivote);
if (i<j){
aux = (OrdenLista)lista.getObjeto(i);
lista.agregar(lista.getObjeto(j),i);
lista.remover(i+1);
lista.agregar(aux,j);
lista.remover(j+1);
}
else break;
}
aux = (OrdenLista)lista.getObjeto(i);
lista.agregar(lista.getObjeto(fin),i);
lista.remover(i+1);
lista.agregar(aux,fin);
lista.remover(fin+1);

ordenar(lista,inicio,i-1);
ordenar(lista,i+1,fin);
}
}


Nodo.java
Código:
/**
 *@author Brian Estrada - USAC Guatemala
 */
public class Nodo implements Cloneable {
private Nodo padre;
private Nodo hijo;
private Object objeto;

public Nodo(){
padre = null;
hijo = null;
objeto = null;
}
public Object getObjeto(){
return objeto;
}
public void setObjeto(Object objeto){
this.objeto = objeto;
}
public Nodo getPadre(){
return padre;
}
public void setPadre(Nodo padre){
this.padre = padre;
}
public Nodo getHijo(){
return hijo;
}
public void setHijo(Nodo hijo){
try{
if (hijo!=null)
this.hijo = (Nodo)hijo.clone();
else
this.hijo = null;
}
catch(CloneNotSupportedException e){
System.out.println("error en nodo");
}
}
public Object clone() throws CloneNotSupportedException{
Nodo clone = (Nodo)super.clone();
return clone;
}
}


Ejemplo:
Código:
Lista lista = new Lista();
    lista.agregar(new Cancion(1,"A"));
    lista.agregar(new Cancion(3,"B"));
    lista.agregar(new Cancion(2,"C"),1);
    lista.agregar(new Cancion(4,"D"));
   
    lista.barajar();
   
    Lista orden = new Lista();   
    for(int i=0;i<4;i++)
    orden.agregar(new OrdenLista(((Cancion)lista.getObjeto(i)).getDuracion(),i));
       
    OrdenLista.ordenar(orden,0,orden.getTamano()-1);
   
    for (int i = 0;i<lista.getTamano();i++)
    System.out.println(((Cancion)lista.getObjeto(i)).getTitulo());
   
    System.out.println();
   
    lista.setOrden(orden);
   
    System.out.println();
    for (int i = 0;i<lista.getTamano();i++)
    System.out.println(((Cancion)lista.getObjeto(i)).getTitulo());
   
  lista.remover(0,2);
 
  System.out.println();
    for (int i = 0;i<lista.getTamano();i++)
    System.out.println(((Cancion)lista.getObjeto(i)).getTitulo());


Explicacion:

Lista
Antes…
•   El tamaño esta dado desde 1, esto quiere decir que si contiene 5 elementos el tamaño será 5.
•   El índice inicia en 0, por lo tanto si contiene 5 elementos, para tener acceso al primero se hará con el índice 0 y para tener acceso al ultimo con índice 4.
agregar(Object objeto)
Se agregara el objeto al final del listado.
agregar(Object objeto,int indice)
Se agregara el objeto en el índice especificado.
agregar(Lista lista)
Se agrega una lista al final de la lista en la que se emplea este método.
agregar(Lista lista,int indice)
Se agrega una lista en el índice seleccionado de la lista en la que se emplea este método.
getObjeto(int indice)
Retorna el objeto que se encuentra en el índice seleccionado, y hace un retorno de tipo objeto al cual solo se le debe hacer un cast para poder emplearlo. Retorna Object.
getLista()
   Retorna el nodo lista donde se almacena toda la información. Retorna Nodo.
setLista(Nodo lista,int tamano)
Asigna a lista global la lista, y tamaño de la lista. Otra forma de agregar una lista que reemplaza a otra. Tienen un mejor desempeño.
getSubLista(int indice,int tamaño)
Retorna una sublista de la lista en la que se llama este método que va desde índice hasta índice+tamaño. Retorna tipo Lista.
remover(int índice)
   Remueve el objeto que ocupa la posición índice.
remover(int índice,int tamaño)
   Remueve todos los objetos comprendidos entre índice e índice+tamaño.
removerTodo()
   Elimina todos los objetos.
barajar()
   Reordena los objetos de forma aleatoria.
setOrden()
   Ordena los objetos como lo indique la clase OrdenLista.

OrdenLista
Antes…
•   El ordenamiento se efectúa de forma ascendente.
•   valor -  es el valor que se tomara como criterio de ordenamiento
•   índice - contiene el valor de índice que lleva el orden
ordenar(Lista lista, int inicio, int fin)
        Ordena la lista con el algoritmo de quicksort en versión de recursión.


les debo la explicacion de nodo, porque ya es muy tarde y tengo sueño...

aprovechenlo bien por favor, me tomo 2 dias de quebradera de cabeza.... ;-)
10  Programación / Java / lista dinamica en: 30 Abril 2009, 04:50 am
debo hacer un nuevo proyecto, reproductor.

en los requerimientos de programacion me han restringido el uso de vectores estaticos y objetos que permitan manejar arreglos dinamicos.

como seria un vector estatico y un arreglo dinamico??

bueno, y para reemplazar esto el enunciado dice que debo usar exclusivamente lista dinamica...

podria darme alguien un ejemplo de cada uno de estos...
Páginas: [1] 2 3
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines