Welcome to the Treehouse Community

Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.

Looking to learn something new?

Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.

Start your free trial

Android Build an Interactive Story App (Retired) User Input Using RelativeLayouts and ImageViews

Rashad Hill
Rashad Hill
1,708 Points

Question regarding syntax of xml code

The challenge asked me to use "@id" as opposed to "@+id" and I see some parts of the code that uses the latter as opposed to the former, what's the difference?

activity_main.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <EditText
        android:id="@+id/captionField"
        android:layout_alignParentTop="true"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:hint="Enter a caption" />

    <ImageView
        android:id="@+id/imageView1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:src="@drawable/grumpy_cat"
        android:layout_below="@id/captionField"/>

</RelativeLayout>

@+id is used to define a new identifier and must be used at the first occurrence of each identifier in the layout. @id simply references an existing identifier and should be used for all subsequent instances of that identifier.

1 Answer

@+id: is used when we have to create an id and add it to the R file for the first time for a new element. @id if an id has already been created. As shown in the code snippet above @+id : <EditText android:id="@+id/captionField" when creating id for this EditText to be referred from here onwards.

Inside ImageView android:layout_below="@id/captionField"/> this line now just referring to the id captionField and not creating it again to be added to R file