first:
Intent跳转通常存用于Activity类,但是若要在非activity类里跳转的话,解决方法是在startActivity(intent)前加mContext即上下文,终于为:
mContext.startActivity(intent); 换言之。之后在非activity类里调用activity的方法 一概这么作。若不行的话 可以这么作:(Activity)mContext。
second:
gridview中textview内容不能居中的问题。
gridview中可以设置一行显示多少个item,因此他为每个item都预留了一部分空间。html
若用textview来填充item 而textview的属性又为wrap_content时。因为内容较少,仅仅占领了分配空间的一部分,因此无论怎么去调试属性。看上去都像是顶格显示;故解决方法是让textview的宽度为marth_parent。这样grity = "centre"才会有:-D。java
third:
Scrollview如下仅仅能嵌套一个控件,当有多个控件时可以在Scrollview里套上一个Relativelayout 就可以就解决这个问题。
forth:
Android SDK Content load很是慢 解决方法 在 C:\Documents and Settings\计算机名 这个路径下有个.android目录, 把这个目录删了 而后从新启动模拟器 会弹出一个对话框 Welcome to Android Development 选择NO就可以了
five:
在多层嵌套时 若层数过多会出现 明明控件的visibilty是visible 但在界面上还是不可见的状况 貌似至关的诡异 解决方法:多个布局换着用 不要一直用linearlayout 可以套一个relativelayout。
缘由不明
android
six:
若activity里的某些响应时基于adapter数据的 而adapter又与activity分开 使得数据没法回传到activity(详细见Listview与GridView预留数据接口一文) 解决方法例如如下:
通常来讲adapter是由activity调用的 需要传入activity的activity listdata等等信息 因此 咱们在就收数据时 把activity方法获得 见代码:
QYSPActivity activty;
//调用这个adapter的activity类
public QYSPFLInfoAdapter(Activity activity, List<SPFLData> listdata) {
super(activity, 0, listdata);
activty = (QYSPActivity) activity;
// 获取activity的类
}
在需要的地方调用activity里的方法
activty.doPost(XXXXX);
//doPost()是在activity里定义好的方法 public
记住了 取名字的时候不要取
activity 因为这个名字与 (QYSPActivity)
activity 同样。而后得到的activity方法就是空的 而后 而后 各类error 解决方法 换名字或者 this.activity = (QYSPActivity) activity; 说白了 就是this. 语句 伤不起~~
目測这种方法可以触类旁通 但是怎么反 待定。。。
seven:
setContentView和inflate差异 setContentView()一旦调用, layout就会立马显示UI;而inflate仅仅会把Layout造成一个以view类实现成的对象,有需要时再用setContentView(view)显示出来 .通常在activity中经过setContentView()将界面显示出来,但是假设在非activity中怎样对控件布局设置操做了。这需LayoutInflater动态载入
eight:
动态删除listview的item
nine:
使用contentView+静态类ViewHolder类来优化adapter 当咱们推断 convertView == null 的时候,假设为空,就会依据设计好的List的Item布局(XML),来为convertView赋值,并生成一个viewHolder来绑定converView里面的各个View控件(XML布局里面的那些控件)。再用convertView的setTag将viewHolder设置到Tag中,以便系统第二次绘制ListView时从Tag中取出。(看如下代码中)
ViewHolder holder;
if(convertView == null)
{
holder = new ViewHolder();
convertView = mInflater.inflate(R.layout.list_item, null);
holder.img = (ImageView)convertView.findViewById(R.id.img);
holder.title = (TextView)convertView.findViewById(R.id.title);
holder.info = (TextView)convertView.findViewById(R.id.info);
convertView.setTag(holder);
}else
{
holder = (ViewHolder)convertView.getTag();
holder.img.setImageResource(R.drawable.ic_launcher);
holder.title.setText("loulijun");
holder.info.setText("www.cnblogs.com/loulijun");
}
eleven: 单个控件的xml不能放缩问题
事实上这里不管你将Button的layout_width和layout_height的值改动成多少。都不会有不论什么效果的。因为这两个值现在已经全然失去了做用。平时咱们经常使用layout_width和layout_height来设置View的大小,并且一直都能正常工做,就好像这两个属性确实是用于设置View的大小的。而实际上则否则,它们事实上是用于设置View在布局中的大小的,也就是说,首先View必须存在于一个布局中,以后假设将layout_width设置成match_parent表示让View的宽度填充满布局,假设设置成wrap_content表示让View的宽度恰好可以包括其内容。假设设置成详细的数值则View的宽度会变成对应的数值。这也是为何这两个属性叫做layout_width和layout_height,而不是width和height。
再来看一下咱们的button_layout.xml吧。很是明显Button这个控件眼下不存在于不论什么布局其中,因此layout_width和layout_height这两个属性理所固然没有不论什么做用。
那么如何改动才干让按钮的大小改变呢?解决方法事实上有很是多种,最简单的方式就是在Button的外面再嵌套一层布局. 固然这个时候最外层的布局失去做用了。git
ten:
throw与throws的差异
throw语句用在方法体内,表示抛出异常,由方法体内的语句处理
throws语句用在方法声明后面,表示再抛出异常,由调用这种方法的上一级方法中的语句来处理
throws主要是声明这种方法会抛出这样的类型的异常,使其它地方调用它时知道要捕获这个异常。
throw是详细向外抛异常的动做,因此它是抛出一个异常实例。
throws说明你有哪一个可能。倾向
throw的话。那就是你把那个倾向变成真实的了 同一时候:
1)throws出现在方法函数头;而throw出现在函数体;
2)throws表示出现异常的一种可能性。并不必定会发生这些异常。throw则是抛出了异常,运行throw则必定抛出了某种异常;
3)二者都是消极处理异常的方式(这里的消极并不是说这样的方式很差)。仅仅是抛出或者可能抛出异常,但是不会由函数去处理异常,真正的处理异常由函数的上层调用处理。
twelve: gravity与 layout_gravity
android:gravity:是对view控件自己来讲的。是用来设置view自己的文本应该显示在view的什么位置,默认值是左側
android:layout_gravity:是相对于包括改元素的父元素来讲的。设置该元素在父元素的什么位置
对于LinearLayout假设设置android:orientation="vertical"。那么android:layout_gravity的设置仅仅在水平方向生效。假设设置android:orientation="horizontal"。那么android:layout_gravity属性仅仅在垂直方向生效。
thirteen
:
带删除button及功能的输入框
* 因为咱们不能直接给EditText设置点击事件,因此咱们用记住咱们按下的位置来模拟点击事件
* 当咱们按下的位置 在 EditText的宽度 - 图标到控件右边的间距 - 图标的宽度 和
* EditText的宽度 - 图标到控件右边的间距之间咱们就算点击了图标,竖直方向没有考虑
代码例如如下:
boolean touchable = event.getX() > (getWidth()
- getPaddingRight() - mClearDrawable.getIntrinsicWidth())
&& (event.getX() < ((getWidth() - getPaddingRight())));
//mClearDrawable为删除button
if (touchable) {
this.setText("");
}
在输入框中加入删除button
forteen:
open failed: EISDIR (Is a directory)
在SD卡中建立目录目录的时候,应该一层一层的建立目录,但是不能一次同一时候建立这两个目录.easy把详细建立的文件看成要建立的空目录来建立。
将"/mnt/sdcard/zhufu/apkbus.db"看成目录来建立,这样就会出现EISDIR错误,解决方法:先建立前面的目录,在建立终于文件。web
如:File parentFile = new File(path);
if (!parentFile.exists()) {
parentFile.mkdirs();
}
File file = new File(parentFile, filename + ".jpg");//这就是终于存放位置,在这里千万不能反复madirs,不然就会出现上面的错误。
15:
播放同一个文件MediaPlayer报IO异常
解决方法:能够播放一次说明Player及文件都是没有问题的,但是假设播第二次 有时候或报IO异常,缘由是待播放的文件正在被占用。若要正常播放的话必须在Player使用它以前,这个资源是被 release的。
player.release(); 。数据结构
16:
scrollview默认初始位置在顶部
因为scrollView里面ListView的上面还有其它的控件,因此我想到一个办法就是使得一開始的时候就让上面当中一个控件得到焦点。滚动栏天然就到顶部去了,例如如下:
txtBaseMsg.setFocusable(true);
txtBaseMsg.setFocusableInTouchMode(true);
txtBaseMsg.requestFocus();
控制其滑动究竟部: sv.fullScroll(ScrollView.FOCUS_DOWN);
17:
Notification 动态图标
通常默认notification的图标是静态的,但是在某些状况下 图标需要是动态的,解决方法事实上蛮简单 就是给notification不停的换icon,而后就显示出来。
notif.iconLevel = 0;
manager.notify(0, notif);
SystemClock.sleep(100);
notif.iconLevel = 1;
manager.notify(0, notif);
18
:
getWidth和getMeasuredWidth 差异
getWidth(): View在设定好布局后,整个View的宽度
getMeasuredWidth():对View上的内容进行測量后获得的View内容占领的宽度。前提是你必须在父布局的onLayout()方法或者此View的onDraw()方法里调用measure(0,0);(measure參数的值可以知己定义)。不然获得的结果和getWidth()获得的结果是同样的。app
这两个方法最基本的差异在于,是否使用了measure()方法,同一时候measure()使用的位置也很是重要。框架
getHeight() 和 get MeasuredHeight() 差异同理。ide
geiHeight有时候会获得0,通常缘由是在View还未绘制完以前调用这种方法,因此获得的就是0。解决该问题的方法有很是多,主要就是延后调用这些方法。函数
可以试着在onWindowFocusChanged()里面调用这些方法。
19
:
onItemClickListener点击区分
多个listView或GridView都要得到item的点击监听时,通常都是直接调用系统的onItemClickListener接口,但是他们并不能区分开来,而且得不到id,不能像ClickListener同样用v.getId来区分,但是可以利用parent的get来区分,他就至关于clickListener的view同样。
20:
在文字如下图片(代码版)
//得到图片资源及大小 最后两句为销毁图片 防止OOM
Bitmap bitmap = BitmapFactory.decodeResource(mContext.getResources(), R.drawable.icon_daohang_select);
width = bitmap.getWidth();
height = bitmap.getHeight();
bitmap.recycle();
bitmap = null;
重点来了:
holder.text1.setText(mTextList.get(position));
Drawable d = mContext.getResources().getDrawable(mImgList.get(position));
d.setBounds(0, 0, width, height);
holder.text1.setCompoundDrawables(null, d, null, null);
21:关于在xml里 android:onClick="onClick"的巧妙使用方法
在代码里若引入了其它地方的xml那么xml的点击事件就有一点麻烦,因此可以採用以前题目的那个方法。因为这个和android自带的onclick事件一样,因此可以直接套用点击方法。(其它部分与普通onclick事件同样)。
22 :
设置导航栏和状态栏(仅仅对4.4或以上实用)
这个就是用来设置app上方的界面,就是显示WiFi标志 时间 电池信息什么的
设置方法:
首先要打开activity的透明主题功能,可以把activity的主题设置继承*.TranslucentDecor 主题,而后设置
android:windowTranslucentNavigation
或者android:windowTranslucentStatus的主题属性为true,又或者在activity的代码里面开启
FLAG_TRANSLUCENT_NAVIGATION
或是
FLAG_TRANSLUCENT_STATUS的window窗体标识。
激活:
// 建立状态栏的管理实例SystemBarTintManager tintManager = new SystemBarTintManager(this);
// 激活状态栏设置tintManager.setStatusBarTintEnabled(true);
// 激活导航栏设置tintManager.setNavigationBarTintEnabled(true);
设置状态栏颜色和图片
// 设置一个颜色给系统栏
tintManager.setTintColor(Color.parseColor("#99000FF"));
// 设置一个样式背景给导航栏
tintManager.setNavigationBarTintResource(R.drawable.my_tint);
// 设置一个状态栏资源
tintManager.setStatusBarTintDrawable(MyDrawable);
23:
Intent的Flag任用
在Activity中若用清除以前所有的Activity和Task 最好的方法是给Activity加个Flag FLAG_ACTIVITY_CLEAR_TASK 这个Flag的解释是在此activity启动以前。不论什么与此activity相关联的task都会被清除。也就是说,此
activity将变成一个空栈中新的最底端的activity,所有的旧activity都会被finish掉。这个标识只和FLAG_ACTIVITY_NEW_TASK联合起来才干使用。
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK | Intent.FLAG_ACTIVITY_NEW_TASK);
若想保留2个Activity也就是说要在新Task里保留2个Act 那么最好的作法是一次启动两个Activity,详细操做例如如下:
Intent intent = new Intent(this,A.class);
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK | Intent.FLAG_ACTIVITY_NEW_TASK);
startActivity(intent);
intent = new Intent(this,B.class);
startActivity(intent);
这个时候系统会直接跳到B界面。同一时候A会放在Task的最底层。从B界面返回 会回到A界面。
getLocationOnScreen
,计算该视图在全局坐标系中的x,y值。(注意这个值是要从屏幕顶端算起。也就是索包含了通知栏的高度)//获取在当前屏幕内的绝对坐标
getLocationInWindow 。计算该视图在它所在的widnow的坐标x。y值。//获取在整个窗体内的绝对坐标 (不是很是理解= =、)
getLeft , getTop, getBottom, getRight, 这一组是获取相对在它父亲里的坐标
假设在Activity的OnCreate()事件输出那些參数。是全为0,要等UI控件都载入完了才干获取到这些。
25:android:ellipsize的使用
EidtText和textview中内容过长的话本身主动换行。使用android:ellipsize与android:singleine可以解决,使仅仅有一行。
EditText不支持marquee
使用方法例如如下:
在xml中
android:ellipsize = "end" 省略号在结尾
android:ellipsize = "start" 省略号在开头
android:ellipsize = "middle" 省略号在中间
android:ellipsize = "marquee" 跑马灯
android:singleline = "true"
固然也可以用代码语句
tv.setEllipsize(TextUtils.TruncateAt.valueOf("END"));
tv.setEllipsize(TextUtils.TruncateAt.valueOf("START"));
tv.setEllipsize(TextUtils.TruncateAt.valueOf("MIDDLE"));
tv.setEllipsize(TextUtils.TruncateAt.valueOf("MARQUEE"));
tv.setSingleLine(true);
26:edittext光标
在XML中:Android:pidding = "10dp"就可以把光标日后移一点
在代码中把光标设在字体后面:titleView.setSelection(titleView.getText().length()); ()里为输入框内容长度。
27:drawpidding与与drawableLeft
后者设置textview的左(可上 下 左 右)边界图片。前者用来
设置text与drawable(图片)的间隔。
28:中文加粗
TextView tv
=
(
TextView
)
findViewById
(
R
.
id
.
TextView01
)
;
TextPaint tp
=
tv
.
getPaint
(
)
;
tp
.
setFakeBoldText
(
true
)
;
其它本身加粗:
在xml文件里使用android:textStyle=”bold”
29:View中利用TAG传值
好比 给一个动态View加入点击事件,点击事件中要得到View中的某些值。那怎么把值传递过去呢?这里就要用到TAG了。
点击事件可以这样写:
view.setOnClickListener(new ContactClick());
监听事件可以这样实现:
private class ContactClick implements OnClickListener {
@Override
public void onClick(View v) {
}
}
但是这种话得不到View里的数据。点击事件不能完毕。
so。利用setTag与getTag来传递消息。
View中Tag有两种使用方法:
1。View.setTag(Object tag);
API是这样写的: Sets the tag associated with this view. A tag can be used to mark a view in its hierarchy and does not have to be unique within the hierarchy. Tags can also be used to store data within a view without resorting to another data structure.
翻译:设置与此视图关联的标签。 tag可用于标记层次结构中的 view而层次结构没必要是惟一的。
标签还可以用于存储视图中的数据,而不诉诸其它数据结构。(第二句话目測翻译有问题)
与之配套使用 的是view.getTag(); API:the Object stored in this view as a tag。以一个tag返回存储在View中的Object。
2,View.
setTag(int key, Object tag)
API: Sets a tag associated with this view and a key. A tag can be used to mark a view in its hierarchy and does not have to be unique within the hierarchy. Tags can also be used to store data within a view without resorting to another data structure. The specified key should be an id declared in the resources of the application to ensure it is unique (see the ID resource type). Keys identified as belonging to the Android framework or not associated with any package will cause an
IllegalArgumentException
to be thrown.
翻译:设置与此视图关联的一个tag和一个key。
tag 可用于标记层次结构中查看层次结构中没必要是惟一的。Tags 还可以用于存储视图中的数据,而不诉诸其它数据结构。key 应是指定的密钥id中声明的应用资源。以确保它是独一无二的(见ID资源类型)。
Keys 为属于Android框架或不相关的不论什么包的密钥,不然将致使抛出一个IllegalArgumentException。(翻译有问题)
两者本质上没有差异,都是传值,但是①通常仅仅是传单个值。而②就克传多个值。
而在传多个值时值得注意的是这个Key,他不能为普通的int型数据,它要的是与其它控件同样的id,且不能是反复的。so解决方法是在value里新建ids.xml文件 里面存放id
eg: <item name="tag_name" type="id"></item>
<item name="tag_address" type="id"></item>
在调用的时候用 R.id.tag_name 就可以解决这个问题了。
末了 完整版的解决方式是:
// 加入数据
view.setTag(R.id.tag_name, str1);
view.setTag(R.id.tag_address, str2);
// 加入监听
view3.setOnClickListener(new ContactClick());
// 监听事件
private class ContactClick implements OnClickListener {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
//获取数据
String name = (String) v.getTag(R.id.tag_name);
String address = (String) v.getTag(R.id.tag_address);
}
}
30:在代码里面没法设置textview文字居左问题
有时候在代码里面没法设置TextView的文字走向,那么解决这个问题的方法是:
LayoutParams params = new RelativeLayout.LayoutParams(
LayoutParams.WRAP_CONTENT,
LayoutParams.WRAP_CONTENT);
params.addRule(RelativeLayout.CENTER_VERTICAL);
tv.setLayoutParams(params);
tv.setGravity(Gravity.LEFT);
又一次设置TextView的layout,而后再来设置文字走向。
31:监听返回键
常常哟重写返回键事件,一般是去重写button点击事件。而后再推断是不是返回键 是不是按下什么的,这样作通常比較繁琐,android里有onBackPress()方法,重写它就是了
32:遍历Map
在不知道Map数据状况下。需要遍历Map里面的数据。那么需要对map进行遍历。有方法例如如下:
Iterator it = levelMap.entrySet().iterator();
while (it.hasNext()) {
//得到节点
Entry entry = (Entry) it.next();
//得到节点的key values
String key = (String) entry.getKey();
String value = (String) entry.getValue();
}
****方法不惟一
over~
33:遍历list并删除某个item注意事项
遍历list的方法很是多。但假设在遍历的时候需要删除某个节点的话,那么不能用for()循环来删除了,使用for循环删除的问题是这样出现的,我删除了i= 5的节点(i++以后i= 6了)。那么我作下一次推断的时候就直接去判读新list的i = 6处的值了,但是新list的长度-1了,并且原来i>5以后的内容都往前移了一位,原来i= 6的节点跑到了i= 5处,但是从上文可知,i= 5节点没有推断。so error occurs。
解决方法:1,构建一个与待遍历的list同样的list。一个做为遍历的对象。一个做为删除的对象,两者分开就没有问题了。最后把删除对象的值赋值待遍历对象就OK了。
2。使用Iterator 来遍历,需要删除的时候使用it.remove()便可了。
(it.remove()仅仅能调用一次,屡次就抛异常了)
3。仍是使用for来遍历
。无论用
Iterator
仍是for(),删除的都是当前item,由上文可知,因为删除了i=5节点以后,下一次就推断i=6的节点。原来的i= 6节点(新list的i= 5)没有推断,那么每删除一次节点以后把i的值减一不便可了吗?! 下一次推断的时候仍是从i= 5開始。而i= 5恰好是以前的i= 6,这样就避免了以前的漏判问题,那就OK了(此法仅仅是构想。还没实践,只是应该可以)。
over~
34:webView禁止复制粘贴
长按选择粘贴文字是webView的onLongClickListener功能。若要禁止复制。那么拦截这个事件就能够。
this.appView.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View view) {
return true;//禁止事件返回
}
});
35:防截屏
activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_SECURE);
36:背景变暗
WindowManager.LayoutParams lp = getWindow().getAttributes();
lp.alpha = 0.3f;(比1小就能够)
getWindow().setAttributes(lp);
37 :截屏并保存
activity.getWindow().getDecorView().setDrawingCacheEnabled(true);
Bitmap bmp = activity.getWindow().getDecorView().getDrawingCache();
try {
OutputStream out = new FileOutputStream(Filename);
bmp.compress(Bitmap.CompressFormat.PNG, 100, out);
out.close();
} catch (Exception e) {
e.printStackTrace();
}
38 :
截屏模拟点击
android里有时候把数据和点击事件封装好了之后。需要人为去触发(如pager的默认首页)。但是在程序里又无法点击,这个时候就可以用view.performClick()。
前提:有view.onClickListener方法设置了监听。
注意:假设同一时候使用了view.setOnTouchListener()方法。则有可能存在拦截view.performClick()的响应事件。因为当view.OnTouchEvent()在event.getAction() == MotionEvent.ACTION_DOWN时返回false,系统会以为view不需要处理Touch事件,则兴许的Touch事件(move、up、click)就不会被传进来,因此也不会触发view.performClick()。而view.setOnTouchListener()至关因而重写了view.OnTouchEvent(),因此在写view的TouchListener处理时,需要留意view是否存在点击事件监听,假设有,则在适当的位置使用view.performClick()触发点击事件。
39:
时钟
时钟控件包含AnalogClock和DigitalClock,它们都负责显示时钟,所不一样的是AnalogClock控件显示模拟时钟,且仅仅显示时针和分针,而DigitalClock显示数字时钟,可精确到秒。
两者都是直接在xml里加控件。不需要在java代码控制。直接就可以本身主动显示时间。
40:
ExpandableListView默认全部展开且点击不收缩
全部展开:
//展开所有的Group
private void expandELV(ExpandableListView elv,
BaseExpandableListAdapter adapter) {
for (int i = 0; i < adapter.getGroupCount(); i++) {
elv.expandGroup(i);
}
}
//屏蔽group的点击事件
private void blockGroupClick(ExpandableListView elv) {
elv.setOnGroupClickListener(new OnGroupClickListener() {
public boolean onGroupClick(ExpandableListView parent, View v,
int groupPosition, long id) {
return true;
}
});
}
41:点击password可见隐藏
android中为EditText提供了setTransformationMethod来控制password的显隐。主要代码例如如下:
/* show the password*/
edittext.setTransformationMethod(HideReturnsTransformationMethod.getInstance());
/* hide the password */
edittext.setTransformationMethod(PasswordTransformationMethod.getInstance());
或者利用InputType也行。
// 显示为普通文本
pwdEdit.setInputType(InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD);
// 显示为password
pwdEdit.setInputType(InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_PASSWORD);
42:导入本身定义属性
43:android ViewPager xml inflate error
add support
android-support-v4.jar
in lib folder. add this jar in
Build Path
. now go to
project property-->Build Path--> Order & Export--> select all --> ok
. Clean & RUN.
44 : android java.lang.NoSuchFieldError: R$id.xxx
第一种状况 參考自http://www.shangxueba.com/jingyan/1856083.html
将引用的本身定义控件的xml文件里的最外层布局上面加入xmlns:sat=“http://schemas.Android.com/apk/res/控件所在位置的包名”可是在执行时就会报Java.lang.NoSuchFieldError:包.R$id.xxx错。
同一时候还会出现no resource identifier found for attribute 的错误。
将xmlns:sat=“http://schemas.android.com/apk/res/控件所在位置的包名”更改成
http://schemas.android.com/apk/res-auto 就不会报错了
另一种 參考:http://www.hankcs.com/program/mobiledev/e-androidruntime-fatal-exception-main-java-lang-nosuchfielderror.html
这个问题是由于主项目覆盖了库项目的xml所致。假设主项目中的某个xml里定义了一个跟库项目中的xml同名的xml,那么库中的xml将会被覆盖。这里的覆盖意思是,编译后仅仅有主项目中的xml以及R.id。全然没有库项目的影子。
因此才会有NoSuchFieldError的错误。
这个错误不会在编译的时候提示。算得上一个陷阱了。
解决方法很是easy,删除主项目中的xml,整个项目仅仅保留一份xml就能够。
45:WebView透明背景
1,android:background="@android:color/transparent"
2。 web_view.setBackgroundColor(0);
3,
在某些场合 加上2也无效,那是由于开启了软加速所致,解决方法。关闭就能够。
wvContent.setLayerType(View.LAYER_TYPE_SOFTWARE,null);
46:
在应用内屏蔽系统字体大小变化
在Application的onCreate方法里添加一下方法便可(不是每个都准)。
Resources res = getResources();
Configuration config = new Configuration();
config.setToDefaults();
res.updateConfiguration(config, res.getDisplayMetrics());
47:ViewGroup与子View点击冲突
有时候在ViewGroup和子View都有点击事件的时候,ViewGroup的事件很是easy被View捕捉到而没法。那么久可以使用 android:descendantFocusability = “”属性,他的主要做用是规定Group与子View之间的焦点关系。主要属性有三种。
- beforeDescendants :Group会优先于子View得到焦点;
- afterDescendants :Group仅仅有在子View不需要焦点的时候得到焦点;
- blocksDescendants :Group强制获取焦点。
48:ListView/GridView自己就有setEmptyView方法。
49:图片变色
项目中咱们还可能遇到图片内容一样。不过颜色不一样的状况。
这个时候咱们就可以使用Android提供的着色来完毕,而不用提供好几套图片。好比在Android 5.0+上咱们可以使用 android:tint
和 android:tintMode
,在低版本号中可以使用 ColorFilter
。
对于那些内容颜色等都一样,仅仅是方向不一样的图片。咱们可以仅仅保留一中方向的,其它方向的图片经过代码实现。
好比咱们可以对上面提到的 ic_favorite_black_24dp
进行翻转。建立一个 drawable
:
<?xml version="1.0" encoding="utf-8"?><rotatexmlns:android="http://schemas.android.com/apk/res/android"android:drawable="@drawable/ic_favorite_black_24dp"android:fromDegrees="180"android:pivotX="50%"android:pivotY="50%"android:toDegrees="180" />
尽管Android设备的分辨率很的多。但这并不表明着咱们需要为每一种分辨率都准备一套资源。
在显示差别不大的状况下。咱们可以尽可能复用一套图片资源。一套布局。而后再考虑特定屏幕密度。