Some Tips About Layout Resource
2016-12-15 18:10
471 查看
<?xml version="1.0" encoding="utf-8"?> <ViewGroup xmlns:android="http://schemas.android.com/apk/res/android" android:id="@[+][package:]id/resource_name" android:layout_height=["dimension" | "match_parent" | "wrap_content"] android:layout_width=["dimension" | "match_parent" | "wrap_content"] [ViewGroup-specific attributes] > <View android:id="@[+][package:]id/resource_name" android:layout_height=["dimension" | "match_parent" | "wrap_content"] android:layout_width=["dimension" | "match_parent" | "wrap_content"] [View-specific attributes] > <requestFocus/> </View> <ViewGroup > <View /> </ViewGroup> <include layout="@layout/layout_resource"/> </ViewGroup>
<1>
<include>
Includes a layout file into this layout.
attributes:
layoutLayout resource. Required. Reference to a layout resource.
android:idResource ID. Overrides the ID given to the root view in the included layout.
android:layout_heightDimension or keyword. Overrides the height given to the root view in the included layout. Only effective if
android:layout_widthis also declared.
android:layout_widthDimension or keyword. Overrides the width given to the root view in the included layout. Only effective if
android:layout_heightis also declared.
You can include any other layout attributes in the
<include>that are supported by the root element in the included layout and they will override
those defined in the root element.
Caution: If you want to override layout attributes using the
<include>tag, you must override both
android:layout_heightand
android:layout_widthin
order for other layout attributes to take effect.
Another way to include a layout is to use
ViewStub.
It is a lightweight View that consumes no layout space until you explicitly inflate it, at which point, it includes a layout file defined by its
android:layoutattribute. For more information about using
ViewStub,
read Loading Views On Demand.
Note: One drawback of
ViewStubis
that it doesn’t currently support the
<merge>tag in the layouts to be inflated.
<2>
<requestFocus>
Any element representing a
Viewobject can include this empty element, which
gives its parent initial focus on the screen. You can have only one of these elements per file.<3>
<3>
<merge>
An alternative root element that is not drawn in the layout hierarchy. Using this as the root element is useful when you know that this layout will be placed into a layout that already contains the appropriate parent View
to contain the children of the
<merge>element.
This is particularly useful when you plan to include this layout in another layout file using
<include>and
this layout doesn't require a different
ViewGroupcontainer. For
more information about merging layouts, read Re-using Layouts with <include/>.
From:https://developer.android.com/guide/topics/resources/layout-resource.html
============================================================================================================
Define a ViewStub
ViewStubis a lightweight view with no dimension that doesn’t draw anything or participate
in the layout. As such, it's cheap to inflate and cheap to leave in a view hierarchy. Each
ViewStubsimply
needs to include the
android:layoutattribute to specify the layout to inflate.
The following
ViewStubis for a translucent progress bar overlay. It should be visible
only when new items are being imported into the application.
<ViewStub android:id="@+id/stub_import" android:inflatedId="@+id/panel_import" android:layout="@layout/progress_overlay" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_gravity="bottom" />
Load the ViewStub Layout
When you want to load the layout specified by theViewStub, either set it visible by calling
setVisibility(View.VISIBLE)or
call
inflate().
findViewById(R.id.stub_import)).setVisibility(View.VISIBLE); // or View importPanel = ((ViewStub) findViewById(R.id.stub_import)).inflate();
Note: The
inflate()method returns the inflated
Viewonce
complete. so you don't need to call
findViewById()if you need to interact
with the layout.
Once visible/inflated, the
ViewStubelement
is no longer part of the view hierarchy. It is replaced by the inflated layout and the ID for the root view of that layout is the one specified by the
android:inflatedIdattribute of the ViewStub. (The ID
android:idspecified
for the
ViewStubis valid only until the
ViewStublayout
is visible/inflated.)
Note: One drawback of
ViewStubis
that it doesn’t currently support the
<merge>tag in the layouts to be inflated.
From: https://developer.android.com/training/improving-layouts/loading-ondemand.html
相关文章推荐
- Some tips about SoapUI project
- some tips about python Three
- MaxPooling的作用 and some tips about CNN
- Some tips about how to reverse Array with C#
- Some tips about looping statement
- 通过HTTP压缩来提高WebService性能的一些好资源(some good resource about WebService with HTTP-Compression )
- Some tips about crawling large external data with bcs connector
- About GNIT some tips
- some tips about python Four
- some tips about web hacking
- Some tips about argument in python
- some tips about python Six
- some resource about 'Better, Faster, Lighter Java'
- Some tips about python Seven
- Some basic tips about 'git stash'
- some tips about sys.objects table
- Some tips about Abstract base classes and pure virtual functions
- Some useful tips about sox rec
- some tips about python
- ASP.NET 事件日历(some resource about Event Calendar)