大家好 现在由于是国庆 不知道大家过的都怎么样 本来我是想 这博客估计是没什么人看 自己记录记录随笔罢了
但我发现 访问人数还是有一点的 虽然不能跟大牛们比(笑) 因此我觉得既然有人看 就要把这些东西写的通俗易懂
我见过很多博客 有些写的确实很好 一看就能明白而有的则很模棱两可 问了博主其中之一算法 回复说是copy的 自己也不怎么懂
但是能用。虽然解决了问题 但未免感觉不负责任 我也是看过代码大全 上面有一句话很经典:不要去引用那些你不知道原理的
代码。但现实却是由于周期的限制 我们不得不以解决问题为前提 然后再去考虑其中的道理 这实在是自相矛盾。
我是一个比较喜欢玩游戏的人 我很坦白 而且我也是对各种主机游戏比较了解 (PS:最近就在玩ps4上的fifa15和闪之轨迹2)
我很纳闷为什么人家的game做的如此丰富 而我们最多的只有武侠题材的页游 发现自己扯得有点多 还是回到正题
我们来说说actvity。
究竟什么是actvity 英文名解释曰活动 而大多数人都理解为界面 的确 我们在写一个界面的时候 以前通常的做法是要写一个actvity加载布局
但是久而久之 我们问下自己 actvity真的是界面么。
打断一下 这里照顾一下刚刚接触andriod的人 我们来建立一个标准的demo应用
打开eclipse 使用快捷键 或者菜单新建工程
直接下一步 下一步就可以了
最初的代码
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
}
也许你连看都不用看 这一段实在太熟悉了 而 setContentView(R.layout.activity_main);
这一段控制着 你要加载什么布局 我们可以修改
找到res/layout的布局文件
这里 我们引入几个新的控件 textView editText imageView imageButton 和button
你可以理解为 文字 输入框 图 图形按钮和普通按钮
我们来修改下这里的布局
<LinearLayout xmlns:android="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"
android:orientation="vertical"
>
<TextView
android:id="@+id/tv_demo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/demo" />
<EditText
android:id="@+id/et_type"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:hint="@string/type_something" />
<ImageView
android:id="@+id/iv_pic1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:contentDescription="@null"
android:src="@drawable/pic1"/>
<ImageButton
android:id="@+id/ib_wifi"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:contentDescription="@null"
android:background="@drawable/wifi" />
<Button
android:id="@+id/bt_click"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/click" />
</LinearLayout>
很简单的几点 1 利用线性布局 控制控件的排列 orientation
2 利用id 以便日后找到控件
3 layout_width layout_height 分别为宽高 而text选择引用string 也是谷歌推荐的一种方式 string在res/values里 你很容易找得到
4 给editText设 hint是常用的一种方式 效果下图你会看到
5 用到image系列组件时 最好设置contentDescription 不然会报黄线 imageview设置src imageButton推荐设置background
效果图
这里看到 请输入那里就是hint的效果 一个简单的活动就完成了
但是 仅仅这样是不够的 我们要实现一种简单的交互效果 简单来说就是点击什么弹出一个东西提示一下
这个东西在andriod中叫做吐司
我们看下代码
public class MainActivity extends Activity implements OnClickListener {
private TextView tv_demo;
private EditText et_type;
private ImageView iv_pic1;
private ImageButton ib_wifi;
private Button bt_click;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.activity_main);
this.getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
findview();
initview();
setListener();
}
private void initview() {
tv_demo.setText("初次的actvity");
}
private void setListener() {
iv_pic1.setOnClickListener(this);
ib_wifi.setOnClickListener(this);
bt_click.setOnClickListener(this);
}
private void findview() {
tv_demo = (TextView) findViewById(R.id.tv_demo);
et_type = (EditText) findViewById(R.id.et_type);
iv_pic1 = (ImageView) findViewById(R.id.iv_pic1);
ib_wifi = (ImageButton) findViewById(R.id.ib_wifi);
bt_click = (Button) findViewById(R.id.bt_click);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.iv_pic1:
if(iv_pic1.isClickable())
showToast("这是一个灵梦");
break;
case R.id.ib_wifi:
if(ib_wifi.isClickable())
showToast("wifi打开");
break;
case R.id.bt_click:
if(bt_click.isClickable())
showToast("进入下一界面");
break;
default:
break;
}
}
private void showToast(String content) {
Toast.makeText(this,content,Toast.LENGTH_LONG).show();
}
}
1这里很简单 首先是全屏 有两行代码
requestWindowFeature(Window.FEATURE_NO_TITLE); 只是去除标题
而后者 则是真全屏
2获得控件的方法在findview里 代码则是findviewbyid来找到
3initview 方法里做了初始化 设置了tv的文字显示
4 setListener里设置了监听 通过实现 OnClickListener方法来实现
5 设置一个弹出吐司的方法 而核心代码吐司 Toast.makeText(this,content,Toast.LENGTH_LONG).show();
三个参数 1 上下文 2 内容 3 时长
而andriod的核心配置 maniest文件中
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.act"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="17" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.example.act.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
package="com.example.act" 是包名称
android:versionCode="1"是你的应用代码版本为1
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="17" />
上为最低支持sdk版本 下为目标版本 8为andriod 2.2
应用用application节点分开
而要想让你的活动成为第一个主页面 则需要加intent-filter
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
这里要注意 往后 我们每写一个act 都要继承actvity 而每次在清单文件里要配置act节点
最重要的属性是name 你也可以这么写
<activity android:name="com.example.act.TestActivity"/>
好了 关于活动的第一部分内容 我们就先到这里
下一次咱来说说活动的生命周期 以及如何在多个活动之间进行数据交互