Ir al contenido principal

R.java, la librería que no se toca.

Como ya hemos visto en varios proyectos, si has curioseado un rato, observaste que la librería R.java, al momento de modificarla, eclipse nos lanza una advertencia diciendo que no se puede modificar y que REGRESARA a los valores que tenia anteriormente.

Al principio es algo chistoso, porque piensas: “¿Por qué pasa esto? ¿Si no la puedo modificar a mano, entonces como?”. Esa es la pregunta que responderemos en esta entrada.

Android nos permite definir una serie de recursos para facilitar  la creación de aplicaciones. Pero, ¿que es un recurso? ¿Que tipo de recursos?. Bueno, en Android un recurso es un archivo (como uno de música), el titulo de un dialogo cualquier cosa que este ligado a una aplicaciones ejecutable, estos archivos podemos cambiarlos sin necesidad de recompilar la aplicación. ¿Interesante no?

Recurso “string” y su efecto en R.java

Android permite definir strings en uno o MAS archivos XML de recursos. Estos archivos están bajo el directorio /res/values. El nombre del archivo XML para este tipo de recursos pueden ser cualquiera, pero por convención se suele llamar strings.xml.

Veamos el ejemplo que trae Android por default.


    Hello World, PoderosoActivity!
    Poderoso



Cuando este archivo se crea o se modifica, el plugin ADT de eclipse automáticamente actualizará la clase R.java de nuestra aplicación que se encuentra en el directorio /gen, que contiene los ID’s únicos para las cadenas que se crean.

package el.poderoso.unico;

public final class R {
    public static final class attr {
    }
    public static final class drawable {
        public static final int ic_launcher=0x7f020000;
    }
    public static final class layout {
        public static final int main=0x7f030000;
    }
    public static final class string {
        public static final int app_name=0x7f040001;
        public static final int hello=0x7f040000;
    }
}
Como vemos como primero R.java define una clase principal en el paquete raiz: public final class R. Depues, define una clase interna llamada public static final class string. R.java crea esta clase estática interna como espacio de nombres para guardar los IDs de los recursos string.

La definición de los dos public static final int llamados app_name y hello son los IDs de los recursos que representan nuestras cadenas de texto. Podemos usar estos IDs en cualquier lugar de nuestro código mediante R.string.hello o R.string.app_name

Ahora agreguemos unas líneas de código para ver que pasa

strings.xml 

    Hello World, PoderosoActivity!
    Poderoso
    Hello, this is a test!
    Maximo


R.java

package el.poderoso.unico;

public final class R {
    public static final class attr {
    }
    public static final class drawable {
        public static final int ic_launcher=0x7f020000;
    }
    public static final class layout {
        public static final int main=0x7f030000;
    }
    public static final class string {
        public static final int app_name=0x7f040001;
        public static final int app_name1=0x7f040003;
        public static final int hello=0x7f040000;
        public static final int hello1=0x7f040002;
    }
}
Y así es como se debe modificar R.java, eclipse por las malas o por las buenas nunca te dejara modificarla a mano. Siempre tendremos que modificar los XML de la aplicación.

Comentarios

Publicar un comentario

Entradas populares de este blog

Pequeño Juego con LEDS y Dip Switch

Siguiendo con los mini-proyectos, lo que quería hacer originalmente era un tipo "candado" con push-button y LEDs, el objetivo seria, meter la combinacion de botones correcta y los LEDS encendería por un motivo practico, en forma de serpiente. El objetivo no cambio, pero por falta de "material" lo hice con un dip switch de X entradas(depende de que tan grande quieras la combinación). CONOCIMIENTOS(max. 7 estrellas): Electronica:     ★ ★ Programación: ★ ★ Juego de Combinación + LEDs El programa es un poco mas complicado que el mini-proyecto pasado , pero aun asi es basico. Guardamos las salidas de los LEDs en un arreglo, despues con los valores recibidos y comparados de los dip switch jugamos con los LEDś. Hardware Requerido (1) Arduino Uno (6) LED (8) Resistencias 330 Ω (1) Dip Switch Circuito Usamos las salidas del ARduino 2-7 para los LEDS Usamos la salida A5, A4 para el dip switch Para hacer prender los LEDS tienes que encontrar la

Tarea #5 - Codigo Hamming - Python

Codigo hamming Liga al repo Teoria segun wikipedia Antes de los códigos Hamming se utilizaron ciertos códigos detectores de error, como lo fueron el código linteing, pero ninguno llegó a ser tan eficaz como los de Hamming. A continuación se describen algunos de estos códigos. Paridad   La   paridad   consiste en añadir un bit, denominado   bit de paridad , que indique si el número de los bits de valor 1 en los datos precedentes es par o impar. Si un solo bit cambiara por error en la transmisión, el mensaje cambiará de paridad y el error se puede detectar (nótese que el bit donde se produzca el error puede ser el mismo bit de paridad). La convención más común es que un valor de paridad   1   indica que hay un número impar de unos en los datos, y un valor de paridad de   0   indica que hay un número par de unos en los datos. info. completa y un vídeo que me ayudo mucho para esta tarea: (TIENEN QUE VERLO - OBLIGATORIO) http://www.youtube.com/watch?v=xiDPFm9PeLU Impleme

Potenciometro + pushboton + led

Bueno, estos días he estado practicando con los ejemplos de la pagina de Arduino , algunos que me llamaron la atención los voy a compartir, por supuesto con modificaciones. Nivel de conocimientos: Electronica:        ★   Programació n :    ★    Potenciometro + push-boton = LEDintensidad El mini-proyecto es controlar la intensidad de un LED mediante un potenciometro el cual combinado con push-botton para prenderlo o apagarlo. Hardware Requerido (1) Arduino UNO (1) Potenciometro (1) Push-boton (1) LED (1) Resistencia 330 Ω Circuito Conectamos el LED al PIN 9 del Arduino Conectamos el PUSH_BOTON al PIN ANOLOGICO 0 (A0) Conectamos el POTENCIOMETRO al PIN ANOLOGICO 1 (A1) El funcionamiento del circuito es basico, mientras tengas pulsado el Push-Boton el LED se mantendrá encendido y con el pontenciometro controlas la intensidad del LED. Código Video