android Hello World示例的内部详细信息

在这里,我们将学习内部细节或Hello Android示例的工作原理。
Android应用程序包含不同的组件,例如java源代码,字符串资源,图像,清单文件,apk文件等。让我们了解android应用程序的项目结构。

android Hello World示例的内部详细信息

文章图片
Java源代码让我们看一下Eclipse IDE创建的Java源文件:
package com.example.helloandroid; import android.os.Bundle; import android.app.Activity; import android.view.Menu; import android.widget.TextView; public class MainActivity extends Activity {//(1) @Override protected void onCreate(Bundle savedInstanceState) {//(2) super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //(3) } @Override public boolean onCreateOptionsMenu(Menu menu) {//(4) // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.activity_main, menu); return true; } }

(1)Activity是一个Java类,它在屏幕上创建一个默认窗口,我们可以在其中放置不同的组件,例如Button,EditText,TextView,Spinner等。它类似于Java AWT的Frame。
它为活动提供生命周期方法,例如onCreate,onStop,OnResume等。
【android Hello World示例的内部详细信息】(2)首次创建Activity类时,将调用onCreate方法。
(3)setContentView(R.layout.activity_main)提供有关我们的布局资源的信息。在这里,我们的布局资源在activity_main.xml文件中定义。
< RelativeLayout xmlns:androclass="http://schemas.android.com/apk/res/android" 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:layout_centerHorizontal="true" android:layout_centerVertical="true" android:text="@string/hello_world" /> < /RelativeLayout>

如你所见,textview由框架自动创建。但是,此字符串的消息是在strings.xml文件中定义的。 @ string / hello_world提供有关textview消息的信息。属性hello_world的值在strings.xml文件中定义。
< ?xml version="1.0" encoding="utf-8"?> < resources> < string name="app_name">helloandroid< /string> < string name="hello_world">Hello world!< /string> < string name="menu_settings">Settings< /string> < /resources>

你可以从此文件更改hello_world属性的值。
生成的R.java文件它是自动生成的文件,其中包含res目录的所有资源的ID。它由aapt(Android资产打包工具)生成。每当你在activity_main上创建任何组件时,都会在R.java文件中创建一个对应的ID,以后可以在Java Source文件中使用该ID。
/* AUTO-GENERATED FILE.DO NOT MODIFY. * * This class was automatically generated by the * aapt tool from the resource data it found.It * should not be modified by hand. */ package com.example.helloandroid; public final class R { public static final class attr { } public static final class drawable { public static final int ic_launcher=0x7f020000; } public static final class id { public static final int menu_settings=0x7f070000; } public static final class layout { public static final int activity_main=0x7f030000; } public static final class menu { public static final int activity_main=0x7f060000; } public static final class string { public static final int app_name=0x7f040000; public static final int hello_world=0x7f040001; public static final int menu_settings=0x7f040002; } public static final class style { /** Base application theme, dependent on API level. This theme is replaced by AppBaseTheme from res/values-vXX/styles.xml on newer devices. Theme customizations available in newer API levels can go in res/values-vXX/styles.xml, while customizations related to backward-compatibility can go here. Base application theme for API 11+. This theme completely replaces AppBaseTheme from res/values/styles.xml on API 11+ devices. API 11 theme customizations can go here. Base application theme for API 14+. This theme completely replaces AppBaseTheme from BOTH res/values/styles.xml and res/values-v11/styles.xml on API 14+ devices. API 14 theme customizations can go here. */ public static final int AppBaseTheme=0x7f050000; /**Application theme. All customizations that are NOT specific to a particular API-level can go here. */ public static final int AppTheme=0x7f050001; } }

APK文件框架会自动创建一个apk文件。如果要在移动设备上运行android应用程序,请传输并安装它。
资源资源它包含资源文件,包括activity_main,字符串,样式等。
清单文件它包含有关软件包的信息,包括活动,服务,内容提供者等组件。
有关清单文件的更多信息,请访问:AndroidManifest.xml文件。

    推荐阅读