关于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自带电话应用的实现。可见,在开发中,灵活运用自定义的控件,可以实现独特而富有魅力的效果!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
拨打电话 拨打电话给 Skype 联系人。开始通话前,需先让支援PSP™版 Skype 的音频输入设备连接PSP™主机。 从联系人名单选择拨打对象 1. 进入 Skype 的选单画面后选择(联系人)。 2. 从联系人名单中选择电话的拨打对象。 可拨打电话给登入状态为(在线)等可通话状态的联系人。 开始呼叫后,会显示对方的名字或 Skype 账号。对方回复后即可开始通话。 提示 透过 Sky
问题内容: 我正在尝试拨打的电话不是使用特定号码,而是使用在变量中被调用的号码,或者至少告诉它在您的电话中提取该号码。这个在变量中被调用的数字是我使用解析器或从网站sql检索到的数字。我做了一个按钮,试图用一个函数调用存储在变量中的电话号码,但无济于事。一切都会帮助谢谢! 问题答案: 试一试: 假设电话号码在。 的返回Optional,因此使用可以确保它是(而不是)返回的。 对于Swift 3:
本文向大家介绍Android自定义控件之自定义组合控件(三),包括了Android自定义控件之自定义组合控件(三)的使用技巧和注意事项,需要的朋友参考一下 前言: 前两篇介绍了自定义控件的基础原理Android自定义控件基本原理详解(一)、Android自定义控件之自定义属性(二)。今天重点介绍一下如何通过自定义组合控件来提高布局的复用,降低开发成本,以及维护成本。 使用自定义组合控件的好处? 我
模拟ios5的拨号键盘,带有拨号键,可以调用系统的电话功能进行打电话。只有在真机中才能测试打电话功能。 作者说:修改delegate后,可以自定义电话。 [Code4App.com]
前言:我从一个带有小键盘的旧翻盖手机搬到了S3,用它我可以很容易地键入电话银行密码或类似的东西,在我键入时用另一只手屏蔽了一只手。 如果我将手机旋转到横向模式,我最初会得到一个尺寸较小的拨号器,但一旦我输入电话(比如语音邮件),它会跳回到纵向模式和股票拨号器。从我对自定义拨号器所做的研究来看,一旦呼叫开始,它们似乎就不起作用了,所以我不太抱希望。 唯一的解决办法是根植手机并把它黑得很深吗?(显然,
拨打普通电话(SkypeOut) 使用 Skype ,对传统的电话回线拨打电话。若要使用此机能,需先购买 Skype 点数。 1. 进入 Skype 的选单画面后,选择(拨号)。 2. 选择[国家或地区],从清单中选择国家或地区。 3. 选择[电话号码]后,输入号码并选择[确定]。 4. 选择[通话]。 对方接听后,即可开始通话。 重要 无法使用 Skype 拨打紧急电话。