layout 布局_layout margin

layout 布局_layout marginLayoutParams布局

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

AbsoluteLayout.LayoutParams可以重新设置坐标,然后调用setLayoutParams
LinearLayout.LayoutParams可以调用setMargins();来移动控件位置
比如在调用rootLayout.addView(view2);后面再加上
        LinearLayout.LayoutParams param3 = new LinearLayout.LayoutParams(50, 50);
        param3.setMargins(-200, 300, 0, 0);
        view2.setLayoutParams(param3);

 

///

view = new FrameLayout(activity);
  view.setOnTouchListener(otListener);
  
  // keyboard
  LinearLayout keyboard = new LinearLayout(activity);
  keyboard.setBackgroundResource(R.drawable.skb_back);
  keyboard.setOrientation(LinearLayout.VERTICAL);
  keyboard.setPadding(0, 4, 0, 6);
  FrameLayout.LayoutParams lp = new FrameLayout.LayoutParams(
    LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT);
  lp.gravity = Gravity.BOTTOM;
  keyboard.setLayoutParams(lp);
  view.addView(keyboard);
  
  tvKeys = new TextView[4][];
  tvKeys[0] = new TextView[10];
  tvKeys[1] = new TextView[9];
  tvKeys[2] = new TextView[9];
  tvKeys[3] = new TextView[5];
  LinearLayout.LayoutParams lineLp = new LinearLayout.LayoutParams(
    LayoutParams.FILL_PARENT, keyHeight);
  lineLp.setMargins(0, 9, 0, 8);
  for (int i = 0; i < tvKeys.length; i++) {

   LinearLayout llLine = new LinearLayout(activity);
   llLine.setLayoutParams(lineLp);
   for (int j = 0; j < tvKeys[i].length; j++) {

    LinearLayout.LayoutParams keyLp = new LinearLayout.LayoutParams(
      keyWidth, LayoutParams.FILL_PARENT);
    keyLp.setMargins(4, 0, 4, 0);
    tvKeys[i][j] = new TextView(activity);
    tvKeys[i][j].setBackgroundResource(R.drawable.skey_normal_back);
    tvKeys[i][j].setGravity(Gravity.CENTER);
    tvKeys[i][j].setText(keys[state][i][j]);
    tvKeys[i][j].setTextColor(0xffffffff);
    tvKeys[i][j].setTextSize(20);
    tvKeys[i][j].setLayoutParams(keyLp);
    llLine.addView(tvKeys[i][j]);
   }
   keyboard.addView(llLine);
  }

 

 

 

Android笔记之一:adapter

    

先从ListAdapter说起吧。什么是ListAdapter?

ListAdapter继承于Adapter,它是ListView和其里边数据的适配器。也就是要让一个ListView现实出来。为此需要3个东西。

 

 

ListView(需要被显示的列表)

Data,和ListView绑定的数据,一般是一个Cursor或者一个字符串数组。

ListAdapter,是data和ListView的桥梁,其一个适配作用。

 

Adapter 的数据源有三种

 

ArrayAdapter

ListAdapter

SimpleCursorAdapter

自己实现的CustomAdapter

 

——————————-

 

 

android adapter的体系文章分类:Java编程

在android开发中列表的使用是十分常见的。google对列表的封装使列表既有显示传统文本列表的能力,也有加入了诸如选择项、复选项等处理事件的能力。这里写一些我这几天对这个问题的理解。在android的api中,LIST和adapter都被放在了android.widget包内。包内的具体结构我这里先不展示了,主要侧重列表和 adapter。adapter的作用就是将要在列表内显示的数据和列表本身结合起来。列表本身只完成显示的作用,其实他就是继承自VIEWGROUP 类。但是他又有一个独特的函数就是setAdapter()就是完成了view和adapter的结合。adapter如同其本身含义,其实就是一个适配器,他可以对要显示的数据进行统一的封装,主要是将数据变成view提供给list。我们先来看看adapter的体系:public interface Adapter—-0层(表示继承体系中的层次)public interface ExpandableListAdapter—(无所谓层次因为没有其他接口继承实现它)这是adapter的始祖,其他个性化的adapter均实现它并加入自己的接口。public interface ListAdapter—-1层public interface SpinnerAdapter—-1层public interface WrapperListAdapter—-2层(实现ListAdapter)以上接口层面上的体系已经完了。可以看出来作为widgetview的桥梁adapter其实只分为2种:ListAdapter和 SpinnerAdapter以及ExpandableListAdapter。也就是说所有widget也就是基于list和spinne与 ExpandableList三种view形式的。由于在实际使用时,我们需要将数据加入到Adapter,而以接口形式呈现的adapter无法保存数据,于是Adapter就转型为类的模式。public abstract class BaseAdapter—-2层(实现了ListAdapter和SpinnerAdapter)以抽象类的形式出现构造了类型态下的顶层抽象,包容了List和Spinnerpublic class ArrayAdapter—-3层public class SimpleAdapter—3层public class CursorAdapter—-3层(CursorAdapter其后还有子类这里先不探讨)基本体系有了之后,让我们看看顶层Adapter里有哪些方法(只列举常用的):abstract Object getItem_r(int position)abstract int getCount_r()abstract long getItemId_r(int position)abstract int getItemViewType_r(int position)abstract View getView_r(int position,View convertVeiw,ViewGroup parent)以上是比较重要的方法,ArrayAdapter他们也是重新实现以上方法的。在实际的开发过程中,往往我们要自己做属于自己的Adapter,以上方法都是需要重新实现的。这个在android提供的APIdemo例子中可以看到。

 

 

—————————–

 

 

(转)android adapter的学习

 

 

 

 

 

我在刚玩android 时候,对这个adapter很不理解,到底是什么原理呢? 适配器,哎,只知道setAdapter()把参数传进去,系统就显示出来了。今天,针对这个东西,我们做个系统详细的分析.listview加载adapter过程是这样的.1 先判断adapter 有多少数据项,根据这个数据确定有多少item.2 确定每个item里加载哪个View. 3 把View里加载要显示的数据.问提一个一个来解决. 第一个问题: 因为adapter都要关联一个list .有来存储数据.list的项数就是Item的

数目. 我们在重载BaseAdapter 时候,都要实现这个函数

public int getCount() {return weatherList.size();}哎,这个函数就是确定关联条目的.第二个问题 哪来的view 呢, 当然我们自己创建的.重载BaseAdapter时候你要实现getView()这个函数,就

是这个view.第三个问题,你自己创建的view.加载哪些数据你该知道的.呵呵.张豪就喜欢看例子,这个小伙子技术,管理都很牛,得以他为榜样. 得努力.public class CustomAdapterActivity extends ListActivity{@Overridepublic void onCreate(Bundle savedInstanceState){super.onCreate(savedInstanceState);setContentView(R.layout.main);ArrayListWeather weatherList = new ArrayListWeather();Weather w = new Weather( “London”, 17, Weather.OVERCAST );weatherList.add( w );w = new Weather( “Paris”, 22, Weather.OVERCAST );weatherList.add( w );w = new Weather( “Athens”, 29, Weather.SUNNY );weatherList.add( w );w = new Weather( “Stockholm”, 12, Weather.RAIN );weatherList.add( w );WeatherAdapter weatherAdapter = new WeatherAdapter(this,weatherList );setListAdapter( weatherAdapter );}}哎,这个大家都很清楚,关键问题是weatherAdapter 哪来的呢? 自己创建的啊,如果创建呢?public class WeatherAdapter extends BaseAdapter {private Context context;private ListWeather weatherList;  这就是adapter关联的List,用来存储数据.还记的ArrayList 要往

里传参数吗? 传的也是这个类型啊.呵呵public WeatherAdapter(Context context, ListWeather weatherList ) {this.context = context;this.weatherList = weatherList;}public int getCount() {return weatherList.size();}public Object getItem(int position) {return weatherList.get(position);}public long getItemId(int position) {return position;}public View getView(int position, View convertView, ViewGroup parent) {Weather weather = weatherList.get(position);return new WeatherAdapterView(this.context, weather );}}哎,这段告诉了我们,有多少个Item, 可以通过getCount()得到了。 可是View 哪来的呢?当然是getView ()这个函数提供.这个view 的获取就多中多样了,我们可以传个LayoutID. 通过Inflater出来,也可以自己创建个,只要出来就行.

在这里,我们自己创建个View. 这个View.是个VIewGroup.class WeatherAdapterView extends LinearLayout {public static final String LOG_TAG = “WeatherAdapterView”;public WeatherAdapterView(Context context,Weather weather ) {super( context );this.setOrientation(HORIZONTAL);LinearLayout.LayoutParams cityParams =new LinearLayout.LayoutParams(100, LayoutParams.WRAP_CONTENT);cityParams.setMargins(1, 1, 1, 1);TextView cityControl = new TextView( context );cityControl.setText( weather.getCity() );addView( cityControl, cityParams);LinearLayout.LayoutParams temperatureParams =new LinearLayout.LayoutParams(20, LayoutParams.WRAP_CONTENT);temperatureParams.setMargins(1, 1, 1, 1);TextView temperatureControl = new TextView(context);temperatureControl.setText( Integer.toString( weather.temperature ) );addView( temperatureControl, temperatureParams);LinearLayout.LayoutParams skyParams =new LinearLayout.LayoutParams(25, LayoutParams.WRAP_CONTENT);ImageView skyControl = new ImageView( context );Log.d( LOG_TAG, weather.getCity()+” – “+weather.sky );skyControl.setImageResource( weather.getSkyResource() );addView( skyControl, skyParams );}}有了这个就很清楚了. 呵呵,很明白吧, 一定得深入,细致的理解.

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/193113.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • MD编辑器设置字体、颜色、大小

    MD编辑器设置字体、颜色、大小颜色:浅红色文字:浅红色文字:深红色文字:深红色文字浅绿色文字:浅绿色文字深绿色文字:深绿色文字浅蓝色文字:浅蓝色文字深蓝色文字:深蓝色文字浅黄色文字:浅黄色文字深黄色文字:深黄色文字浅青色文字:浅青色文字深青色文字:深青色文字浅紫色文字:浅紫色文字深紫色文字:深紫色文字大小:size为1:size为1size为2:size为2size为3:size为3size为4:size为4size为10:size为10字体:我是黑体字我是宋体字我是微软雅黑字我是fanta

  • 业务流程引擎_业务流程管理

    业务流程引擎_业务流程管理一般的时候,我们都采用编程式开发,编程式开发的好处非常明显:直接、高效、自由,当然其缺点也是有的,与其优点刚好相对,因为直接,所以有些变化都要进行代码上的修改;因为高效,所以一旦出问题,导致的结果也比较严重,因为自由,所以带来的修改风险也比较大。  这也就是许多大的公司都在进行流程化开发的重要原因之一,比如:上海普元,Livebos,Justep,还有许许多多知名不知名的公司都有类似的流程化开发

  • pycharm专业版激活码(JetBrains全家桶)

    (pycharm专业版激活码)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.html9ZHRNTE33T-eyJsaWNlbnNlSWQi…

  • python dll注入监听_DLL注入和API拦截

    python dll注入监听_DLL注入和API拦截读《Windows核心编程》笔记一DLL注入和API拦截在Windows中,每个进程相互独立,都有自己的私有的地址空间,程序中使用的指针都是进程自己地址空间的一个内存地址,无法创建也没法使用其他进程的指针。这种机制使得各个进程之间不会相互影响,万一自己出现了问题,也不会影响到其他的进程。对用户来说,系统更加的稳定了,但是对于开发人员来说,会使我们很难编写能够与其他进程通信的应用程序或对其他进程进…

  • Ubuntu下很给力的下载工具

    Ubuntu下很给力的下载工具

  • 3d立方体旋转动画代码_3d旋转图片制作

    3d立方体旋转动画代码_3d旋转图片制作3D立方体旋转动画

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号