Android動態(tài)布局使用詳解
本文為大家分享了Android動態(tài)布局的實現(xiàn)代碼,供大家參考,具體內(nèi)容如下
內(nèi)容如下:介紹多種實現(xiàn)動態(tài)布局的方法,以及如何用代碼來調(diào)整View位置
這里只介紹三種布局情況(注意不是方式)
1、無xml : 一個父類布局包含一個子父類布局,子父類布局中包含ImageView
2、無xml : 只有一個父類布局包含一個ImageView
3、有xlm布局: 通過布局ID 來進行動態(tài)布局添加
總結(jié)了下其實步驟如下:
無xml布局:
1、setContentView()之前new一個需要的布局layout,再將layout放入setContentView()
2、new 出需要的控件設(shè)置好參數(shù)(id、text···)
3、new LayoutParams 設(shè)置好控件的大小、位置屬性(這里感覺和xml設(shè)置控件屬性是一樣的)
4、最后將params和控件放入之前new的layout即可
有xml布局:
1、setContentView()和以前一樣放入layout.xml
2、通過findViewById()找到要進行添加的布局控件
之后的步驟和無xml布局的2、3、4一樣
代碼如下:
1、無xml : 一個父類布局包含一個子父類布局,子父類布局中包含ImageView
RelativeLayout relativeLayout = new RelativeLayout(this); setContentView(relativeLayout); RelativeLayout rl = new RelativeLayout(this); rl.setId(11); ImageView imageView = new ImageView(this); imageView.setId(1); imageView.setImageResource(R.mipmap.ic_launcher); RelativeLayout.LayoutParams lpRl = new RelativeLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT); rl.setGravity(RelativeLayout.CENTER_IN_PARENT); //設(shè)置imageView 在 rl中的位置為居中 rl.addView(imageView, lpRl); RelativeLayout.LayoutParams lpParent = new RelativeLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT); relativeLayout.addView(rl,lpParent);
2、無xml : 只有一個父類布局包含一個ImageView
RelativeLayout relativeLayout = new RelativeLayout(this); setContentView(relativeLayout); ImageView imageView = new ImageView(this); imageView.setId(2); imageView.setImageResource(R.mipmap.ic_launcher); //params 可以理解為 imageView的位置、大小參數(shù)集合 RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT); params.addRule(RelativeLayout.CENTER_IN_PARENT); relativeLayout.addView(imageView,params);
3、有xlm布局: 通過布局ID 來進行動態(tài)布局添加
public class ThirdActivity extends AppCompatActivity { private LinearLayout mLinearLayout; @Override protected void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_third); mLinearLayout = (LinearLayout) findViewById(R.id.linear_layout); ImageView imageView = new ImageView(this); imageView.setImageResource(R.mipmap.ic_launcher); imageView.setId(31); LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT); params.setMargins(150, 80, 10, 0); mLinearLayout.addView(imageView, params); } }
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/linear_layout" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> </LinearLayout>
是不是很簡單啊,了解到原理后對以后一些需要動態(tài)變化的布局操作起來就十分的方便了。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
flutter FadeTransition實現(xiàn)透明度漸變動畫
這篇文章主要為大家詳細介紹了flutter FadeTransition實現(xiàn)透明度漸變動畫,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-07-07Android使用SharedPreferences存儲XML文件的實現(xiàn)方法
這篇文章主要介紹了Android使用SharedPreferences存儲XML文件的實現(xiàn)方法,實例分析了SharedPreferences類的基本初始化與文件存儲相關(guān)技巧,需要的朋友可以參考下2016-07-07Kotlin + Flow 實現(xiàn)Android 應用初始化任務(wù)啟動庫
這篇文章主要介紹了Kotlin + Flow 實現(xiàn)Android 應用初始化任務(wù)啟動庫的方法,幫助大家更好的理解和學習使用Android,感興趣的朋友可以了解下2021-03-03Android 網(wǎng)絡(luò)圖片查看顯示的實現(xiàn)方法
本篇文章小編為大家介紹,Android 網(wǎng)絡(luò)圖片查看顯示的實現(xiàn)方法,需要的朋友參考下2013-04-04