本文适合于对Android开发有一定了解,正在Android入门中的小白
Github源码:无
Let's Go Android!
Android 四大组件:
Activity、Service、Broadcast、Content Provider-
(1) R.java文件:在项目中添加的任何资源文件都会在其中生成一个相应的资源id,这个文件永远不要试图手动修改它。
(2)AndroidManifest.xml文件:在程序中定义的四大组件都需要在这个文件里注册。
(3)AndroidManifest.xml文件中注册的Activity中,带有如下代码的表示App启动后首先激活的Activity(第一个界面)
<intent-filter>
<action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /> </intent-filter>
比如,如下两个Activity,ActivityLogin是首先激活的Activity,而ActivityMain则是普通的Activity,需要通过其他方式启动。
<activity
android:name=".ActivityLogin"
android:label="@string/app_name"
android:theme="@style/AppTheme.NoActionBar">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".ActivityMain"
android:theme="@style/Theme.AppCompat.Light.NoActionBar"/>
- Android程序讲究逻辑和视图分离;
Android程序不推荐在程序中对字符串进行硬编码。
①字符串的定义都是在string.xml文件中使用键值对的形式。
②在代码中通过R.string.hello_world可以获得该字符串的引用;
在XML中通过@string/hello_world可以获得该字符串的引用。 - 使用Log打印日志而不要使用System.out
Log.i("TAG","Some information to print");
理由有很多,刚开始的时候我也喜欢用System.out,后来逐渐体会到了Log的优点:五个级别的日志分级别过滤,日志筛选器以及使用最多的关键字过滤等
如下,两行代码
Log.i("TAG_1","something 1");
Log.i("TAG_2","Something 2");
①当没有筛选条件时,日志打印如下(多而杂):
②当筛选条件是"TAG"时,日志打印如下:
③当筛选条件是"TAG_1"时,日志打印如下:
- 在XML中引用一个id,语法
@id/id_name
;
在XML中定义一个id,语法:@+id/id_name
。 - 去除界面的标题栏,可以在配置文件的Activity注册信息中将theme属性改为:
android:theme="@style/Theme.AppCompat.NoActionBar">
网上有许多通过代码设置去除标题栏的方法,实测好多都不成功 - findViewById()方法返回的是一个View对象,我们需要将它向下转型转成Button/TextView/EditText/…等对象
registerTxv = (TextView) findViewById(R.id.text_view_register);
- 销毁一个活动(出栈),调用Activity类中的finish()方法即可,效果等同于按下了Back键;
-
创建目录menu(效果如下图):
I:在res目录下新建menu子文件夹-->新建menu布局文件,添加item子菜单项;
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group android:checkableBehavior="single">
<item
android:id="@+id/seek_mode_menu_item"
android:icon="@mipmap/ic_near_me_white_24dp"
android:title="Add" />
<item
android:id="@+id/setting_menu_list"
android:icon="@mipmap/ic_settings_white_24dp"
android:title="Remove" />
</group>
</menu>
II:在Activity中重写onCreatOptionMenu()方法,显示菜单;
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main,menu);
return true;
}
III:在Activity中重写onOptionItemSelected()方法,定义菜单响应事件。
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()){
case R.id.add_item:
Toast.makeText(MainActivity.this, "Add", Toast.LENGTH_SHORT).show();
break;
case R.id.remove_item:
Toast.makeText(MainActivity.this, "Remove", Toast.LENGTH_SHORT).show();
break;
default:
break;
}
return true;
}
- Intent的启动活动:
(1)显式Intent
Intent intent = new Intent(MainActivity.this, AnotherActivity.class);
startActivity(intent);
(2)隐式Intent
①通过在<activity>标签下配<intent-filter>的内容,可以指定当前活动能够响应的action和category,只有<action>和<category>里的内容全部匹配时,这个活动才能响应该Intent;
②每个Intent中只能指定一个action,但却可以指定多个category(intent.addCategory(…));
③一个activity可以对应多个<action>和多个<category>,只要某个intent中的action和category在这个activity中存在即可响应;
④若两个不同的Activity(可以来自不同的App)均可以响应某一个intent,则会弹出下面的窗口。若有不同的软件都可以处理某一功能时进行选择
注意:<category android:name="android.intent.category.DEFAULT"/>是一种默认的category,在调用startActivit()时可以自动添加这个category到intent中去,所以每个Activity若增加了<intent-filter>标签,则必须加入<category android:name="android.intent.category.DEFAULT"/>,否则不会产生匹配(不匹配原因:系统认为默认的category项目没有存在于Activity中)。
⑤使用隐式Intent,我们不仅可以启动自己程序内的活动,还可以启动其他程序的活动。setDate(),它接受一个Uri对象,主要用于指定当前Intent正在操作的数据,而这些数据通常都是以字符串的形式传入到Uri.parse()方法中解析产生的,例如:
intent.setData(Uri.parse("http://www.baidu.com"));
intent.setData(Uri.parse("tel:10086"));
我们还可以在<intent-filter>标签中再配置一个<date>标签,用于更精确地指定当前活动能够响应什么类型的数据。
<activity android:name=".FifthActivity">
<intent-filter>
<action android:name="android.intent.action.VIEW"/>
<category android:name="android.intent.category.DEFAULT"/>
<data android:scheme="http"/>
</intent-filter>
</activity>
例:上面这个Activity可以响应http协议的intent。
- Intent传递数据
(1)向下一个活动传递数据:
intent.putExtra(“键值对名称”,键值对内容);
例:
Intent intent = new Intent(thisActivity.this,MainActivity.class);
intent.putExtra("Data", 123);
startActivity(intent);
从新启动的活动中得到上个活动通过Intent传过来的数据
Intent intent = getIntent();
例:
Intent receivedIntent = getIntent();
int receiveData = receivedIntent.getIntExtra("Data",0);
getIntExtra()的第二个参数是默认参数,即:出现错误无法从Intent取出数据时,receiveData 的默认赋值
(2)返回数据给上一个活动
Activity中还有一个startActivityForResult(Intent intent , int requestCode)方法也是用于启动活动的,但这个方法期望在活动销毁的时候能够返回一个结果给上一个活动;
setResult(int resultCode , Intent intent)方法,专门用于向上一个活动返回数据,第一个参数用于返回处理结果,一般只用RESULT_OK , RESULT_CANCELED这两个值;一般还要在后启动的Activity里面重写onBackPressed()方法;
onActivityResult(int requestCode , int resultCode , Intent data)方法,用于接收返回的数据。
例:
①.Activity-A启动Activity-B
Intent intent = new Intent(FirstActivity.this, SecondActivity.class);
startActivityForResult(intent, 1);
②.Activity-B销毁后返回数据给Activity-A(backImgBtn的点击事件是销毁SecondActivity)
backImgBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent = new Intent();
intent.putExtra("data_return", "Hello FirstActivity");
setResult(RESULT_OK, intent);
finish();
}
});
③.Activity-A中接受Activity-B销毁时返回的数据
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
switch (requestCode) {
case 1:
if (resultCode == RESULT_OK) {
String returnedData = data.getStringExtra("data_return");
Log.i("FirstActivity",returnedData);
}
break;
default:
break;
}
}
链接:《第一行代码》作者郭霖--博客
原创文章,转载请注明出处: http://www.jianshu.com/p/4aacc6be9d51