之前积累了一些知识点,很遗憾最后没有保存被覆盖掉了,都是一些基础知识,有一些是面试中问到过的,希望以此能让自己的知识慢慢积累,扎实基础,现在从零开始积累,之前写的问题大都不记得了,想起来时再慢慢补充。
1.fragment中的onCreateView和onViewCreated的区别和联系。
- onCreateView是创建的时候调用,onViewCreated是在onCreateView后被触发的事件,前后关系
- 且onStart运行时间位于onViewCreated之后
- onCreateView中代码内容:(查看源码理解更好)
//方法一
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {
//layoutId()位置即为要显示的布局(下同)
View root = inflater.inflate(layoutId(), container, false);
return root;
}
//方法二:不会继承母布局信息
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {
//layoutId()是个虚函数,用来在子类里实现。子类只需要返回R.layout.*就可以了,
// 不必每个片段都重写onCreateView了。在onViewCreated里根据传来的参数根去实例化各个控件。
View root = inflater.inflate(layoutId(), null);
return root;
}
- 总结:90%的情况下,我们使用片段此处一定要用方法1。有一种情况,如创建dialog fragment时,不需要得到母布局参数信息可以用方法2。
- 虚函数layoutId()下次研究
2.drawable的椭圆布局属性
- android:useLevel布尔值,如果当做是LevelListDrawable使用时值为true,否则为false。
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape android:shape="oval" android:useLevel="false">
<solid android:color="@color/dot_cherry_red" />
<size android:width="10dp" android:height="10dp" />
</shape>
</item>
</selector>
- android:useLevel ="false"一定设置为false否则没效果
3.LinearLayout垂直水平居中
- 1、
android:orientation="vertical"表示该布局下的元素垂直排列;
- 2、给子布局设置
//水平居中
android:layout_gravity="center_horizontal" //表示该布局在父布局里水平居中,此时其父布局必须拥有
android:orientation="vertical" //属性;
//垂直居中
android:layout_gravity="center_vertical" //表示该布局在父布局里垂直居中,此时其父布局必须应设置成
android:orientation="horizontal" //属性(默认为该属性),且其父布局的高度应设置为
android:layout_height="math_parent" //属性;
- 3、给父布局设置
//水平居中
android:gravity="center_horizontal" //表示该布局下的元素水平居中;
- 4、一个item小例子:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="8dp"
android:layout_marginRight="8dp"
android:background="@color/white"
android:orientation="horizontal">
<RelativeLayout
android:layout_width="50dp"
android:layout_height="50dp"
android:layout_marginBottom="6dp"
android:layout_marginLeft="6dp"
android:layout_marginTop="6dp"
android:layout_gravity="center_vertical">
<ImageView
android:id="@+id/discovery_image"
android:layout_width="50dp"
android:layout_height="50dp"
android:layout_centerVertical="true" />
<View
android:layout_width="10dp"
android:layout_height="10dp"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:background="@drawable/bg_circle_discovery" />
</RelativeLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:orientation="vertical"
android:layout_marginTop="6dp">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/discovery_title_txt"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_marginLeft="12dp"
android:layout_marginTop="4dp"
android:text="-"
android:textColor="@color/webview_menu"
android:textSize="16sp" />
<TextView
android:id="@+id/discovery_date_txt"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:layout_marginRight="6dp"
android:layout_marginTop="4dp"
android:text="-"
android:textColor="@color/warm_grey"
android:textSize="12sp" />
</RelativeLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:gravity="center_vertical"
android:layout_marginBottom="6dp">
<TextView
android:id="@+id/discovery_msg_txt"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="7dp"
android:layout_marginLeft="12dp"
android:layout_marginRight="46.3dp"
android:layout_marginTop="9dp"
android:ellipsize="end"
android:lines="1"
android:text="-"
android:textColor="@color/warm_grey"
android:textSize="14sp" />
</LinearLayout>
</LinearLayout>
</LinearLayout>
- 小红点:bg_circle_discovery.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape android:shape="oval" android:useLevel="false">
<solid android:color="@color/dot_cherry_red" />
<size android:width="10dp" android:height="10dp" />
</shape>
</item>
</selector>
4.Android Studio最全插件
- https://www.cnblogs.com/SharkBin/p/7452409.html
5.permission 和 user-permission
- permission是自定义权限
- uses-permission是使用的权限
给自己的计划:
6.编程工具大全
- https://baijiahao.baidu.com/s?id=1563708117568569&wfr=spider&for=pc
7.RecycleView
- http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2014/1118/2004.html
- https://www.jianshu.com/p/12ec590f6c76
- ListView的几个重要属性:https://www.jianshu.com/p/12ec590f6c76
8.PopuWindow
- 弹出动画(顶部 or 底部):http://blog.csdn.net/java04/article/details/51946595
- 显示位置:https://www.cnblogs.com/chenliyang/p/6559483.html
9.GrowingIO数据分析工具(SDK集成)
- https://docs.growingio.com/SDK/Android.html
10. 多用户处理认证的最佳方式Token(登录):
- 好处:
- 1.无状态、可扩展
- 2.支持移动设备
- 3.跨程序调用
- 4.安全
- 验证原理:
- 基于Token的身份验证是无状态的,我们不将用户信息存在服务器或Session中。这种概念解决了在服务端存储信息时的许多问题NoSession意味着你的程序可以根据需要去增减机器,而不用去担心用户是否登录。
- 基于Token的身份验证的过程如下:
- 1.用户通过用户名和密码发送请求。
- 2.程序验证。
- 3.程序返回一个签名的token 给客户端。
- 4.客户端储存token,并且每次用于每次发送请求。
- 5.服务端验证token并返回数据。
每一次请求都需要token。token应该在HTTP的头部发送从而保证了Http请求无状态。我们同样通过设置服务器属性Access-Control-Allow-Origin:* ,让服务器能接受到来自所有域的请求。需要注意的是,在ACAO头部标明(designating)*时,不得带有像HTTP认证,客户端SSL证书和cookies的证书。 - http://blog.csdn.net/xunfeng13/article/details/52371562