Android入门学习笔记(更新中ing)

Posted 电烤牛上脑

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android入门学习笔记(更新中ing)相关的知识,希望对你有一定的参考价值。

android入门知识梳理

Activity篇

关于activity的理解

理解一:activity是提供界面(UI)的一种组件。

理解二:Activity用于显示用户界面,用户通过Activity交互完成相关操作。

activity的生命周期

-onCreate():在Activity第一次被创建时调用

-onStart():在Activity由不可见变为可见时调用

-onResume():这个方法在Activity准备好和用户交互的时候调用。此时的Activity一定位于返回栈的栈顶,并处于运行状态

-onPause():这个方法在系统准备去启动或恢复另一个Activity的时候调用

-onStop():这个方法在Activity完全不可见的时候调用,它和onPause()方法的主要区别在于,如果启动的新 Activity是一个对话框式的activity,那么,onPause()方法会得到执行,而onStop()方法并不会执行。

-onDestroy():这个方法在Activity被销毁之前调用,之后Activity的状态将变为销毁状态

-onRestart():在这个方法在Activity由停止状态变为运行状态之前调用,也就是Activity被重新启动了。

activity之间的传值

1.相邻activity之间的传值

方法:Intent传值(传递对象或单个属性)

代码:

//step1:在第一个activity文件内设置
Intent intent = new Intent(OneActivity.this,TwoActivity.class); //跳转
intent.putExtra("aLogin",aLogin);
intent.putExtra("aPassword",aPassword);
startActivity(intent);

//step2:在第二个activity内取值
Intent getIntent = getIntent();
String aLogin = getIntent.getStringExtra("aLogin");
String aPassword = getIntent.getStringExtra("aPassword");

2.相邻两个以上activity之间的传值

方法:自定义全局类,用于储存临时数据

代码:

public class Constant {
    public static String aLogin;
    public static String aPassword;
}

//step1
Intent intent = new Intent(OneActivity.this,TwoActivity.class);
Constant.aLogin = aLogin;
Constant.aPassword = aPassword;
startActivity(intent);

//step2:这样我们在其他activity里随时可以取值,不受activity的限制
String aLogin = Constant.aLogin;
String aPassword = Constant.aPassword;
mEmailView.setText(aLogin);
mPasswordView.setText(mPassword);
3.从第一个界面到第二个界面取值并取回第一个界面

代码:

//从一界面跳到二界面
startActivityForResult(intent,code);  //code是请求码,int类型

//二界面
Intent rIntent = new Intent();
rIntent.putExtra("sex",mSex);
rIntent.putExtra("address",mAddress);
setResult(resultCode,getIntent());//resultCode为返回码,用于区分从哪里返回
finish();


//使用onActivityResult方法接受此intent
@Override
protected void onActivityResult(int requestCode,int resultCode,Intent data) {
    user.setName(data.getStringExtra("sex"))
        Toast.makeText(this,data.getStringExtra("sex"),1).show();
    super.onActivityResult(requestCode,resultCode,data);
}
4.使用回调

说明:在two中的定义一个回调接口,one中去实现这个接口原型,two中将你需要传的值(例如email)放到接口中two中执行此接口方法就ok,这样A就拿到了email了。

可以在任何类里使用回调,不仅限于activity方法二页适用于任何类

【注意】:虽然activity的启动模式并非传值,但是当某个activt跳到其他界面,然后关闭在回到当前界面的时候,有的需求需要可以保留本界面的一些数据,比如用户输入还没提交的一些数据,比如editview,等待上传的照片等。我们可以作为一种传值的方式。

activity的四种启动模式简述

1.standard(默认)

说明:standard是默认的启动模式,即如果说明aunchMode属性,则自动就会使用这种启动模式,每次打开需开启新的activity

2.single Top

说明:如果要启动的这个Activity在当前Task中已经存在,并且还处于栈顶的位置,那么系统就不会创建一个该Activity的实例,而是调用栈顶Activity的onNewIntent()方法。声明成这种启动模式的Activity也可以被实例化多次,一个任务当中也可以包含多个这种Activity的实例。举个例子来讲,一个任务的返回栈中有A、B、C、D四个Activity,其中A在最底端,D在最顶端,这个时候如果我们要求再启动一次D,并且D的启动模式是standard,那么系统就会再创建一个D的实例放入到返回栈中,此时栈内元素为A-B-C-D-D。而如果D的启动模式是“single Top”的话,由于D已经是在栈顶了,那么系统就不会再创建一个D实例,而是直接调用D Activity的onNewIntent()方法,此时栈内元素仍然是A-B-C-D.

3.single Task

说明:这种启动模式表示,系统会创建一个新任务,并启动的Activity放入这个新任务的栈底位置。但是,如果现有任务当中已经存在一个该Activity的实例了,那么系统就不会再创建一个它的实例,而且会直接调用它的onNewIntent()方法。声明成这种启动模式的Activity,在同一个任务当中只存在一个实例。注意这里我们所说的启动Activity,都指的是启动其他应用程序中的Activity,因为“single Task”模式在默认情况下只有启动其它程序的Activity才会创建一个新任务,启动自己程序中的Activity还是会使用相同的任务。

4.singleInstance

说明:这种启动模式和“single Task”有点相似,只不过系统不会向声明成“singleInstance”的Activity所在的任务当中再添加其他Activity。也就是说,这种Activity所在的任务中始终只会有一个Activity,通过这个Activity再打开其他的Activity也会被放入到别的任务当中。

布局篇

ConstraintLayout布局

核心:使用ConstraintLayout布局的目的是为了减少嵌套。

TextView
android:gravity="center_vertical|left"  //字体左侧垂直居中
android:text="服务协议"  //文本内容
android:textSize="40sp"  //文本大小

补充:android:gravity是对自身内容的限定
     android:layout_gravity是对当前控件相对其父控件内容的限定
EditText
<EditText
                    android:id="@+id/new_password1"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:layout_alignParentEnd="true"
                    android:layout_marginStart="0dp"
                    android:layout_marginEnd="0dp"
                    android:layout_toEndOf="@+id/textView6"
                    android:ems="10"
                    android:selectAllOnFocus="true"    //获取焦点后全选文本内容
                    android:hint="默认显示"    //默认显示值,相当于placeholder
                    android:background="@null"
                    android:inputType="textPassword" />  //设置文本输入框为密码,password
SimpleDraweeView

说明:加载网络图片

//布局代码
<com.facebook.drawee.view.SimpleDraweeView
                android:id="@+id/user_info_image"  
                android:layout_width="113dp"
                android:layout_height="113dp"
                android:layout_marginStart="56dp"
                android:layout_marginTop="26dp"
                app:layout_constraintStart_toStartOf="parent"
                app:layout_constraintTop_toTopOf="parent"
                app:placeholderImage="@drawable/ic_et_user_name"  //如果未加载网络图片,设置默认显示图片
                app:placeholderImageScaleType="fitXY" />    //图片默认填充满

LinearLayout线性布局

View分割线
//view实现分割线效果
<View
                android:layout_width="match_parent"
                android:layout_height="1dp"
                android:background="@color/gray" />

核心:适合水平数值排列,且每行(列)包含内容简单(内容少)

💙android:orientation=“horizontal”

⭐️horizontal-水平

⭐️vertical-垂直

💙android:gravity & android:layout_gravity

⭐️android:gravity是指本元素的子元素相对它的对齐方式

⭐️android:layout_gravity是指本元素相对它的父元素的对齐方式

🌟其中关于start和left的区分:这里的start和left属性,end和right属性需要注意一下,这里写的是对于中国的情况而言。实际上,他们两个是不同的,left是绝对的左边,而start会根据不同的国家习惯改变。比如在从右向左顺序阅读的国家,start代表的就是在右边

💙layout_height & layout_width & layout_weight(子控件大小)

⭐️wrap_content是根据子控件内容的大小决定大小

⭐️match_parent是子控件填满父容器

⭐️xdp是直接设置大小,dp为单位

RelativeLayout相对布局

核心:相对布局可以让子控件相对于兄弟控件或父控件进行布局,可以设置子控件相对于兄弟控件或父控件进行上下左右对齐(※必须设置id进行管理)

属性值为true或false

⭐️android:layout_centerHrizontal 水平居中

⭐️android:layout_centerVertical 垂直居中

⭐️android:layout_centerInparent 相对于父元素完全居中

⭐️android:layout_alignParentBottom 贴紧父元素的下边缘

⭐️android:layout_alignparentLeft 贴紧父元素的左边缘

⭐️android:layout_alignparentRight 贴紧父元素的右边缘

⭐️android:layout_alignParentTop 贴紧父元素的上边缘

💙属性值必须为id的引用名[“@id/id-name”]

⭐️android:layout_below 在某元素的下方

⭐️android:layout_above 在某元素的的上方

⭐️android:layout_alignTop 本元素的上边缘和某元素的的上边缘对齐

⭐️android:layout_alignLeft 本元素的左边缘和某元素的的左边缘对齐

FrameLayout层布局

核心:常用于fragment组件隐藏/展示,对其填充

布局规范

数据

match_parent:与其父组件保持一致(大小)

wrap_content:与其子组件保持一致(大小)

布局尺寸尽可能选取“dp”作为单位(自适应)

文本信息尽可能选取“sp”作为单位

AndroidManifest.xml(应用清单文件)

activity标签

说明:声明实现应用部分可视化界面的Activity。必须用清单文件中的元素表示所有Activity。系统不会识别和运行任何进行声明的Activity。

1.1intent-filter标签

说明:指定Activity、服务或广播接收器可以响应的Intent类型。Intent过滤器声明其父组件的功能 - Activity或服务可执行哪些操作,以及接收器可处理哪些类型的广播。它让组件可以接收所通告类型的Intent,同时过滤掉对组件没有意义的Intent。

1.1.1action标签

说明:向Intent过滤器添加操作。元素必须包含一个或多个元素。如果Intent过滤器中没有元素,则过滤器不接受任何Intent对象。

1.1.2category标签

说明:向Intent过滤器添加类别名称。

Android开发常用快捷键

生成实例对象插件 Butterknife Injections

需求:自动生成

 @BindView(R.id.content)
    FrameLayout content;

前提条件:使用快捷键前,类一定extends Activity

操作:在activity中,将光标移动到布局文件位置,然后使用alt+insert快捷键,点击Generate Butterknife Injecctions,进行生成设置


全选格式化(规范)代码

需求:保持全局代码规范

前提条件:Ctrl+A 全选代码

操作:按住Ctrl+Alt后,依次点击I、O、L

Android开发 操作代码


🗡需求:修改TextView文本内容

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_agreement, container, false);
        unbinder = ButterKnife.bind(this, view);
        //注意,操作界面信息需在上行代码下书写
        //更改文本标题
        tvTitle.setText(R.string.fragment_agreement_tv);
        return view;
    

🗡需求:隐藏图片ImageView内容

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_agreement, container, false);
        unbinder = ButterKnife.bind(this, view);
        //注意,操作界面信息需在上行代码下书写
        //更改文本标题
        tvTitle.setText(R.string.fragment_agreement_tv);
        //隐藏界面内图片信息
        ivBack.setVisibility(View.GONE);
        return view;
    }

🗡需求:关闭activity页面

//直接调用finish方法即可
...
    finish();

以上是关于Android入门学习笔记(更新中ing)的主要内容,如果未能解决你的问题,请参考以下文章

RabbitMQ学习笔记(持续更新ing)

Pyqt4学习笔记-对话框(更新ing)

一些个人笔记,持续更新ing

solr 学习系列目录——更新ing

AngularJS入门学习笔记一

ECMAScript 6 入门学习笔记(持续更新)