因为项目须要,也不想使用网上的写好的控件,于是作死的自己定义了一个控件。特此记录下成功。效果例如以下:

首先须要把全部的字母绘制出来:

private static String letters[] = {
"A","B","C","D","E","F","G",
"H","I","J","K","L","M","N",
"O","P","Q","R","S","T",
"U","V","W","X","Y","Z"
}; //绘制用的画笔
private Paint mPaint;
//当前控件的宽高
private int mWidth;
private int mHegiht;
// 每一个文字item的高度
private int letterItemHeight; private void init() {
// 初始化画笔
mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
mPaint.setColor(Color.GRAY);
mPaint.setTextSize(32.0f);
} @Override
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
super.onLayout(changed, left, top, right, bottom);
mWidth = getWidth();
mHegiht = getHeight();
letterItemHeight = mHegiht/letters.length;
} @Override
protected void onDraw(Canvas canvas) { for (int i=0; i<letters.length; i++){
// 计算文字绘制的x值:控件宽度的一半 减去 測量文字宽度的一半
float x = mWidth/2 - mPaint.measureText(letters[i])/2;
float y = (i + 1)*letterItemHeight;
canvas.drawText(letters[i], x, y, mPaint);
}
}

在init方法中初始化画笔及其画笔颜色和画笔大小,在onLayout布局的时候获取当前自己定义View的控件宽高和每一个字母item的高度。接下来是绘制,在绘制的时候须要获取到每一个字母的x、y值。x值即:字母左边缘到控件左边缘的距离:(逗比。图太丑不予评论 orz)



如图,蓝色的框代表自己定义控件。红色框代表字母。紫色线是控件宽度的一半,绿色线是字母文字宽度的一半,粉红色就是要绘制的文字的x值。所以,非常显然 x = 紫色 - 绿色。

y的值计算,因为文字的绘制是基于baseline基准线的。所以每一个字母item的基准线就是(i + 1)letterItemHeight。详细的能够深入学习大神爱哥的自己定义View系列blog

增加Touch事件,并获取所点击的字母:

private OnTouchLettersListener onTouchLettersListener;
@Override
public boolean dispatchTouchEvent(MotionEvent event) { final float y = event.getY();
// 数组下标
final int index = (int)(y/mHegiht*letters.length);
final OnTouchLettersListener listener = onTouchLettersListener;
final int action = event.getAction();
switch (action){
case MotionEvent.ACTION_UP:
setBackgroundColor(getResources().getColor(android.R.color.transparent));
invalidate();
break;
default:
setBackgroundColor(getResources().getColor(R.color.gray));
if (index >= 0 && index < letters.length){
if (listener != null){
//把点击的字母信息回调出去给使用者
listener.onTouchLetters(letters[index]);
}
}
invalidate();
break;
} return true;
} public interface OnTouchLettersListener{
public void onTouchLetters(String s);
} public void setOnTouchLettersListener(OnTouchLettersListener onTouchLettersListener){
this.onTouchLettersListener = onTouchLettersListener;
}

重写dispatchTouchEvent事件方法。首先获取每次点击的相对于当前View的y值,通过y/mHegiht*letters.length就是依据点击的在整个控件大概比例*数组总长度。计算出下标值来获取letters数组中的字母回调出去。(这是一个大概的值,误差也不会大)

在ACTION_UP的时候我们把控件的背景色设置为透明的。其他其他情况设置了一个灰色值。

使用这个自己定义的控件:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"> <com.jerry.testproject.view.LetterSiderBar
android:id="@+id/letter"
android:layout_centerInParent="true"
android:layout_width="45dp"
android:layout_height="match_parent" /> </RelativeLayout> package com.jerry.testproject; import android.os.Bundle;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity; import com.jerry.testproject.view.LetterSiderBar;
import com.lidroid.xutils.ViewUtils;
import com.lidroid.xutils.view.annotation.ViewInject; public class MainActivity extends AppCompatActivity implements LetterSiderBar.OnTouchLettersListener{ @ViewInject(R.id.letter)
private LetterSiderBar mLetterSiderBar; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ViewUtils.inject(this);
mLetterSiderBar.setOnTouchLettersListener(this);
} // 实现回调的方法
@Override
public void onTouchLetters(String s) {
Snackbar.make(mLetterSiderBar, "你选择了:" + s, Snackbar.LENGTH_SHORT).show();
}
}

这里使用了xUtils开源组件的视图注解方式来初始化控件。以及使用了22.2.0 api支持包design的相似于Toast的提示控件Snackbar来作为提示,AS的开发人员仅仅要引入:compile ‘com.android.support:design:22.2.0’ 就能够使用了。

下面是项目下载地址:

http://download.csdn.net/detail/abren32/8895649

自己定义View----点击滑动选择字母列表的更多相关文章

  1. vue-cli 3.0 实现A-Z字母滑动选择城市列表

    项目地址: https://github.com/caochangkui/vue-cli3 项目代码: 城市列表首页: City.vue <template> <div id=&qu ...

  2. 图文剖析自己定义View的绘制(以自己定义滑动button为例)

    自己定义View一直是横在Android开发人员面前的一道坎. 一.View和ViewGroup的关系 从View和ViewGroup的关系来看.ViewGroup继承View. View的子类.多是 ...

  3. Qt--自定义View

    这是上一篇文章的续篇,关于自定义View. 多个View内部可以映射到同一个数据模型,也可以映射不同的数据结构:可以使用所有数据,也可以只使用部分数据.因为视图层与数据层的分离,操作相对比较灵活. 1 ...

  4. 自己定义View Controller转换动画

    原文链接 : Introduction to Custom View Controller Transitions and Animations 原文作者 : joyce echessa 译文出自 : ...

  5. 自己定义View步骤

     概述 Android已经为我们提供了大量的View供我们使用,可是可能有时候这些组件不能满足我们的需求,这时候就须要自己定义控件了.自己定义控件对于刚開始学习的人总是感觉是一种复杂的技术. 由于 ...

  6. Android自己定义View的实现方法

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/17357967 不知不觉中,带你一步步深入了解View系列的文章已经写到第四篇了.回 ...

  7. Android自己定义View基础篇(三)之SwitchButton开关

    自己定义View基础篇(二) 自己定义View基础篇(一) 自己定义View原理 我在解说之前,先来看看效果图,有图有真相:(转换gif图片效果太差) 那来看看真实图片: 假设你要更改样式,请改动例如 ...

  8. 自己定义View实现水平滚动控件

    前几天项目中须要使用到一个水平可滚动的选择条,类似下图效果(图片是从简书上一位作者那儿找来的,本篇也是在这位作者的文章的基础上改动的,站在大神的肩膀上,哈哈,因为原文没有提供demo,并且实现的效果跟 ...

  9. 【代码笔记】iOS-点击出现选择框

    一,效果图. 二,工程图. 三,代码. RootViewController.h #import <UIKit/UIKit.h> @interface RootViewController ...

随机推荐

  1. ssh生成密钥(供git使用)

    我们在使用git远程更新时候,需要设置好远程密钥,以使我们能够远程更新代码到代码库中.现在我们就来做一下这件事情(ssh模式下) ssh-keygen  -t rsa -c “hcu5555@hotm ...

  2. 理解ROS的节点(NODE)

    经过前面的学习,我们已经知道了如何构建一个ROS的包,这篇博客将介绍ROS中的节点的概念. 在继续之前,请按ctrl+alt+t打开一个终端,在里面输入: sudo apt-get install r ...

  3. leetcode Container With Most Water python

    class Solution(object): def maxArea(self, height): """ :type height: List[int] :rtype ...

  4. Django 探索(一) HelloWorld

    一.Django怎么读 酱狗 二.Django下载 安装 下载地址 安装: tar zxvf Django-1.5.4.tar.gz python setup.py install 三.建立一个Hel ...

  5. R与数据分析旧笔记(一)基本数学函数的使用

    创建向量矩阵 > x1=c(2,3,6,8) > x2=c(1,2,3,4) > a1=(1:100) > length(a1) [1] 100 > length(x1) ...

  6. 一周学会Mootools 1.4中文教程:(7)汇总收尾

    转眼之间已经第七课了,这也将成为最后一课,如果这7课下来您感觉水平没有达到预想的水平,没关系您可以继续关注本站的博文,我会陆续发一些类似的文章帮您提升水平,另外我最近打算和群里的几个Mootools爱 ...

  7. 手机端 UI一些插件

    手机弹出框 http://yun.baidu.com/share/link?shareid=3523128425&uk=2685891615

  8. Java处理java.util.ConcurrentModificationException异常

    代码: public static void reduce(HashMap<String, Integer> hashMap, final Integer count) { Iterato ...

  9. Tensorflow tflearn 编写RCNN

    两周多的努力总算写出了RCNN的代码,这段代码非常有意思,并且还顺带复习了几个Tensorflow应用方面的知识点,故特此总结下,带大家分享下经验.理论方面,RCNN的理论教程颇多,这里我不在做详尽说 ...

  10. Android SharedPreference最佳实践

    Android提供多种方式保存应用数据,其中一种方式是SharedPreferences,使用键值对保存私有基本的数据.所有的逻辑仅基于以下三个类: SharedPreferences SharedP ...