目录
- 前言
- 一、创建项目
- 二、分析第一个安卓项目
- 总结
- 《END》
前言
任何一个编程语言写出的第一个程序都毫无疑问是HelloWorld,在这里也不例外,一起开启安卓的新世界吧~
一、创建项目
创建项目阿月也找到了相关教程——Brainbg的博客。
已经亲自试验过,写的很详尽,无坑,建议大家直接跟做,跟做后遇到问题再往下看。
只有一个地方阿月和教程上的略有不同。在用数据线连接移动设备时,开发者模式如果找不到可以百度一下对应型号的打开方式,然后开发者选项-打开USB调试:
打开后,电脑会弹出正在设置的小黑框,之后并没有发现AndroidStudio弹出文章里这样的框:
但在AndroidStudio的上方导航栏里已经出现了对应的手机型号:
此时点击图上的绿色运行按钮,手机上就会加载出来自电脑的项目啦~
不难发现,我们只是创建了项目,还并没有编码,项目就已经可以启动了,并且将HelloWorld显示了出来,这是因为AndroidStudio太智能了,已经将简单的内容自动显示出来。下面将分析我们的第一个项目:
二、分析第一个安卓项目
回到AndroidStudio中,先来分析我们第一个项目的目录结构,此处建议跟着《第一行代码》的16-26页熟悉一遍。需要资源可以找我要~
此处只分析HelloWorld项目是如何运行起来的:
首先,打开AndroidMainfest.xml:
会找到如下代码:
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
这段代码表示对MainActivity
这个活动进行注册,没有在AndroidMainfest.xml文件里注册过的活动是不能使用的。其中<intent-filter></intent-filter>
中的两行代码表示MainActivity是这个项目的主活动。在手机上点击应用图标,首先启动的就是这个活动。下面找到MainActivity这个主活动:
可以看到如下代码:
package com.example.helloworld
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
}
}
其中这行代码:class MainActivity : AppCompatActivity()
表示MainActivity
是继承AppCompatActvity
的。AppCompatActvity
是Activity
的子类,Activity
是安卓系统提供的一个活动基类,我们项目中所有的活动都需要继承Activity或Activity的子类才能拥有活动的特性。然后可以看到,MainActivity中的onCreate()
方法是一个活动被创建时必定会执行的方法。在onCreate()
方法的第二行引用了一个layout.activity_main
布局。下面打开这个文件:
可以看到以下代码:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
可以看到在TextView
中有语句:android:text="Hello World!"
。这个就是在手机屏幕上显示的Hello World!字样啦~
总结
以上就是Hello World!显示出来的精简过程啦。相信读完了那十页《第一行代码》再加上上文列出的简要过程后,小伙伴已经对安卓项目有了初步认识。下面阿月要开始安卓语言的学习啦~
《END》