Android UI 模板

来源:互联网 发布:mp3铃声截取软件 编辑:程序博客网 时间:2024/04/28 15:14
简单学习了Android UI 模板,自定义的UI模板,在自己设计的app中可以进行有效的代码复用。在这里做个流程整理,之后再添加漂亮的效果:

首先加个在线阅读Android 源码的链接点击打开链接  花个时间阅读一下系统的封装方法对学习Android帮助还是挺大滴。

1、在工程目录的res/values文件中添加atts.xml文件,设计需要的属性:

<resources>    <declare-styleable name="TopBar">        <attr name="TitleText" format="string"/>        <attr name="TitleColor" format="color"/>        <attr name="TextSize" format="dimension"/>        <attr name="LeftText" format="string"/>        <attr name="LeftColor" format="color"/>        <attr name="LeftBackground" format="color|reference"/>        <!--类型不一定,使用reference-->        <attr name="RightText" format="string"/>        <attr name="RightColor" format="color"/>        <attr name="RightBackground" format="color|reference"/>    </declare-styleable></resources>
<attr name="" format=“”> 定义模板中属性的名字和取值类型。

2.定义View

public class TopBar extends RelativeLayout {    private Button leftbutton,rightbutton;    private TextView tvTitle;    //获取组件中的属性    private String titleText,leftText,rightText;    private int titleColor,leftColor,rightColor;    private float titleSize;    private Drawable leftBackground,rightBackground;    private LayoutParams leftparams,rightparams,titleparams;    private OnTopBarListenner listenner;    public interface OnTopBarListenner{        public void leftclick();        public void rightclick();    }    public void setOnClikTopBarListenner(OnTopBarListenner listenner){        this.listenner=listenner;    }    public TopBar(Context context, AttributeSet attrs) {        super(context, attrs);       <strong> TypedArray ta=context.obtainStyledAttributes(attrs,R.styleable.TopBar);</strong>        titleColor=ta.getColor(R.styleable.TopBar_TitleColor, 0);        titleSize=ta.getDimension(R.styleable.TopBar_TextSize, 0);        titleText=ta.getString(R.styleable.TopBar_TitleText);                leftText=ta.getString(R.styleable.TopBar_LeftText);        leftColor=ta.getColor(R.styleable.TopBar_LeftColor, 0);        leftBackground=ta.getDrawable(R.styleable.TopBar_LeftBackground);        rightText=ta.getString(R.styleable.TopBar_RightText);        rightColor=ta.getColor(R.styleable.TopBar_RightColor, 0);        rightBackground=ta.getDrawable(R.styleable.TopBar_RightBackground);        ta.recycle();        leftbutton=new Button(context);        rightbutton=new Button(context);        tvTitle=new TextView(context);                leftbutton.setText(leftText);       // leftbutton.setBackground(leftBackground);//这里注意sdk不能低于16        leftbutton.setTextColor(leftColor);        rightbutton.setText(rightText);       // rightbutton.setBackground(rightBackground);//这里注意sdk不能低于16        rightbutton.setTextColor(rightColor);        tvTitle.setText(titleText);        tvTitle.setTextColor(titleColor);        tvTitle.setTextSize(titleSize);        tvTitle.setGravity(Gravity.CENTER);        setBackgroundColor(0x33a3dcff);       <strong> leftparams=new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);        leftparams.addRule(RelativeLayout.ALIGN_PARENT_LEFT, TRUE);//这里的true是relativeLayout定义的常量</strong>        rightparams=new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);        rightparams.addRule(RelativeLayout.ALIGN_PARENT_RIGHT,TRUE);        titleparams=new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.MATCH_PARENT);        titleparams.addRule(RelativeLayout.CENTER_IN_PARENT,TRUE);        addView(leftbutton, leftparams);        addView(rightbutton, rightparams);        addView(tvTitle,titleparams);        leftbutton.setOnClickListener(new OnClickListener() {            @Override            public void onClick(View v) {                listenner.leftclick();            }        });        rightbutton.setOnClickListener(new OnClickListener() {            @Override            public void onClick(View v) {                listenner.rightclick();            }        });    }}

利用接口回调机制,我们封装好用户可以自定义的监听事件,首先定义一个接口interface OnClickListenner{

};然后向用户暴露一个方法:public void SetOnClickListenner(OnClickListener listenner){this.listener=listener};

然后为button(组件)注册这个监听事件,在监听器中执行接口的方法,那么用户只需要实现了接口,再传递给我们暴露的方法,就实现了简单的监听。

同样的道理,如果要实现对模板中组件的操作,只需要在设计View 的时候暴露出公共方法。

3.引用设计的View,和系统提供View 一样调用即可。

xml 文件中使用该组件:

<com.yangyang.myapplication.TopBar       android:id="@+id/topbar"       android:layout_width="match_parent"       android:layout_height="40dp"       custom:LeftColor="@color/colorAccent"       custom:LeftText="返回"       custom:RightColor="@color/colorAccent"       custom:RightText="更多"       custom:TextSize="10sp"       custom:TitleColor="@color/colorAccent"       custom:TitleText="朋友圈"       >
</pre><p></p><p><span style="font-family:Microsoft YaHei; font-size:18px">JAVA文件中调用:</span></p><p><span style="font-family:Microsoft YaHei; font-size:18px"></span></p><pre code_snippet_id="1601001" snippet_file_name="blog_20160307_6_880744" name="code" class="java">protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        TopBar topbar= (TopBar) findViewById(R.id.topbar);        im= (ImageView) findViewById(R.id.imageView);        topbar.setOnClikTopBarListenner(new TopBar.OnTopBarListenner() {            @Override            public void leftclick() {                Toast.makeText(MainActivity.this,"点击了左键",Toast.LENGTH_SHORT).show();            }            @Override            public void rightclick() {                Toast.makeText(MainActivity.this,"点击了右键",Toast.LENGTH_SHORT).show();            }        });}

以上只是简单的基本学习过程,模板很简单还需要改进。


0 0