Android UI 模板

简单学习了Android UI 模板,自定义的UI模板,在自己设计的app中可以进行有效的代码复用。在这里做个流程整理,之后再添加漂亮的效果:

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

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


    
        
        
        
        
        
        
        
        
        
        

    
定义模板中属性的名字和取值类型。

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);
        TypedArray ta=context.obtainStyledAttributes(attrs,R.styleable.TopBar);
        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);

        leftparams=new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
        leftparams.addRule(RelativeLayout.ALIGN_PARENT_LEFT, TRUE);//这里的true是relativeLayout定义的常量

        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 文件中使用该组件:

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();

            }
        });
}

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


你可能感兴趣的:(Android整理,笔记)