Android 自定义控件 仿乐Phone UI
2010-09-29 08:44
459 查看
本来想自己重新写个类似的UI,没想用snakeLayout就直接能成了,出乎意料,画了点时间设计好位置,效果如下:
主文件:newSnake.java
package com.newSnake;
import android.app.Activity;
import android.os.Bundle;
public class newSnake extends Activity {
/** Called when the activity is first created. */
SnakeLayout mSnake;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
mSnake = (SnakeLayout)findViewById(R.id.my_snake);
mSnake.addRec(R.drawable.p0);
mSnake.addRec(R.drawable.p1);
mSnake.addRec(R.drawable.p2);
mSnake.addRec(R.drawable.p3);
mSnake.addRec(R.drawable.p4);
mSnake.addRec(R.drawable.p5);
mSnake.addRec(R.drawable.p6);
mSnake.addRec(R.drawable.p7);
mSnake.addRec(R.drawable.p8);
mSnake.Init();
}
}
布局文件:main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:snake="http://schemas.android.com/apk/res/com.newSnake"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center"
android:background="#FFFFFF">
<com.newSnake.SnakeLayout android:layout_width="200dip" android:layout_weight="1"
android:id="@+id/my_snake" android:layout_height="330dip"
snake:selectImg="3">
<FrameLayout android:layout_width="fill_parent" android:orientation="vertical"
android:layout_height="wrap_content" android:id="@id/snakeContent">
<ImageView android:layout_width="140dip" android:id="@id/snakeImg0"
android:layout_height="60dip"
android:paddingLeft="60dip"
android:paddingTop="0dip"/>
<ImageView android:layout_width="160dip" android:id="@id/snakeImg1"
android:layout_height="105dip"
android:paddingLeft="40dip"
android:paddingTop="15dip"/>
<ImageView android:layout_width="180dip" android:id="@id/snakeImg2"
android:layout_height="165dip"
android:paddingLeft="20dip"
android:paddingTop="45dip"/>
<ImageView android:layout_width="140dip" android:id="@id/snakeImg6"
android:layout_height="330dip"
android:paddingLeft="60dip"
android:paddingTop="270dip"/>
<ImageView android:layout_width="160dip" android:id="@id/snakeImg5"
android:layout_height="315dip"
android:paddingLeft="40dip"
android:paddingTop="225dip"/>
<ImageView android:layout_width="180dip" android:id="@id/snakeImg4"
android:layout_height="285dip"
android:paddingLeft="20dip"
android:paddingTop="165dip"/>
<ImageView android:layout_width="200dip" android:id="@id/snakeImg3"
android:layout_height="240dip"
android:paddingLeft="0dip"
android:paddingTop="90dip"/>
</FrameLayout>
</com.newSnake.SnakeLayout>
</LinearLayout>
主文件:newSnake.java
package com.newSnake;
import android.app.Activity;
import android.os.Bundle;
public class newSnake extends Activity {
/** Called when the activity is first created. */
SnakeLayout mSnake;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
mSnake = (SnakeLayout)findViewById(R.id.my_snake);
mSnake.addRec(R.drawable.p0);
mSnake.addRec(R.drawable.p1);
mSnake.addRec(R.drawable.p2);
mSnake.addRec(R.drawable.p3);
mSnake.addRec(R.drawable.p4);
mSnake.addRec(R.drawable.p5);
mSnake.addRec(R.drawable.p6);
mSnake.addRec(R.drawable.p7);
mSnake.addRec(R.drawable.p8);
mSnake.Init();
}
}
布局文件:main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:snake="http://schemas.android.com/apk/res/com.newSnake"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center"
android:background="#FFFFFF">
<com.newSnake.SnakeLayout android:layout_width="200dip" android:layout_weight="1"
android:id="@+id/my_snake" android:layout_height="330dip"
snake:selectImg="3">
<FrameLayout android:layout_width="fill_parent" android:orientation="vertical"
android:layout_height="wrap_content" android:id="@id/snakeContent">
<ImageView android:layout_width="140dip" android:id="@id/snakeImg0"
android:layout_height="60dip"
android:paddingLeft="60dip"
android:paddingTop="0dip"/>
<ImageView android:layout_width="160dip" android:id="@id/snakeImg1"
android:layout_height="105dip"
android:paddingLeft="40dip"
android:paddingTop="15dip"/>
<ImageView android:layout_width="180dip" android:id="@id/snakeImg2"
android:layout_height="165dip"
android:paddingLeft="20dip"
android:paddingTop="45dip"/>
<ImageView android:layout_width="140dip" android:id="@id/snakeImg6"
android:layout_height="330dip"
android:paddingLeft="60dip"
android:paddingTop="270dip"/>
<ImageView android:layout_width="160dip" android:id="@id/snakeImg5"
android:layout_height="315dip"
android:paddingLeft="40dip"
android:paddingTop="225dip"/>
<ImageView android:layout_width="180dip" android:id="@id/snakeImg4"
android:layout_height="285dip"
android:paddingLeft="20dip"
android:paddingTop="165dip"/>
<ImageView android:layout_width="200dip" android:id="@id/snakeImg3"
android:layout_height="240dip"
android:paddingLeft="0dip"
android:paddingTop="90dip"/>
</FrameLayout>
</com.newSnake.SnakeLayout>
</LinearLayout>
相关文章推荐
- Android自定义控件实现环形播放进度条
- android自定义控件(一) 官方文档的翻译
- android 自定义控件 Switch
- Android 自定义控件(画圆)并且可以拖动
- Android 实现形态各异的双向侧滑菜单 自定义控件来袭
- Android自定义控件之onMeasure
- Android快乐贪吃蛇游戏实战项目开发教程-02虚拟方向键(一)自定义控件概述
- android 自定义控件 自定义属性详细介绍
- Android自定义控件(一)
- Android自定义控件无法通过代码修改大小、高宽,setMinimumHeight无效的问题
- android自定义控件二(转载)
- Android 自定义控件PullToZoomListView
- androidの自定义控件View在Activity中使用findByViewId得到结果为null,解决方法。。
- android 代码家自定义控件
- Android自定义控件实战——滚动选择器PickerView
- Android自定义控件——仿淘宝、网易、彩票等广告条、Banner的制作
- 【android自定义控件】TextView详解及自定义<一>
- Android 实现形态各异的双向侧滑菜单 自定义控件来袭
- android自定义控件
- Android自定义控件之Shader(着色器/渲染器)