百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

使用Kotlin实战一个Android的HelloWorld

yuyutoo 2025-01-13 18:58 2 浏览 0 评论

一、内容概要

本文主要内容是通过通过AndroidStudio开发工具开发一个基于纯Kotlin语言的Android应用程序,这个程序也非常的简单,因为它只会输出一个HelloWorld。

我默认大家都是稍微懂一点Android开发的,至少jdk、sdk、androidstudio的安装、真机、模拟器连接电脑这些基础的东西会一点。因为在今后的文章中基本上都会是实战,实战后会详细的解释代码中用到的一些新的特性、新功能以及相关注意事项。

二、实战部分

  1. 打开AndroidStudio,并准备新建一个项目

2.选择一个空白项目作为项目的主模板,并点击next进入下一步


3.定义项目名称、定义包名名称(包名会自动输入,如果需要更改直接编辑即可)、并选择Kotlin为app的开发语言,并点击finish进入AndroidStudio主界面


4.进入AndroidStudio主界面并了解其目录结构



5.链接真机,点击运行按钮看下运行后的效果,如下图所示,则会在主界面显示出HelloWorld


三、代码讲解部分

以上就是新建一个Kotlin项目的并运行显示的步骤,在这个目录结构中我们目前只用关注四个文件。

1.MainActivity.kt App运行的主页,此页就是一个Activity,其在AndroidManifest.xml中有配置

2.activity_main.xml 布局配置文件,可视化配置页面要显示的内容

3.build.gradle app目录下的主配置文件,主要用于配置签名、版本、运行环境以及引入第三方库

4.AndroidManifest.xml 主配置文件,用来配置Android系统中的四大组件,如:Activity、Service、BroadcastReceiver、ContentProvider、渠道、权限等配置

下面一一来介绍这部分的内容

1.MainActivity.kt

/**在Kotlin中类和java一样依然使用的是class关键字,只是在Kotlin中默认情况下类是不能被继承的
/*如下面这个类就不能被继承,如果一定想要继承某个类,需要在class前面加上open关键字或者此类是
/*抽象类才行(抽象类在Kotlin中默认是可以被继承的)
/*在java中继承用extends关键字,但是到了Kotlin中继承只能用“:”来表示,java中实现接口用
/*implements 而Kotlin中依然用“:”来表示。就像下面的MainActivity继承AppCompatActivity()
/*一样。
/*在继承关系中必须强调一点,大家需要注意下,Kotlin中继承一个类必须指明其默认的构造方法,即在父类
/*后面加上一对“()”
*/
class MainActivity : AppCompatActivity() {
		//Activity的回调函数OnCreate,其中savedInstanceState:Bundle?代表Bundle可以为空
   //Kotlin中的变量命名必须是变量名:类型
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
       //给Activity设置布局
        setContentView(R.layout.activity_main)
    }
}

2.activity_main.xml

android中的布局文件可以可视化的进行布局,用户根据需要可以切换到代码模式、设置模式或代码和设置互存的模式。如下图所示



<?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">
		<!--Android中的控件,TextView代表一个文本其继承自View-->
    <!--android:代表控件的属性,例如:android:text="helloworld"代表给这个控件-->
    <!--  设置值,让其显示helloworld-->
    <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>

3.build.gradle

apply plugin: 'com.android.application'
//引入kotlin核心插件
apply plugin: 'kotlin-android'
//引入kotlin扩展插件
apply plugin: 'kotlin-android-extensions'

android {
  	//android项目编译版本
    compileSdkVersion 30
  	//打包工具版本
    buildToolsVersion "29.0.2"
		//默认配置
    defaultConfig {
      //appid,你可以把其理解成java的包名(在项目中是唯一的,当然可以通过多渠道配置不同的id)
        applicationId "com.yw.kotlin_helloworld"
        //最小sdk版本
        minSdkVersion 23
      	//目标sdk版本
        targetSdkVersion 30
      	//版本号
        versionCode 1
      	//版本名称
        versionName "1.0"
				
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }

    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }

}
//引入的第三方库的配置
dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    //引入kotlin的核心sdk
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
  	//支持androidx
    implementation 'androidx.appcompat:appcompat:1.1.0'
  	//支持android的扩展库ktx,使用和这个库可以给android开发提供一些方便,例如:我们可以完全
  	//避免布局文件的findViewById,这个后面会讲到
    implementation 'androidx.core:core-ktx:1.3.0'
  	//为减少布局层级给造出来的一个布局类,当前xml中使用的就是这个插件的类
    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
  	//以下是单元测试的一些内容,暂不做介绍
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'androidx.test.ext:junit:1.1.1'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
}

4.AndroidManifest.xml

android中的四大组件,除了BroadcastReceiver的动态注册与解注册,都需要在这个文件中进行配置,其中Activity组件是在所有的组件中被使用次数最多的一个组件,大家对此要保持高度关注。

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.yw.kotlin_helloworld">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        //此处是我们新建的MainActivity的配置,可以用相对路径也可以用绝对路径,此处用的是相对
        //路径,因为上面的package="com.yw.kotlin_helloworld"已经把完整包名写好了,所以只
        //需要贴上相对路径就行了
        <activity android:name=".MainActivity">
            <intent-filter>
         				//此处代表此MainActivity是我们的主Activity,是入口Activity
          			//记住,以后凡是看到这个action,那么此activity必定是app的口入Activity
          			//也就是点击app图标打开后的第一个你看到的Activity
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

四、总结语

到此一个非常简单的用Kotlin作为主开发语言的Android项目就算是完成了,那么快速开启你的HelloWorld之旅吧。

相关推荐

如何在HTML中使用JavaScript:从基础到高级的全面指南!

“这里是云端源想IT,帮你...

推荐9个Github上热门的CSS开源框架

大家好,我是Echa。...

前端基础知识之“CSS是什么?”_前端css js

...

硬核!知网首篇被引过万的论文讲了啥?作者什么来头?

整理|袁小华近日,知网首篇被引量破万的中文论文及其作者备受关注。知网中心网站数据显示,截至2021年7月23日,由华南师范大学教授温忠麟等人发表在《心理学报》2004年05期上的学术论文“中介效应检验...

为什么我推荐使用JSX开发Vue3_为什么用vue不用jquery

在很长的一段时间中,Vue官方都以简单上手作为其推广的重点。这确实给Vue带来了非常大的用户量,尤其是最追求需求开发效率,往往不那么在意工程代码质量的国内中小企业中,Vue占据的份额极速增长...

【干货】一文详解html和css,前端开发需要哪些技术?
【干货】一文详解html和css,前端开发需要哪些技术?

网站开发简介...

2025-02-20 18:34 yuyutoo

分享几个css实用技巧_cssli

本篇将介绍几个css小技巧,目录如下:自定义引用标签的符号重置所有标签样式...

如何在浏览器中运行 .NET_怎么用浏览器运行代码

概述:...

前端-干货分享:更牛逼的CSS管理方法-层(CSS Layers)

使用CSS最困难的部分之一是处理CSS的权重值,它可以决定到底哪条规则会最终被应用,尤其是如果你想在Bootstrap这样的框架中覆盖其已有样式,更加显得麻烦。不过随着CSS层的引入,这一...

HTML 基础标签库_html标签基本结构
HTML 基础标签库_html标签基本结构

HTML标题HTML标题(Heading)是通过-...

2025-02-20 18:34 yuyutoo

前端css面试20道常见考题_高级前端css面试题

1.请解释一下CSS3的flexbox(弹性盒布局模型),以及适用场景?display:flex;在父元素设置,子元素受弹性盒影响,默认排成一行,如果超出一行,按比例压缩flex:1;子元素设置...

vue引入外部js文件并使用_vue3 引入外部js

要在Vue中引入外部的JavaScript文件,可以使用以下几种方法:1.使用``标签引入外部的JavaScript文件。在Vue的HTML模板中,可以直接使用``标签来引入外部的JavaScrip...

网页设计得懂css的规范_html+css网页设计

在初级的前端工作人员,刚入职的时候,可能在学习前端技术,写代码不是否那么的规范,而在工作中,命名的规范的尤为重要,它直接与你的代码质量挂钩。网上也受很多,但比较杂乱,在加上每年的命名都会发生一变化。...

Google在Chrome中引入HTML 5.1标记

虽然负责制定Web标准的WorldWideWebConsortium(W3C)尚未宣布HTML5正式推荐规格,而Google已经迁移到了HTML5.1。即将发布的Chrome38将引入H...

HTML DOM 引用( ) 对象_html中如何引用js

引用对象引用对象定义了一个同内联元素的HTML引用。标签定义短的引用。元素经常在引用的内容周围添加引号。HTML文档中的每一个标签,都会创建一个引用对象。...

取消回复欢迎 发表评论: