zoukankan      html  css  js  c++  java
  • UI——布局

         这两天一直在调界面,很有心得,界面少不了的就是一层套一层,有时即便是界面的简单实现不需要一个linearlayout套另一个linearlayout,但是也必须在外层加上一个linearlayout,比如需要隐藏(View.gone)一个view的时候,还必须与左右间隔(margin),而内层实现间隔一旦隐藏后就没有这个间隔了,所以这个时候必须在外层实现这个间隔。

    另外,在代码中设置长度单位为dip时,可以用以下方法:

    Resources resources = getResources();
    
    float fPx = TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 300, resources.getDisplayMetrics());
    
    // 同理 px转dip:
    // float fDip = TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_PX, 300, resources.getDisplayMetrics());
    // int iDip = Math.round(fDip);
    
    int iPx = Math.round(fPx);
    
    EditText editText = new EditText(this);
    editText.setWidth(iPx);
    editText.setHeight(LayoutParams.WRAP_CONTENT);
    
    // 或者
    // LayoutParams layoutParams = new LayoutParams(iPx, LayoutParams.WRAP_CONTENT);
    // editText .setLayoutParams(layoutParams);

     方法二:

    /**
    
     * 根据手机的分辨率从 dp 的单位 转成为 px(像素)
    
     */
    
    public static int dip2px(Context context, float dpValue) {
    
    final float scale = context.getResources().getDisplayMetrics().density;
    
    return (int) (dpValue * scale + 0.5f);
    
    }
    
     
    
    /**
    
     * 根据手机的分辨率从 px(像素) 的单位 转成为 dp
    
     */
    
    public static int px2dip(Context context, float pxValue) {
    
    final float scale = context.getResources().getDisplayMetrics().density;
    
    return (int) (pxValue / scale + 0.5f);
    
    }

    方法三:

    使用尺寸(dimen)资源res/values/dimens.xml

    获得尺寸资源的方法:
    getResources().getDimension()
    引用尺寸资源的格式:
    Java代码中:R.dimen.dimen_name
    XML文件中:@[package:]dimen/dimen_name

          最后还有一点感悟:在代码中设置界面时常用到:view.setLayoutParams(new LinearLayout.LayoutParams(276, 110)),但是有时不一定就是new LinearLayout.LayoutParams(276, 110),比如还可能是new ListView.LayoutParams(276, 110),这取决于这个view的外层组件是LinearLayout还是ListView或者还是什么别的什么组件,否则就会报cast类型转换错误。

  • 相关阅读:
    面试题练习
    小作业7
    小作业6,7
    小作业
    坦克大战
    面试题
    20181213作业
    20181212作业
    20181211作业
    第三周周末作业
  • 原文地址:https://www.cnblogs.com/kobe8/p/2579966.html
Copyright © 2011-2022 走看看