项目遇到的问题以及解决方式

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 类似于这种异常,一般来说,可能是中的view写成了小写。


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中填充数据

你可能感兴趣的:(项目遇到的问题以及解决方式)