first:
    Intent跳转一般存用于Activity类,可是若要在非activity类里跳转的话,解决方法是在startActivity(intent)前加mContext即上下文,终于为:mContext.startActivity(intent);
 换言之。以后在非activity类里调用activity的方法  一律这么做。若不行的话 能够这么做:(Activity)mContext。



second:
  gridview中textview内容不能居中的问题。

gridview中能够设置一行显示多少个item,所以他为每一个item都预留了一部分空间。

若用textview来填充item 而textview的属性又为wrap_content时。由于内容较少,仅仅占领了分配空间的一部分,所以不管怎么去调试属性。看上去都像是顶格显示;故解决方法是让textview的宽度为marth_parent。这样grity
= "centre"才会有:-D。




third:

   Scrollview以下仅仅能嵌套一个控件,当有多个控件时能够在Scrollview里套上一个Relativelayout 就能够就解决这个问题。

forth:

  Android SDK Content load非常慢          解决方法 在 C:\Documents and Settings\计算机名 这个路径下有个.android目录, 把这个目录删了 然后重新启动模拟器 会弹出一个对话框 Welcome to Android Development 选择NO就能够了


five:
        在多层嵌套时 若层数过多会出现 明明控件的visibilty是visible 但在界面上仍是不可见的情况  貌似相当的诡异 解决方法:多个布局换着用 不要一直用linearlayout 能够套一个relativelayout。

原因不明



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的外面再嵌套一层布局. 当然这个时候最外层的布局失去作用了。


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错误,解决方法:先创建前面的目录,在创建终于文件。

  如: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()得到的结果是一样的。

这两个方法最基本的差别在于,是否使用了measure()方法,同一时候measure()使用的位置也非常重要。

getHeight() 和 get MeasuredHeight() 差别同理。

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界面。



24:获取控件在屏幕中的位置
     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设备的分辨率很的多。但这并不代表着我们须要为每一种分辨率都准备一套资源。

在显示差异不大的情况下。我们能够尽量复用一套图片资源。一套布局。然后再考虑特定屏幕密度。



android 编程小技巧(持续中)的更多相关文章

  1. [编程小技巧]Notepad++中如何实现文本对比功能?

    1.打开Notepad++插件中心   2.安装Compare   3.按提示重启Notepad++     4.点击Compare比较临近的两个文件       5. 取消比较     6 Comp ...

  2. Java编程小技巧(1)——方法传回两个对象

    原文地址:Java编程小技巧(1)--方法传回两个对象 | Stars-One的杂货小窝 题目是个伪命题,由Java语法我们都知道,方法要么返回一个对象,要么就不返回 当有这样的情况,我们需要返回两个 ...

  3. Shellcode编程小技巧

    工作需要,需要注入其他程序监控一些东西,检测到的数据通过WM_COPY 消息发送给显示窗体.(大体是这样的还没定稿) ##1 选择一个框架 ## tombkeeper/Shellcode_Templa ...

  4. grep的用法,小技巧,模板中含有\t时:grep -P "^\t" file

    linux中grep和find的用法区别 本文章详细的介绍了关于在linux中的grep和find两个命令的用法介绍,以及后面总结了它们两年用法区别哦. 先我们来介绍一下关于grep用法和一些小注意事 ...

  5. [Tools] Eclipse使用小技巧-持续更新

    [背景] 使用之中发现一些eclipse使用的小技巧,记录下来供以后查阅   Eclipse保存preferences,并导入到其他workspaces The Export wizard can b ...

  6. 学会这些 pycharm 编程小技巧,编程效率提升 10 倍

    PyCharm 是一款非常强大的编写 python 代码的工具.掌握一些小技巧能成倍的提升写代码的效率,本篇介绍几个经常使用的小技巧. 一.分屏展示 当你想同时看到多个文件的时候: 1.右击标签页: ...

  7. Android Studio 小技巧(2):AS中Button文字默认大写的问题

    问题类型 设置Layout中添加一个Button <Button android:id="@+id/bt_showerror" android:layout_width=&q ...

  8. Visual C++中的一些编程小技巧

    在应用程序的任意地方实现窗体的最大化.最小化.正常窗口等功能 // 设置Windows窗体的状态void CMinWindowsDlg::SetWindowState(int nWindowSize) ...

  9. linux常用小技巧(持续更新中)

    一.设置固定ip地址1.config查看用的是哪一个网卡这是假设用的是eth12.修改dns地址vim /etc/resolv.confsearch 域名地址nameserver 192.168.3. ...

随机推荐

  1. BZOJ 3168 [Heoi2013]钙铁锌硒维生素 ——矩阵乘法 矩阵求逆

    考虑向量ai能否换成向量bj 首先ai都是线性无关的,然后可以a线性表出bj c1*a1+c2*a2+...=bj 然后移项,得 c1/ci*a1+...-1/ci*bj+...=ai 所以当ci不为 ...

  2. BZOJ2425 [HAOI2010]计数 【数位dp】

    题目 你有一组非零数字(不一定唯一),你可以在其中插入任意个0,这样就可以产生无限个数.比如说给定{1,2},那么可以生成数字12,21,102,120,201,210,1002,1020,等等. 现 ...

  3. centos 7如何配置网络、网卡、ip命令

    Linux网络相关配置文件 Linux网络配置相关的文件根据不同的发行版目录名称有所不同,但大同小异,主要有似下目录或文件. (1)/etc/hostname:主要功能在于修改主机名称. (2)/et ...

  4. Goldbach

    Description: Goldbach's conjecture is one of the oldest and best-known unsolved problems in number t ...

  5. CodeForces 762D Maximum path

    http://codeforces.com/problemset/problem/762/D 因为是3*n很巧妙的地方是 往左走两步或更多的走法都可以用往回走以一步 并走完一列来替换 那么走的方法就大 ...

  6. hdu 5691 Sitting in Line

    传送门 Sitting in Line Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/O ...

  7. vba比较日期大小,定义日期;vba让excel保存

    Private Sub CommandButton1_Click()Dim i, j As IntegerDim a As Datea = #10/1/2013#j = 2i = 2' If  Wor ...

  8. ORACLE RMAN增量备份经典理解

    http://blog.itpub.net/26118480/viewspace-1793548/

  9. 42.QT-QSqlQuery类操作SQLite数据库(创建、查询、删除、修改)详解

    Qt 提供了 QtSql 模块来提供平台独立的基于 SQL 的数据库操作.这里我们所说的“平台 独立”,既包括操作系统平台,也包括各个数据库平台,Qt支持以下几种数据库: QT自带SQLITE数据库, ...

  10. codevs——1842 递归第一次

    1842 递归第一次  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 白银 Silver 题解       题目描述 Description 同学们在做题时常遇到这种函数 f( ...