Android自定义控件之电话拨打小键盘

 更新时间:2018年04月28日 15:34:23   作者:chenjie19891104  
这篇文章主要为大家详细介绍了Android自定义控件之电话拨打小键盘,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

关于Android的自定义控件,之前也写了两个,一个是简单地继承View,另一个通过继承Layout实现一个省市联动控件。这篇,将通过继承ViewGroup来实现一个电话拨打小键盘。本人一贯风格,懒得罗里吧嗦讲一大堆,直接上图上代码,一切尽在注释中!

1、MyPhoneCard.java

/** 
 * 
 * 自定义一个4*3的拨打电话的布局控件, 
 * 
 * 
 */ 
public class MyPhoneCard extends ViewGroup{ 
   
  private static final int COLUMNS = 3; 
  private static final int ROWS = 4; 
  private static final int NUM_BUTTON = COLUMNS*ROWS; 
   
  private View[] mButtons = new View[NUM_BUTTON]; 
   
  private int mButtonWidth; 
  private int mButtonHeight; 
  private int mPaddingLeft; 
  private int mPaddingRight; 
  private int mPaddingTop; 
  private int mPaddingBottom; 
  private int mWidthInc; 
  private int mHeightInc; 
  private int mWidth; 
  private int mHeight; 
 
  public MyPhoneCard(Context context) { 
    super(context); 
  } 
   
  public MyPhoneCard(Context context, AttributeSet attrs){ 
    super(context,attrs); 
  } 
   
  public MyPhoneCard(Context context, AttributeSet attrs, int defStyle){ 
    super(context,attrs,defStyle); 
  } 
   
  /** 
   * 当从xml将所有的控件都调入内存后,触发的动作 
   * 在这里获取控件的大小,并计算整个ViewGroup需要的总的宽和高 
   */ 
  @Override 
  protected void onFinishInflate(){ 
    super.onFinishInflate(); 
    final View[] btns = mButtons; 
     
    for(int i=0; i<NUM_BUTTON; i++){ 
      btns[i] = this.getChildAt(i); 
      btns[i].measure(MeasureSpec.UNSPECIFIED, MeasureSpec.UNSPECIFIED); 
    } 
     
    //缓存大小 
    final View child = btns[0]; 
    mButtonWidth = child.getMeasuredWidth(); 
    mButtonHeight = child.getMeasuredHeight(); 
    mPaddingLeft = this.getPaddingLeft(); 
    mPaddingRight = this.getPaddingRight(); 
    mPaddingTop = this.getPaddingTop(); 
    mPaddingBottom = this.getPaddingBottom(); 
    mWidthInc = mButtonWidth + mPaddingLeft + mPaddingRight; 
    mHeightInc = mButtonHeight + mPaddingTop + mPaddingBottom; 
     
    mWidth = mWidthInc*COLUMNS; 
    mHeight = mHeightInc*ROWS; 
     
    Log.v("Finish Inflate:", "btnWidth="+mButtonWidth+",btnHeight="+mButtonHeight+",padding:"+mPaddingLeft+","+mPaddingTop+","+mPaddingRight+","+mPaddingBottom); 
 
     
     
  } 
   
  /** 
   * 这个方法在onFinishInflate之后,onLayout之前调用。这个方面调用两次 
   */ 
  @Override 
  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec){ 
    super.onMeasure(widthMeasureSpec, heightMeasureSpec); 
    Log.v("ViewGroup SIZE:width=", mWidth+""); 
    Log.v("ViewGroup SIZE: height=",mHeight+""); 
    final int width = resolveSize(mWidth, widthMeasureSpec);//传入我们希望得到的宽度,得到测量后的宽度 
    final int height = resolveSize(mHeight,heightMeasureSpec);//传入我们希望得到的高度,得到测量后的高度 
    Log.v("ViewGroup Measured SIZE: width=", width+""); 
    Log.v("ViewGroup Measured SIZE: height=", height+""); 
    //重新计算后的结果,需要设置。下面这个方法必须调用 
    setMeasuredDimension(width, height); 
  } 
 
  /** 
   * 这个方法在onMeasure之后执行,这个自定义控件中含有12个子控件(每个小键),所以,重写这个方法, 
   * 调用每个键的layout,将他们一个一个布局好 
   * 就是4*3的放置,很简单,一个嵌套循环搞定 
   */ 
  @Override 
  protected void onLayout(boolean changed, int left, int top, int right, int bottom) { 
    final View[] buttons = mButtons; 
    int i = 0; 
    Log.v("BOTTOM:", bottom+""); 
    Log.v("TOP", top+""); 
     
    int y = (bottom - top) - mHeight + mPaddingTop;//这里其实bottom-top=mHeight,所以y=mPaddingTop 
    Log.v("Y=", y+""); 
    for(int row=0; row<ROWS; row++){ 
      int x = mPaddingLeft; 
      for(int col = 0; col < COLUMNS; col++){ 
        buttons[i].layout(x, y, x+mButtonWidth, y+mButtonHeight); 
        x = x + mWidthInc; 
        i++; 
      } 
      y = y + mHeightInc; 
    } 
  } 
 
} 

2、布局文件:

<?xml version="1.0" encoding="utf-8"?> 
<demo.phone.card.MyPhoneCard 
 xmlns:android="http://schemas.android.com/apk/res/android"  
 android:id = "@+id/dialpad"  
 android:paddingLeft="7dp"  
 android:paddingRight="7dp"  
 android:paddingTop="6dp"  
 android:paddingBottom="6dp"  
 android:layout_gravity="center"  
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content"  
 android:layout_marginBottom="5dp"> 
  
  <ImageButton android:id="@+id/one"  
    android:src="@drawable/dial_num_1_no_vm"  
    style="@style/dial_btn_style"  
    /> 
     
  <ImageButton android:id="@+id/two"  
    android:src="@drawable/dial_num_2"  
    style="@style/dial_btn_style"/>  
     
  <ImageButton android:id="@+id/three"  
    android:src="@drawable/dial_num_3"  
    style="@style/dial_btn_style"/>  
     
  <ImageButton android:id="@+id/four"  
    android:src="@drawable/dial_num_4"  
    style="@style/dial_btn_style"/>  
     
  <ImageButton android:id="@+id/five"  
    android:src="@drawable/dial_num_5"  
    style="@style/dial_btn_style"/> 
     
  <ImageButton android:id="@+id/six"  
    android:src="@drawable/dial_num_6"  
    style="@style/dial_btn_style"/>  
     
  <ImageButton android:id="@+id/seven"  
    android:src="@drawable/dial_num_7"  
    style="@style/dial_btn_style"/> 
     
  <ImageButton android:id="@+id/eight"  
    android:src="@drawable/dial_num_8"  
    style="@style/dial_btn_style"/> 
     
  <ImageButton android:id="@+id/nine"  
    android:src="@drawable/dial_num_9"  
    style="@style/dial_btn_style"/>  
     
  <ImageButton android:id="@+id/star"  
    android:src="@drawable/dial_num_star"  
    style="@style/dial_btn_style"/>   
     
  <ImageButton android:id="@+id/zero"  
    android:src="@drawable/dial_num_0"  
    style="@style/dial_btn_style"/>   
     
  <ImageButton android:id="@+id/pound"  
    android:src="@drawable/dial_num_pound"  
    style="@style/dial_btn_style"/>                                                    
   
</demo.phone.card.MyPhoneCard> 

这样,就实现了上图的小键盘。这个例子参考Android自带电话应用的实现。可见,在开发中,灵活运用自定义的控件,可以实现独特而富有魅力的效果!

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

相关文章

  • 详解Android中接口回调、方法回调

    详解Android中接口回调、方法回调

    在Android开发中我们很多地方都用到了方法的回调,回调就是把方法的定义和功能导入实现分开的一种机制,目的是为了解耦他的本质是基于观察者设计模式,即观察者设计模式的的简化版。本文主要对Android中接口回调、方法回调进行详细介绍,下面跟着小编一起来看下吧
    2017-01-01
  • 在Android打包中区分测试和正式环境浅析

    在Android打包中区分测试和正式环境浅析

    这篇文章主要给大家介绍了关于在Android打包中如何区分测试和正式环境的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起看看吧。
    2017-10-10
  • Android Activity与Fragment之间的跳转实例详解

    Android Activity与Fragment之间的跳转实例详解

    这篇文章主要介绍了Android Activity与Fragment之间的跳转实例详解的相关资料,需要的朋友可以参考下
    2017-02-02
  • 手把手教你实现Android编译期注解

    手把手教你实现Android编译期注解

    今天给大家介绍Android编译期注解sdk的步骤以及注意事项,并简要分析了运行时注解以及字节码技术在生成代码上与编译期注解的不同与优劣,感兴趣的朋友一起看看吧
    2021-07-07
  • Android 实现带角标的ImageView(微博,QQ消息提示)

    Android 实现带角标的ImageView(微博,QQ消息提示)

    下面小编就为大家分享一篇Android 实现带角标的ImageView(微博,QQ消息提示),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • Android视频播放器屏幕左侧边随手指上下滑动亮度调节功能的原理实现

    Android视频播放器屏幕左侧边随手指上下滑动亮度调节功能的原理实现

    这篇文章主要介绍了Android视频播放器屏幕左侧边随手指上下滑动亮度调节功能的原理实现,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • Android 出现问题Installation error: INSTALL_FAILED_CONFLICTING_PROVIDER解决办法

    Android 出现问题Installation error: INSTALL_FAILED_CONFLICTING_P

    这篇文章主要介绍了Android 出现问题Installation error: INSTALL_FAILED_CONFLICTING_PROVIDER解决办法的相关资料,需要的朋友可以参考下
    2016-12-12
  • Flutter中显示条件Widget的实现方式

    Flutter中显示条件Widget的实现方式

    在 Flutter 日常开发中经常会遇见这样的需求,如: 只有用户是 VIP 时,才能展示某个入口或者某个模块,这样的需求在开发业务需求中多如牛毛,那你是如何来优雅的实现的呢,本文将给大家介绍Flutter中显示条件Widget的实现方式,需要的朋友可以参考下
    2024-04-04
  • Android 键盘开发知识点总结

    Android 键盘开发知识点总结

    这篇文章我们给大家总结了Android 键盘开发的相关知识点内容以及开发心得,有需要的朋友参考学习下。
    2018-06-06
  • Android设备蓝牙连接扫描枪获取扫描内容

    Android设备蓝牙连接扫描枪获取扫描内容

    这篇文章主要为大家详细介绍了Android设备蓝牙连接扫描枪获取扫描内容,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09

最新评论