标签:演示 时间 spec launch 分享 程序 图片 文件 字体
转载请注明出处:http://blog.csdn.net/lhy_ycu/article/details/39643669
LinearLayout是Android控件中的线性布局控件,它包括的子控件将以横向(HORIZONTAL)或竖向(VERTICAL)的方式排列,依照相对位置来排列全部的子控件及引用的布局容器。
超过边界时,某些控件将缺失或消失。
因此一个垂直列表的每一行仅仅会有一个控件或者是引用的布局容器。
一、LinearLayout线性布局的相关属性说明:
android:orientation 布局方向:"vertical"垂直线性布局,"horizontal"水平线性布局
android:id 为控件指定对应的ID
android:text 指定控件其中显示的文字。须要注意的是,这里尽量使用strings.xml文件其中的字符
android:grivity 指定控件的基本位置。比方说居中,居右等位置
android:textSize 指定控件其中字体的大小
android:background 指定该控件所使用的背景色,RGB命名法
android:width 指定控件的宽度
android:height 指定控件的高度
android:padding 指定控件的内边距,也就是说控件其中的内容
android:singleLine 假设设置为真的话,则将控件的内容在同一行其中进行显示
android:layout_weight 默认值为0,layout_weight属性能够控制各个控件在布局中的相对大小,线性布局会依据该控件layout_weight值与其· 所处布局中全部控件layout_weight值之和的比值为该控件分配占用的区域。
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Hello!" android:textSize="20sp" /> </LinearLayout>
<MainActivity.java>
</pre><pre name="code" class="java">/** * @author liu * @description 代码动态创建线性布局管理器 */ public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // setContentView(R.layout.main); LinearLayout layout = new LinearLayout(this);// 创建现行布局管理器 LinearLayout.LayoutParams params = new LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);// 设置线性布局參数 layout.setOrientation(LinearLayout.VERTICAL); TextView txt = new TextView(this); LinearLayout.LayoutParams txtParams = new LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);// 设置组件參数 txt.setLayoutParams(txtParams); txt.setText("Hello!"); txt.setTextSize(20); layout.addView(txt, txtParams); addContentView(layout, params); } }
public class MyLinearLayout extends LinearLayout { /** * 在xml布局文件里声名的view,创建时由系统自己主动调用。 */ public MyLinearLayout(Context context, AttributeSet attrs) { super(context, attrs); initView(); } /** * 初始化LinearLayout视图 */ private void initView() { // 设置LinearLayout的布局方向 setOrientation(LinearLayout.VERTICAL); // 设置布局參数 LinearLayout.LayoutParams params = new LayoutParams( LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT); TextView tv = new TextView(getContext()); tv.setText(R.string.hello_world); // 在MyLinearLayout里面加入TextView addView(tv, params); for (int i = 0; i < 10; i++) { ImageView iv = new ImageView(getContext()); iv.setImageResource(R.drawable.ic_launcher); Animation animation1 = AnimationUtils.loadAnimation(getContext(), R.anim.rotate); iv.setAnimation(animation1); // 在MyLinearLayout里面加入10个带动画的ImageView addView(iv, params); } } /** * 对子view进行布局,确定子view的位置 */ @Override protected void onLayout(boolean changed, int l, int t, int r, int b) { super.onLayout(changed, l, t, r, b); } /** * 測量尺寸时的回调方法 */ @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(widthMeasureSpec, heightMeasureSpec); } }
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <com.liu.mylinearlayout01.MyLinearLayout android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout>
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true" android:fillBefore="false" > <!-- 旋转效果,pivotX,pivotY指旋转坐标; fillAfter="true" fillBefore="false" 表示动画停止在最后的位置; fromDegrees toDegrees从0°到350° startOffset:延时1s运行 duration:动画运行时间3s repeatCount: 反复次数3+1 --> <rotate android:duration="3000" android:fromDegrees="0" android:pivotX="50%p" android:pivotY="20%p" android:repeatCount="3" android:startOffset="1000" android:toDegrees="350" /> </set>
以上就是笔者知道的LinearLayout的三种实现基本方式。
Android学习系列(二)布局管理器之线性布局的3种实现方式
标签:演示 时间 spec launch 分享 程序 图片 文件 字体
原文地址:http://www.cnblogs.com/claireyuancy/p/6791983.html