1,android中,ImageView的src与background有什么区别呢
答:
用src的时候,应是原图显示,不该变图片的大小;用background的时候,按照组件的大小来放大或者缩小图片 |
background当背景的。可以设置的参数是不同的。比如background是可以平铺的
| |
2 之前一直没有搞懂android:padding和android:layout_margin的区别,其实概念很简单,padding是站在父view的角度描述问题,它规定它里面的内容必须与这个父view边界的距离。margin则是站在自己的角度描述问题,规定自己和其他(上下左右)的view之间的距离,如果同一级只有一个view,那么它的效果基本上就和padding一样了。例如我的XML layout代码如下:
[xhtml] view plaincopy
1 <?xml version="1.0" encoding="utf-8"?>
2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
3 android:orientation="vertical"
4 android:layout_width="fill_parent"
5 android:layout_height="fill_parent"
6 android:paddingLeft="10dip"
7 android:paddingRight="10dip"
8 android:paddingTop="10dip"
9 android:paddingBottom="10dip"
10 >
11 <TextView
12 android:layout_width="wrap_content"
13 android:layout_height="wrap_content"
14 android:background="#FF0000"
15 android:text="@string/hello"
16 android:paddingLeft="50dip"
17 android:paddingRight="50dip"
18 android:paddingTop="50dip"
19 android:paddingBottom="50dip"
20 android:layout_marginBottom="10dip"
21 />
22 <TextView
23 android:layout_width="wrap_content"
24 android:layout_height="wrap_content"
25 android:background="#FF0000"
26 android:text="@string/hello"
27 android:paddingLeft="50dip"
28 android:paddingRight="50dip"
29 android:paddingTop="50dip"
30 android:paddingBottom="50dip"
31 android:layout_marginBottom="10dip"
32 />
33 <TextView
34 android:layout_width="wrap_content"
35 android:layout_height="wrap_content"
36 android:background="#FF0000"
37 android:text="@string/hello"
38 android:paddingLeft="50dip"
39 android:paddingRight="50dip"
40 android:paddingTop="50dip"
41 android:paddingBottom="50dip"
42 android:layout_marginBottom="10dip"
43 />
44 <TextView
45 android:layout_width="wrap_content"
46 android:layout_height="wrap_content"
47 android:background="#FF0000"
48 android:text="@string/hello"
49 android:paddingLeft="50dip"
50 android:paddingRight="50dip"
51 android:paddingTop="50dip"
52 android:paddingBottom="50dip"
53 android:layout_marginBottom="10dip"
54 />
55 </LinearLayout>
那么我会得到如下的效果,图上已经很明确的标出来区别咯。
3.Android中各种“相似“的区别
2011-05-09 16:46
1.View 的setVisibility有三个值可以设置: 注意:若你在Adapter中的getView或bindview将某些特殊的位置的View.INVISIBLE之后,要记得在别的判断条件下将其 View.Visible.不然你会看到很多怪现象的。 2.android:gravity与android:layout_gravity LinearLayout有两个非常相似的属性:android:gravity与android:layout_gravity。他们的区别在于:android:gravity用于设置View组件的对齐方式,而android:layout_gravity用于设置Container组件的对齐方式。 3.android:padding和android:layout_margin android:padding和android:layout_margin的区别,其实概念很简单,padding是站在父view的角度描述问题,它规定它里面的内容必须与这个父view边界的距离。margin则是站在自己的角度描述问题,规定自己和其他(上下左右)的view之间的距离,如果同一级只有一个view,那么它的效果基本上就和padding一样了。 |
显示单位px和dip以及sp的区别
dip: device independent pixels(设备独立像素). 不同设备有不同的显示效果,这个和设备硬件有关,一般我们为了支持WVGA、HVGA和QVGA 推荐使用这个,不依赖像素。
px: pixels(像素). 不同设备显示效果相同,一般我们HVGA代表320x480像素,这个用的比较多。
pt: point,是一个标准的长度单位,1pt=1/72英寸,用于印刷业,非常简单易用;
sp: scaled pixels(放大像素). 主要用于字体显示best for textsize。
由此,根据 google 的建议,TextView 的字号最好使用 sp 做单位,而且查看
TextView
的源码可知 Android 默认使用 sp 作为字号单位。
###################################################################
关于换算(以 sp 和 pt 为例)
查看 TextView 等类的源码,可知:
case COMPLEX_UNIT_PX:
return value;
case COMPLEX_UNIT_SP:
return value * metrics.scaledDensity;
case COMPLEX_UNIT_PT:
return value * metrics.xdpi * (1.0f/72);
--------------------------
scaledDensity = DENSITY_DEVICE / (float) DENSITY_DEFAULT;
xdpi = DENSITY_DEVICE;
--------------------------
DENSITY_DEFAULT = DENSITY_MEDIUM = 160;
============================================
所以: 假设 pt 和 sp 取相同的值 1,则可设 1pt 和 1sp 之间系数为 x,
1 * DENSITY_DEVICE / 72 = x * 1 * DENSITY_DEVICE / 160 =>
x = 160 / 72 = 2.2222
也就是说在 Android 中, 1pt 大概等于 2.22sp
以上供参考,如果 UI 能够以 sp 为单位提供设计是最好的,如果设计中没有 sp
的概念,则开发人员也可以通过适当的换算取近似值。
什么是Dip和 Sp
过去,程序员通常以像素为单位设计计算机用户界面。例如,定义一个宽度为300像素的表单字段,列之间的间距为5个像素,图标大小为16×16像素 等。这样处理的问题在于,如果在一个每英寸点数(dpi)更高的新显示器上运行该程序,则用户界面会显得很小。在有些情况下,用户界面可能会小到难以看清 内容。
与分辨率无关的度量单位可以解决这一问题。Android支持下列所有单位。
px(像素):屏幕上的点。
in(英寸):长度单位。
mm(毫米):长度单位。
pt(磅):1/72英寸。
dp(与密度无关的像素):一种基于屏幕密度的抽象单位。在每英寸160点的显示器上,1dp = 1px。
dip:与dp相同,多用于 android/ophone示例中。
sp(与刻度无关的像素):与dp类似,但是可以根据用户的字体大小首选项进行缩放。