1、AppCompatActivity去掉ActionBar
当使用BaseActivity继承AppCompatActivity时,使用原始方法 requestWindowFeature(Window.FEATURE_NO_TITLE); 无法去掉标题栏
原因:AppCompatActivity在Android5.0之后出现,是用来替换ActionBarActivity的,因此AppCompatActivity中只有ActionBar,没有标题栏
解决方式:
getSupportActionBar().hide();
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);
2、首页下拉刷新时,每次下拉刷新之后都会跳到ListView顶部,这是因为每次刷新时都会去请求数据,而请求数据完成后会调用onModeChange()方法,在这个方法中,我给ListView设置数据使用的时new HomeLiveAdapter(),每次重新设置Adapter时,ListView都会重新回到顶部,因此这样改了一下代码,问题解决。当第一次进来的时候,livePage == 1 这个时候去new Adapter 第二次 三次进来时,直接提醒adpter更新数据即可。
3、动态申请权限时,在Fragment中申请权限,onRequetsPermission()方法未被调用,这是因为在Activity和Fragment中调用requestPermissions()方法是不同的,Fragment要自己调用该方法
4.点击EditTex不弹出软键盘的方法:editEdit.setInputType(InputType.TYPE_NULL); 这个方法不光不会弹出软键盘,还会使EditText失去焦点。
另外 EditText默认点击两次才会响应onClick方法,解决方法:在xml文件中设置:
android:clickable="true"//允许单击
android:focusableInTouchMode="false"//不获得焦点,此时会触发onclick事件
如果需要同时获得焦点,则在onclick处理中添加如下代码
(EditText) mEditText=(EditText)v;
mEditText.setFocusable(true);
mEditText.setFocusableInTouchMode(true);
mEditText.requestFocus();
mEditText.requestFocusFromTouch();
还要自动弹出软键盘?!加入以下2行就行啦
InputMethodManagerinputManager =
(InputMethodManager)mEditText.getContext().getSystemService(Context.INPUT_METHOD_SERVICE);
inputManager.showSoftInput(mEditText, 0);
4.ImageView在代码中设置图片
imageView.setImageResoure()/.setImageDrawable();这在xml中相当于设置src 前景
imageView.setBackgroud();这在xml相当于设置background 背景
5.启动时 白屏问题 项目启动时,可能会去找背景颜色因此给SplashActivity设置一个主题 设置windowBackground属性为启动页的图片即可
true @null @drawable/logo_splash true
6.父类的构造方法最先调用。
7.如果出现 Binary XML file line #0: Attempt to invoke virtual method 'boolean java.lang.String.equals(java.lang.Object)' on a null object reference 类似于这种异常,一般来说,可能是
8.ScrollView与底部布局的嵌套。底部布局一直置于底部,不会随着ScrollView的滑动而滑动。
<底部布局>>
如上。最外层LinearLayout 里面ScrollView高度设置为0 weight设置为1 占满底部布局外的所有位置。
9.在utils类中定义一个静态的dialog 编辑一个静态方法使之弹出,在页面中使用时报了这样一个错:
Unable to add window -- token android.os.BinderProxy@9e87e8f is not valid; is your activity running?
此时需要在创建dialog时添加一句代码
Window dialogWindow = kefuDialog.getWindow();dialogWindow.setType(WindowManager.LayoutParams .TYPE_SYSTEM_ALERT);
why?以后再查
10.ShareSDK分享自定义九宫格。
点击分享键,弹出九宫格。在九宫格点击事件中添加指定平台分享的代码即可。
11.如果有嵌套滑动时,使用NestedScrollView。(后续更新)
12.View.inflate(),在RecyclerView中,item的inflate需要添加root参数,不然在布局文件中设置的控件宽高将失效:参考
https://www.jianshu.com/p/9a6db88b8ad3里面对inflate 和 RecyclerView源码的分析,通过分析inflate()的源码,发现如果不添加root,那么就不会有LayoutParams,那么RecyclerView的LayoutManager就会实现generateDefaultLayoutParams()这个方法,这个方法是这样写的
/** * {@inheritDoc} */
@Override
publicLayoutParamsgenerateDefaultLayoutParams(){
return new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
}
也就是说,如果不添加root,无论设置的宽高是多少,最终的结果都是WRAP_CONTENT。
所以在RecyclerView中 item inflate xml最好是使用LayoutInflater.from(parent.getContext()).inflate(id,parent,false); 这样一句代码 注意最后一个参数必须为false。不然会包这样的错:
The specified child already has a parent. You must call removeView() on the child's parent first.
在inflate方法中有这样一句代码:
if (root != null && attachToRoot) {
root.addView(temp, params);
}
就是说,如果root!=null && attachToRoot为true,那么会执行root.addView(),而RecyclerView/ListView会自动将child添加到它里面去,所以会报两个parent的错。
但是,如果Item中写了父容器,如LinearLayout等,就不会有无法设置宽高的问题了。
13.RecyclerView展示多种布局:
13.1.重写getItemViewType()
13.2要写几种布局,就创建几种ViewHolder
在onCreateViewHolder()方法中使用
13.3 在onBindViewHolder中填充数据