android自定义加减按钮

本文实例为大家分享了android自定义加减按钮的具体代码,供大家参考,具体内容如下

1、定义两个shape:

my_button_shape_normal.xml:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
 android:shape="rectangle" >

 <stroke
 android:width="1dp"
 android:color="#007FFF" />

 <corners android:radius="5dip" />

 <padding
 android:bottom="1dp"
 android:left="10dp"
 android:right="10dp"
 android:top="1dp" />

</shape>

my_button_shape_pressed.xml:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
 android:shape="rectangle" >

 <stroke
 android:width="1dp"
 android:color="#007FFF" />

 <corners android:radius="5dip" />

 <padding
 android:bottom="1dp"
 android:left="10dp"
 android:right="10dp"
 android:top="1dp" />

</shape>

2、定义一个drawable:my_button_style.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

 <item android:drawable="@drawable/my_button_shape_normal" android:state_focused="false" android:state_pressed="false"></item>
 <item android:drawable="@drawable/my_button_shape_pressed" android:state_focused="false" android:state_pressed="true"></item>

</selector>

3、定义button布局(mybutton.xml):

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:orientation="horizontal" >

 <Button
 android:id="@+id/reduce"
 android:layout_width="50dp"
 android:layout_height="30dp"
 android:background="@drawable/my_button_style"
 android:gravity="center"
 android:paddingBottom="10dp"
 android:text="-"
 android:textColor="#007FFF" />

 <Button
 android:id="@+id/add"
 android:layout_width="50dp"
 android:layout_height="30dp"
 android:layout_toRightOf="@+id/reduce"
 android:background="@drawable/my_button_style"
 android:gravity="center"
 android:paddingBottom="10dp"
 android:text="+"
 android:textColor="#007FFF" />

</RelativeLayout>

4、定义MyButton类:

public class MyButton extends RelativeLayout {
 private View view;
 private Button add, reduce;

 private OnAddReduceChangeStatusListener mAddReduceChangeStatusListener;

 public MyButton(Context context, AttributeSet attrs, int defStyle) {
 super(context, attrs, defStyle);
 // TODO Auto-generated constructor stub
 }

 public MyButton(Context context, AttributeSet attrs) {
 super(context, attrs);
 // TODO Auto-generated constructor stub
 view = LayoutInflater.from(context).inflate(R.layout.mybutton, this, true);

 init();
 }

 public MyButton(Context context) {
 super(context);
 // TODO Auto-generated constructor stub
 }

 private void init() {
 add = (Button) view.findViewById(R.id.add);
 reduce = (Button) view.findViewById(R.id.reduce);

 add.setOnTouchListener(new ComponentOnTouch());
 reduce.setOnTouchListener(new ComponentOnTouch());
 }

 class ComponentOnTouch implements OnTouchListener {

 @Override
 public boolean onTouch(View v, MotionEvent event) {
 // TODO Auto-generated method stub
 switch (v.getId()) {
 case R.id.add:
 if (mAddReduceChangeStatusListener != null) {
 mAddReduceChangeStatusListener.add(MyButton.this.getId(),event.getAction());
 }
 break;
 case R.id.reduce:
 if (mAddReduceChangeStatusListener != null) {
 mAddReduceChangeStatusListener.reduce(MyButton.this.getId(),event.getAction());
 }
 break;
 }
 return true;
 }
 }

 public void setOnAddReduceChangeStatusListener(OnAddReduceChangeStatusListener listener) {
 this.mAddReduceChangeStatusListener = listener;
 }

 public abstract interface OnAddReduceChangeStatusListener {
 public abstract boolean add(int viewId,int eventAction);

 public abstract boolean reduce(int viewId,int eventAction);

 }
}

5、布局中使用:

<package.MyButton
  android:id="@+id/mybutton_id"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content" >
 </package.MyButton>

6.代码中使用:

a.初始化:

mybutton = (MyButton) findViewById(R.id.mybutton_id);
 mybutton.setOnAddReduceChangeStatusListener(new OnAddReduceListener());

b.listener监听:

class OnAddReduceListener implements OnAddReduceChangeStatusListener {

 @Override
 public boolean add(int viewId, int eventAction) {
 // TODO Auto-generated method stub
 if (eventAction == MotionEvent.ACTION_DOWN) {
 onTouchChange("add");
 } else if (eventAction == MotionEvent.ACTION_UP) {
 if (plusThread != null) {
 isOnLongClick = false;
 }
 } else if (eventAction == MotionEvent.ACTION_MOVE) {
 if (plusThread != null) {
 isOnLongClick = true;
 }
 } else if (eventAction == MotionEvent.ACTION_CANCEL) {
 if (plusThread != null) {
 isOnLongClick = false;
 }
 }
 return true;
 }

 @Override
 public boolean reduce(int viewId, int eventAction) {
 // TODO Auto-generated method stub
 if (eventAction == MotionEvent.ACTION_DOWN) {
 onTouchChange("reduce");
 } else if (eventAction == MotionEvent.ACTION_UP) {
 if (miusThread != null) {
 isOnLongClick = false;
 }
 } else if (eventAction == MotionEvent.ACTION_MOVE) {
 if (miusThread != null) {
 isOnLongClick = true;
 }
 } else if (eventAction == MotionEvent.ACTION_CANCEL) {
 if (miusThread != null) {
 isOnLongClick = false;
 }
 }
 return true;
 }
 }

 private void onTouchChange(String method) {
 if (method.equals("add")) {
 plusThread = new PlusThread();
 isOnLongClick = true;
 plusThread.start();
 } else if (method.equals("reduce")) {
 miusThread = new MiusThread();
 isOnLongClick = true;
 miusThread.start();
 }
 }

c,定义两个线程用来加减:

// 减操作
 class MiusThread extends Thread {
 @Override
 public void run() {
 while (isOnLongClick) {
 try {
 Thread.sleep(200);
 myHandler.sendEmptyMessage(1);
 } catch (InterruptedException e) {
 e.printStackTrace();
 }
 super.run();
 }
 }
 }

 // 加操作
 class PlusThread extends Thread {
 @Override
 public void run() {
 while (isOnLongClick) {
 try {
 Thread.sleep(200);
 myHandler.sendEmptyMessage(2);
 } catch (InterruptedException e) {
 e.printStackTrace();
 }
 super.run();
 }
 }
 }

使用Handler进行处理:

Handler myHandler = new Handler() {

 @Override
 public void handleMessage(Message msg) {
 // TODO Auto-generated method stub
 if (msg.what == 1) {
 //加操作
 } else if (msg.what == 2) {
 //减操作
 }
 }
 };

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android实战教程第一篇之最简单的计算器

    从今天开始,本专栏持续更新Android简易实战类博客文章.和以往专栏不同,此专栏只有实例.每个实例尽量按照知识点对应相应一章节的内容去写,循序渐进.有些实例可能会与另一个专栏有重复的文章. 开始本专栏的第一个简易案例: 首先设置两个布局文件,一个布局文件进行输入数据,获取加法运算:另一个布局文件进行显示最终结果.Activity1启动Activity2,并传递计算结果值给Activity2. main.xml: <?xml version="1.0" encoding=&quo

  • Android studio实现简单计算器

    本文实例为大家分享了Android studio实现简单计算器的具体代码,供大家参考,具体内容如下 需求分析 在Android studio中设计并实现一个简单的计算器,实现连续的加减乘除运算. 界面设计 采用网格GridLayout布局,设计了一个6行4列的网格,最上边是一个EditText用来显示用户输入的运算数字和运算符,以及相关的运算结果,其占4列,文本框大小为50dip:依次往下的界面分别设置了数字和运算符以及操作的按钮,各行各列的每个按钮的大小均设为26sp. 编程分析 设计了两个文

  • android实现简单计算器功能

    本文实例为大家分享了android实现简单计算器的具体代码,供大家参考,具体内容如下 // 日期:2014/9/26 // 首先,人们的输入习惯为中缀表达式.为了便于计算,程序会将中缀表达式会转换为后缀表达式 //////////////////////////////////////////////////////////////////////////////////////// // 目前软件还存在 // 1.输入运算数和运算符不匹配时,崩溃的现象.(如:只输入一个操作数) // 2.一个

  • Android实现简易计算器小程序

    本文实例为大家分享了Android实现简易计算器小程序的具体代码,供大家参考,具体内容如下 目标效果: 通过编写代码,可以实现整数和小数的加减乘除运算,以及删除和清空的功能. 1.页面中Button使用的是线性布局,最外边一个是父布局,第一行C,DEL,/,*为第一个子布局,第二行7,8,9,-为第二个子布局,第三行4,5,6,+为第三个子布局,第四五行为第四个子布局,第四个子布局中还有两个相当于是孙布局的级别,1,2,3为第一个孙布局,0和.为第二个孙布局,=在两个孙布局之外第四个子布局以内.

  • android计算器实现两位数的加减乘除

    本文实例为大家分享了android计算器实现加减乘除的具体代码,供大家参考,具体内容如下 注:以下计算器只注重实现功能,不考虑其他BUG,只有两位整数的算法运算,适合新手 1.实现思想 将从键盘得到的数值放在一个字符数组中,以运算符号(+-/)为分割点,将两个数值分割开,进行算法运算.* 2.难点 如何判断是否为符号?+ - ×/ 记录符号的位置? 3.步骤: 1.得到键盘输入的值 2.将值存放在一个字符数组中 3.遍历数组中的每个数,如果找到算法符号,记录下算法符号的位置.(要点,从0开始)

  • Android计算器编写代码

    其实这个安卓计算机,所有的后台思想与<C#计算器编写代码>是一模一样的.Win窗体程序移植到安卓,从C#到Java其实很简单的,因为两者的基本语法都很相像,唯一的难点是安卓的xml布局部分,不像C#窗体能够直接拖.  还是如下图一个能够完成基本四则运算的计算器: 先在res\values\strings.xml设置按钮相应的字体,以免布局文件警告满天飞: <?xml version="1.0" encoding="utf-8"?> <r

  • Android实现加法计算器

    本文实例为大家分享了Android实现加法计算器的具体代码,供大家参考,具体内容如下 布局 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layo

  • Android基于反射技术实现的加减乘除运算示例

    本文实例讲述了Android基于反射技术实现的加减乘除运算.分享给大家供大家参考,具体如下: JAVA反射机制定义: JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法:这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制. Java反射机制主要提供了以下功能: 在运行时判断任意一个对象所属的类:在运行时构造任意一个类的对象:在运行时判断任意一个类所具有的成员变量和方法:在运行时调用任意一个对象的方法

  • Android studio设计简易计算器

    本文实例为大家分享了Android studio设计简易计算器的具体代码,供大家参考,具体内容如下 效果显示: 第一步,简单的界面布局 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.and

  • Android实现简单加法计算器

    本文实例为大家分享了Android实现简单加法计算器的具体代码,供大家参考,具体内容如下 package com.example.calculator; import android.os.Bundle; import android.app.Activity; import android.view.Menu; import android.view.View; import android.widget.Button; import android.widget.EditText; impo

随机推荐