当前位置: 首页 > 编程笔记 >

基于Android代码实现常用布局

司寇苗宣
2023-03-14
本文向大家介绍基于Android代码实现常用布局,包括了基于Android代码实现常用布局的使用技巧和注意事项,需要的朋友参考一下

关于 android 常用布局,利用 XML 文件实现已经有很多的实例了。但如何利用代码实现呢?当然利用代码实现没有太大的必要,也是不提倡的,但我觉得利用代码实现这些布局,可以更好的了解 SDK API ,所以在此也整理一些,和大家分享一下。

首先看一下,布局所对应的类的 API 继承图:

android常用布局的代码实现所有的布局都会对应相关的类,这些类都是继承自 android.view.ViewGroup 类的。而 LinearLayout,RelativeLayout 都是在 android.widget 包里的。另外,TableLayout 是继承自 LinearLayout.

下面直接贴代码了。

// 利用代码设置 线性布局
 private void setLinearLayout(){
  LinearLayout llayout = new LinearLayout(this);
  llayout.setOrientation(LinearLayout.VERTICAL); // 设置线性布局的排列方式
  TextView textView = new TextView(this);
  textView.setText("代码实现的线性布局");
  textView.setTextColor(Color.RED);
  textView.setGravity(Gravity.CENTER); // 设置文本内容的对齐方式
  LinearLayout.LayoutParams ll_lpara = new LinearLayout.LayoutParams(MP,WC);
//  ll_lpara.gravity = Gravity.CENTER_HORIZONTAL; // 设置控件在布局中的对齐方式
  llayout.addView(textView,ll_lpara);
  Button btn = new Button(this);
  btn.setText("按钮");
  llayout.addView(btn,ll_lpara); // 按指定属性添加控件
  setContentView(llayout);  
 }

实现效果图:

=========================================================================

// 利用代码设置 相对布局
 private void setRelativeLayout(){
  RelativeLayout rlayout = new RelativeLayout(this);
  rlayout.setPadding(10, 10, 10, 10); // 单位: pixels
  int textViewID = 100;
  TextView textView = new TextView(this);
  textView.setId(textViewID);
  textView.setText("请输入:");
  RelativeLayout.LayoutParams rl_lpara1 = new RelativeLayout.LayoutParams(MP, WC);
  rlayout.addView(textView, rl_lpara1);
  int editTextID = 200;
  EditText editText = new EditText(this);
  editText.setId(editTextID);
  editText.setBackgroundResource(android.R.drawable.editbox_background); // 设置背景 , 同android:backgroumd
  RelativeLayout.LayoutParams rl_lpara2 = new RelativeLayout.LayoutParams(MP, WC);
  rl_lpara2.addRule(RelativeLayout.BELOW,textViewID); // 设置相对属性,需先指定相对控件的ID
  rlayout.addView(editText, rl_lpara2);  
  int backBtnID = 300;
  Button backBtn = new Button(this);
  backBtn.setId(backBtnID);
  backBtn.setText("返回");
  RelativeLayout.LayoutParams rl_lpara3 = new RelativeLayout.LayoutParams(WC, WC);
  rl_lpara3.addRule(RelativeLayout.BELOW, editTextID);
  rl_lpara3.addRule(RelativeLayout.ALIGN_PARENT_RIGHT); // 设置与父控件的相对属性
  rlayout.addView(backBtn, rl_lpara3);
  Button okBtn = new Button(this);
  okBtn.setText("确定");
  RelativeLayout.LayoutParams rl_lpara4 = new RelativeLayout.LayoutParams(WC, WC);
  rl_lpara4.addRule(RelativeLayout.LEFT_OF, backBtnID);
  rl_lpara4.addRule(RelativeLayout.ALIGN_TOP,backBtnID);
  rlayout.addView(okBtn, rl_lpara4);
  setContentView(rlayout);
 }

实现效果图:

=========================================================================

// 利用代码设置 表格布局
 private void setTableLayout(){
  TableLayout tlayout = new TableLayout(this);
  tlayout.setColumnStretchable(2, true); // 拉长索引从0开始的第2列
  TableLayout.LayoutParams tl_lpara = new TableLayout.LayoutParams(MP,WC);
  // 1. TableRow 不需要设置 layout_width, layout_height
  // 2. TableRow 中的控件不能设置 layout_span 属性
  TableRow tr1 = new TableRow(this); 
  TextView textView0 = new TextView(this);
  textView0.setText("第0列");
  tr1.addView(textView0);  
  TextView textView1 = new TextView(this);
  textView1.setText("第1列");
  tr1.addView(textView1);  
  TextView textView2 = new TextView(this);
  textView2.setText("第2列");
  textView2.setBackgroundColor(Color.CYAN);
  tr1.addView(textView2);   
  tlayout.addView(tr1, tl_lpara); 
  TableRow tr2 = new TableRow(this);
  Button btn0 = new Button(this);
  btn0.setText("按钮0");
  tr2.addView(btn0);  
  Button btn1 = new Button(this);
  btn1.setText("按钮1");
  tr2.addView(btn1);  
  Button btn2 = new Button(this);
  btn2.setText("按钮2");
  tr2.addView(btn2); 
  Button btn3 = new Button(this);
  btn3.setText("按钮3");
  tr2.addView(btn3);
  tlayout.addView(tr2, tl_lpara);
  setContentView(tlayout);  
 }

实现效果图:


 类似资料:
  • 本文向大家介绍jQuery组件easyui基本布局实现代码,包括了jQuery组件easyui基本布局实现代码的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了 效果图: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 本文向大家介绍基于jquery实现瀑布流布局,包括了基于jquery实现瀑布流布局的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家介绍了基于jquery实现瀑布流布局的关键代码,分享给大家供大家参考,具体内容如下 效果图: 具体代码: 使用jquery-1.8.3.min.js,waterfall.js代码如下: 希望本文所述对大家学习有所帮助,谢谢大家的阅读。

  • 本文向大家介绍基于JavaScript实现轮播图代码,包括了基于JavaScript实现轮播图代码的使用技巧和注意事项,需要的朋友参考一下 一、要点: 1.页面加载时,图片重合,叠在一起[绝对定位]; 2.第一张显示,其它隐藏; 3.设置下标,给下标设置颜色让它随图片移动; 4.鼠标移动到图片上去,显示左右移动图标,鼠标移走,继续轮播; 二、实现代码: html代码: css代码: js代码: 以

  • 本文向大家介绍基于C++实现的线程休眠代码,包括了基于C++实现的线程休眠代码的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了基于C++实现的线程休眠代码,分享给大家供大家参考。具体方法如下: linux平台示例如下: 编译代码如下: boost库实现示例如下: 编译命令如下: 希望本文所述对大家的C++程序设计有所帮助。

  • 本文向大家介绍java基于swing实现的连连看代码,包括了java基于swing实现的连连看代码的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了java基于swing实现连连看代码。分享给大家供大家参考。 主要功能代码如下:

  • 本文向大家介绍jQuery基于ajax实现星星评论代码,包括了jQuery基于ajax实现星星评论代码的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jQuery基于ajax实现星星评论代码。分享给大家供大家参考。具体如下: 这里使用jquery模仿点评网的星星评论功能,Ajax评论模块,鼠标点击星星即可评价,下边是分数,可以点击后给分,网上很流行的效果,本代码相对完整,相信很多朋友会喜欢