自定义View实现东购物车加减控件
2017-10-26 10:42
429 查看
1、自定义属性,控制加减按钮的大小
values文件夹下创建attrs文件
<declare-styleable name="AddSubView">
<attr name="add_sub_width" format="dimension"/>
<attr name="add_sub_height" format="dimension"/>
</declare-styleable>
2、定义边框背景 drawable中定义shape
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<solid android:color="#FFFFFF"/>
<stroke android:color="#666666" android:width="1px"/>
<size android:width="20dp" android:height="20dp"/>
</shape>
3、定义组合控件的布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/tv_sub"
android:layout_width="20dp"
android:text="-"
android:background="@drawable/add_sub_bg"
android:gravity="center"
android:layout_height="20dp" />
<TextView
android:id="@+id/tv_num"
android:layout_width="20dp"
android:text="1"
android:layout_weight="1"
android:background="@drawable/add_sub_bg"
android:gravity="center"
android:layout_height="20dp" />
<TextView
android:id="@+id/tv_add"
android:layout_width="20dp"
android:text="+"
android:background="@drawable/add_sub_bg"
android:gravity="center"
android:layout_height="20dp" />
</LinearLayout>
4、具体代码如下
import android.content.Context;
import android.content.res.TypedArray;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView;
public class AddSubView extends LinearLayout implements View.OnClickListener {
private int width;
private int height;
private TextView mTvAdd;
private TextView mTvSub;
private TextView mTvNum;
private boolean setMaxNum = false;
private boolean setMinNum = false;
private int maxNum = 0;
private int minNum = 0;
private AddSubClickListener addSubClickListener;
public AddSubView(Context context) {
this(context, null);
}
public AddSubView(Context context, @Nullable AttributeSet attrs) {
this(context, attrs, 0);
}
public AddSubView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init(context, attrs);
}
private void init(Context context, AttributeSet attrs) {
TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.AddSubView);
width = typedArray.getDimensionPixelSize(R.styleable.AddSubView_add_sub_width, 20);
height = typedArray.getDimensionPixelSize(R.styleable.AddSubView_add_sub_height, 20);
typedArray.recycle();
initView(context);
}
private void initView(Context context) {
View view = LayoutInflater.from(context).inflate(R.layout.add_sub_view, this);
mTvAdd = view.findViewById(R.id.tv_add);
mTvSub = view.findViewById(R.id.tv_sub);
mTvNum = view.findViewById(R.id.tv_num);
LayoutParams params = new LayoutParams(width, height);
mTvAdd.setLayoutParams(params);
mTvSub.setLayoutParams(params);
LayoutParams numParams = new LayoutParams(LayoutParams.WRAP_CONTENT, height);
numParams.weight = 1;
mTvNum.setLayoutParams(numParams);
mTvSub.setOnClickListener(this);
mTvAdd.setOnClickListener(this);
}
public void setMaxNum(int maxNum) {
setMaxNum = true;
this.maxNum = maxNum;
}
public void setMinNum(int minNum) {
setMinNum = true;
this.minNum = minNum;
}
public void setNum(int num) {
if (setMinNum) {
if (num <= minNum) {
mTvSub.setEnabled(false);
}
}
if (setMaxNum) {
if (num >= maxNum) {
mTvAdd.setEnabled(false);
}
}
String s = Integer.toString(num);
mTvNum.setText(s);
}
public int getNum(){
String s = mTvNum.getText().toString();
return Integer.parseInt(s);
}
public void setAddSubClickListener(AddSubClickListener addSubClickListener){
this.addSubClickListener = addSubClickListener;
}
@Override
public void onClick(View view) {
if (addSubClickListener != null) {
if (view.getId() == R.id.tv_add) {
String s = mTvNum.getText().toString();
int num = Integer.parseInt(s);
if (setMaxNum) {
if (num < maxNum) {
num++;
if (num == maxNum) {
mTvAdd.setEnabled(false);
}
}
} else {
num++;
}
if (!mTvSub.isEnabled()) {
mTvSub.setEnabled(true);
}
mTvNum.setText(Integer.toString(num));
addSubClickListener.addSubClickListener(num);
} else if (view.getId() == R.id.tv_sub) {
String s = mTvNum.getText().toString();
int num = Integer.parseInt(s);
if (setMinNum) {
if (num > minNum) {
num--;
if (num == minNum) {
mTvSub.setEnabled(false);
}
}
} else {
num--;
}
if (!mTvAdd.isEnabled()) {
mTvAdd.setEnabled(true);
}
mTvNum.setText(Integer.toString(num));
addSubClickListener.addSubClickListener(num);
}
}
}
public interface AddSubClickListener {
void addSubClickListener(int num);
}
}
values文件夹下创建attrs文件
<declare-styleable name="AddSubView">
<attr name="add_sub_width" format="dimension"/>
<attr name="add_sub_height" format="dimension"/>
</declare-styleable>
2、定义边框背景 drawable中定义shape
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<solid android:color="#FFFFFF"/>
<stroke android:color="#666666" android:width="1px"/>
<size android:width="20dp" android:height="20dp"/>
</shape>
3、定义组合控件的布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/tv_sub"
android:layout_width="20dp"
android:text="-"
android:background="@drawable/add_sub_bg"
android:gravity="center"
android:layout_height="20dp" />
<TextView
android:id="@+id/tv_num"
android:layout_width="20dp"
android:text="1"
android:layout_weight="1"
android:background="@drawable/add_sub_bg"
android:gravity="center"
android:layout_height="20dp" />
<TextView
android:id="@+id/tv_add"
android:layout_width="20dp"
android:text="+"
android:background="@drawable/add_sub_bg"
android:gravity="center"
android:layout_height="20dp" />
</LinearLayout>
4、具体代码如下
import android.content.Context;
import android.content.res.TypedArray;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView;
public class AddSubView extends LinearLayout implements View.OnClickListener {
private int width;
private int height;
private TextView mTvAdd;
private TextView mTvSub;
private TextView mTvNum;
private boolean setMaxNum = false;
private boolean setMinNum = false;
private int maxNum = 0;
private int minNum = 0;
private AddSubClickListener addSubClickListener;
public AddSubView(Context context) {
this(context, null);
}
public AddSubView(Context context, @Nullable AttributeSet attrs) {
this(context, attrs, 0);
}
public AddSubView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init(context, attrs);
}
private void init(Context context, AttributeSet attrs) {
TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.AddSubView);
width = typedArray.getDimensionPixelSize(R.styleable.AddSubView_add_sub_width, 20);
height = typedArray.getDimensionPixelSize(R.styleable.AddSubView_add_sub_height, 20);
typedArray.recycle();
initView(context);
}
private void initView(Context context) {
View view = LayoutInflater.from(context).inflate(R.layout.add_sub_view, this);
mTvAdd = view.findViewById(R.id.tv_add);
mTvSub = view.findViewById(R.id.tv_sub);
mTvNum = view.findViewById(R.id.tv_num);
LayoutParams params = new LayoutParams(width, height);
mTvAdd.setLayoutParams(params);
mTvSub.setLayoutParams(params);
LayoutParams numParams = new LayoutParams(LayoutParams.WRAP_CONTENT, height);
numParams.weight = 1;
mTvNum.setLayoutParams(numParams);
mTvSub.setOnClickListener(this);
mTvAdd.setOnClickListener(this);
}
public void setMaxNum(int maxNum) {
setMaxNum = true;
this.maxNum = maxNum;
}
public void setMinNum(int minNum) {
setMinNum = true;
this.minNum = minNum;
}
public void setNum(int num) {
if (setMinNum) {
if (num <= minNum) {
mTvSub.setEnabled(false);
}
}
if (setMaxNum) {
if (num >= maxNum) {
mTvAdd.setEnabled(false);
}
}
String s = Integer.toString(num);
mTvNum.setText(s);
}
public int getNum(){
String s = mTvNum.getText().toString();
return Integer.parseInt(s);
}
public void setAddSubClickListener(AddSubClickListener addSubClickListener){
this.addSubClickListener = addSubClickListener;
}
@Override
public void onClick(View view) {
if (addSubClickListener != null) {
if (view.getId() == R.id.tv_add) {
String s = mTvNum.getText().toString();
int num = Integer.parseInt(s);
if (setMaxNum) {
if (num < maxNum) {
num++;
if (num == maxNum) {
mTvAdd.setEnabled(false);
}
}
} else {
num++;
}
if (!mTvSub.isEnabled()) {
mTvSub.setEnabled(true);
}
mTvNum.setText(Integer.toString(num));
addSubClickListener.addSubClickListener(num);
} else if (view.getId() == R.id.tv_sub) {
String s = mTvNum.getText().toString();
int num = Integer.parseInt(s);
if (setMinNum) {
if (num > minNum) {
num--;
if (num == minNum) {
mTvSub.setEnabled(false);
}
}
} else {
num--;
}
if (!mTvAdd.isEnabled()) {
mTvAdd.setEnabled(true);
}
mTvNum.setText(Integer.toString(num));
addSubClickListener.addSubClickListener(num);
}
}
}
public interface AddSubClickListener {
void addSubClickListener(int num);
}
}
相关文章推荐
- 自定义组合控件实现 购物车加减的简单实现
- 自定义view继承LinearLayout实现购物车数量的加减
- Android使用自定义View实现购物车的加减
- Android_自定义HorizontalScrollView实现滑动子控件大小伸缩
- Android 自定义 HorizontalScrollView 实现ViewPager效果,打造再多图片(控件)也不怕 OOM
- 自定义View 购物车加减数量
- 自定义View实现水平滚动控件
- 自定义View实现水平滚动控件
- 自定义控件之ImageView实现点击之后有阴影效果
- 自定义的view中控件的点击事件实现
- Android自定义View之自定义评价打分控件RatingBar实现自定义星星大小和间距
- Android进阶之自定义View实战(一)仿iOS UISwitch控件实现
- 自定义View实现水平滚动控件
- 【Android学习】自定义View的实现----以圆形图片控件为例
- 自定义购物车加减view
- Android进阶——自定义View之扩展系统控件的另一种思路实现渐变文字动画的TextView
- 自定义购物车加减控件
- 自定义View 实现字母快速索引控件
- 购物车自定义加减控件
- Android自定义View实现商品评价星星评分控件