array(2) { ["docs"]=> array(10) { [0]=> array(10) { ["id"]=> string(3) "428" ["text"]=> string(77) "Visual Studio 2017 单独启动MSDN帮助(Microsoft Help Viewer)的方法" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(8) "DonetRen" ["tagsname"]=> string(55) "Visual Studio 2017|MSDN帮助|C#程序|.NET|Help Viewer" ["tagsid"]=> string(23) "[401,402,403,"300",404]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400964" ["_id"]=> string(3) "428" } [1]=> array(10) { ["id"]=> string(3) "427" ["text"]=> string(42) "npm -v;报错 cannot find module "wrapp"" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "zzty" ["tagsname"]=> string(50) "node.js|npm|cannot find module "wrapp“|node" ["tagsid"]=> string(19) "[398,"239",399,400]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400760" ["_id"]=> string(3) "427" } [2]=> array(10) { ["id"]=> string(3) "426" ["text"]=> string(54) "说说css中pt、px、em、rem都扮演了什么角色" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(12) "zhengqiaoyin" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400640" ["_id"]=> string(3) "426" } [3]=> array(10) { ["id"]=> string(3) "425" ["text"]=> string(83) "深入学习JS执行--创建执行上下文(变量对象,作用域链,this)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "Ry-yuan" ["tagsname"]=> string(33) "Javascript|Javascript执行过程" ["tagsid"]=> string(13) "["169","191"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511399901" ["_id"]=> string(3) "425" } [4]=> array(10) { ["id"]=> string(3) "424" ["text"]=> string(30) "C# 排序技术研究与对比" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "vveiliang" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(8) ".Net Dev" ["catesid"]=> string(5) "[199]" ["createtime"]=> string(10) "1511399150" ["_id"]=> string(3) "424" } [5]=> array(10) { ["id"]=> string(3) "423" ["text"]=> string(72) "【算法】小白的算法笔记:快速排序算法的编码和优化" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "penghuwan" ["tagsname"]=> string(6) "算法" ["tagsid"]=> string(7) "["344"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511398109" ["_id"]=> string(3) "423" } [6]=> array(10) { ["id"]=> string(3) "422" ["text"]=> string(64) "JavaScript数据可视化编程学习(二)Flotr2,雷达图" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "chengxs" ["tagsname"]=> string(28) "数据可视化|前端学习" ["tagsid"]=> string(9) "[396,397]" ["catesname"]=> string(18) "前端基本知识" ["catesid"]=> string(5) "[198]" ["createtime"]=> string(10) "1511397800" ["_id"]=> string(3) "422" } [7]=> array(10) { ["id"]=> string(3) "421" ["text"]=> string(36) "C#表达式目录树(Expression)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "wwym" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(4) ".NET" ["catesid"]=> string(7) "["119"]" ["createtime"]=> string(10) "1511397474" ["_id"]=> string(3) "421" } [8]=> array(10) { ["id"]=> string(3) "420" ["text"]=> string(47) "数据结构 队列_队列实例:事件处理" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "idreamo" ["tagsname"]=> string(40) "C语言|数据结构|队列|事件处理" ["tagsid"]=> string(23) "["246","247","248",395]" ["catesname"]=> string(12) "数据结构" ["catesid"]=> string(7) "["133"]" ["createtime"]=> string(10) "1511397279" ["_id"]=> string(3) "420" } [9]=> array(10) { ["id"]=> string(3) "419" ["text"]=> string(47) "久等了,博客园官方Android客户端发布" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(3) "cmt" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511396549" ["_id"]=> string(3) "419" } } ["count"]=> int(200) } 222 Android自定义控件,实现iphone的picker效果 - 爱码网

效果图如下:

1.不带有图标的

Android自定义控件,实现iphone的picker效果

2.带有图标的

Android自定义控件,实现iphone的picker效果

主要有两个类:

1.Picker

2.CustomListView

Picker控件的外部接口:

Android自定义控件,实现iphone的picker效果

Picker控件的使用方法:

public class Main extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        final Picker picker=new Picker(this);
        
    	ArrayList<String> data = new ArrayList<String>();
    	ArrayList<Drawable> icons = new ArrayList<Drawable>();
    	
    	icons.add(getResources().getDrawable(R.drawable.icon1));
    	icons.add(getResources().getDrawable(R.drawable.icon2));
    	icons.add(getResources().getDrawable(R.drawable.icon3));
    	icons.add(getResources().getDrawable(R.drawable.icon1));
    	icons.add(getResources().getDrawable(R.drawable.icon2));
    	icons.add(getResources().getDrawable(R.drawable.icon3));

		for (int i = 2000; i < 2006; i++) {
			data.add("" + i);
		}
		picker.setPickerData(data);
		picker.setPickerSize(100, 200);
		picker.defaultScrollToPos(4);
		picker.setOnPickerItemSelectedListener(new OnPickerItemSelectedListener() {
			@Override
			public void onItemSelected(View view, int pos, String text) {
				
			}
		});
		
        setContentView(picker);
        
    }
}

Picker控件的核心代码如下:

public class Picker extends LinearLayout implements
        CustomScrollView.OnScrollOverListener { 

    private ArrayList<String> data;   //字符串数据List
    private ArrayList<Drawable> iconList;  //与data相对应的图标List 

    private int headAndFootHeight = 150; 

    private int cellHeight = 50; 

    private Context mContext; 

    private LinearLayout contentLinear; 

    private CustomScrollView scrollview; 

    private TextView selector; 

    private int indicaterOffset; // 选择条的偏移量 

    private View ipicker; 

    private int width; 

    private int height; 

    private int defaultPos; 

    private ArrayList<View> viewlist = new ArrayList<View>(); // 每一项中的View(可以是他的子类) 

    private boolean isLayoutOnce; // 只是layout一次的标记
    private int destPos; 

    public Picker(Context context) {
        this(context,null);
    } 

    public Picker(Context context, AttributeSet attrs) {
        super(context, attrs);
        this.mContext = context; 

        defaultPos = headAndFootHeight + cellHeight * 1 - indicaterOffset;
        FrameLayout frameLayout=new FrameLayout(mContext);
        frameLayout.setBackgroundResource(R.drawable.while_bg);
        LayoutParams params=new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT);
        frameLayout.setLayoutParams(params);
        CustomScrollView myScroll=new CustomScrollView(mContext);
        myScroll.setVerticalFadingEdgeEnabled(false);
        myScroll.setVerticalScrollBarEnabled(false);
        LayoutParams params2=new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT);
        myScroll.setLayoutParams(params2);
        LinearLayout linear=new LinearLayout(mContext);
        linear.setLayoutParams(params2);
        linear.setOrientation(LinearLayout.VERTICAL);
        myScroll.addView(linear);
        myScroll.setLayoutParams(params2);
        TextView selector1=new TextView(mContext);
        selector1.setBackgroundResource(R.drawable.selector_bg);
        selector1.setLayoutParams(params2);
        frameLayout.addView(myScroll);
        FrameLayout.LayoutParams params3=new FrameLayout.LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT);
        params3.gravity=Gravity.CENTER_VERTICAL;
        frameLayout.addView(selector1, params3); 

        scrollview = myScroll;
        contentLinear = linear;
        selector =selector1;
        ipicker=frameLayout;
        selector.setHeight(cellHeight); // 将所有设置child宽高,位置的代码在onlayout之前调用
        addView(ipicker);
    } 

    @Override
    protected void onLayout(boolean changed, int l, int t, int r, int b) {
        super.onLayout(false, l, t, r, b);
        Log.e("", "onLayout");
        if (isLayoutOnce) {
            return;
        }
        isLayoutOnce = true;
        int top = selector.getTop()-4;   //9 patch 图片的问题,经多次调试偏移四个像素最好
        indicaterOffset = top;
        if (defaultPos == 0) { 

            scrollview.scrollTo(0, headAndFootHeight - indicaterOffset);
        } else {
            scrollview.smoothScrollTo(0, defaultPos);
        } 

        this.handler.sendEmptyMessage(destPos); 

    } 

    private Handler handler = new Handler() {
        @Override
        public void handleMessage(Message msg) {
            scrollToPos(destPos);
            super.handleMessage(msg);
        } 

    }; 

    private TextView footText;
    /**Ipicker显示的时候,默认滚动到pos位置*/
    public void defaultScrollToPos(int pos) {
        this.destPos = pos;
        // flag = true;
        // defaultPos = headAndFootHeight + cellHeight * pos - indicaterOffset;
    } 

    /**滚动到Pos位置*/
    public void scrollToPos(int pos) {
        scrollview.smoothScrollTo(0, headAndFootHeight + cellHeight * pos
                - indicaterOffset);
    }
    /**为控件添加数据
     * list  StringList
     * */
    public void setPickerData(ArrayList<String> list) {
        this.data = list;
        prepare();
    }
    /**为控件添加数据
     * list  StringList
     * */
    public void setPickerData(ArrayList<String> stringlist,ArrayList<Drawable> iconlist) {
        if(stringlist.size()!=iconlist.size()){
            Log.e("error", "!!error!! the length of stringlist and iconlist is not same!!"); 

            return;
        }
        this.data = stringlist;
        this.iconList=iconlist;
        prepare();
    } 

    /** set the size of the picker */
    public void setPickerSize(int width, int height) {
        this.width = width;
        this.height = height;
    } 

    /**
     *  prepare picker view ,prepare the ipcker's children (will call onlayout again)
     * */
    private void prepare() {
        contentLinear.removeAllViews();
        LayoutParams params = new LayoutParams(LayoutParams.WRAP_CONTENT,
                LayoutParams.WRAP_CONTENT);
        if (width == 0 || height == 0) {
            params.width = 200;
            params.height = 200;
        } else {
            params.width = width;
            params.height = height;
        }
        ipicker.setLayoutParams(params); 

        scrollview.setOnScrollOverListener(this);
        TextView headText = new TextView(mContext);
        headText.setHeight(headAndFootHeight);
        contentLinear.addView(headText); 

        insertData(); 

        footText = new TextView(mContext);
        footText.setHeight(headAndFootHeight);
        contentLinear.addView(footText);
    } 

    private void insertData() {
        viewlist.clear();
        if (data == null || data.size() == 0) {
            selector.setVisibility(View.GONE);
            return;
        }
        for (int i = 0; i < data.size(); i++) {
            LinearLayout itemLayout=new LinearLayout(mContext);
            itemLayout.setGravity(Gravity.CENTER_VERTICAL);
            itemLayout.setPadding(20, 0, 0, 0);
            if(iconList!=null){
                ImageView image=new ImageView(mContext);
                image.setBackgroundDrawable(iconList.get(i));
                itemLayout.addView(image);
            }
            TextView text = new TextView(mContext);
            text.setHeight(cellHeight);
            text.setGravity(Gravity.CENTER);
            text.setTextSize(25);
            text.setTypeface(Typeface.DEFAULT_BOLD);
            text.setTextColor(Color.BLACK);
            itemLayout.addView(text);
            LayoutParams params = new LayoutParams(LayoutParams.FILL_PARENT,
                    LayoutParams.WRAP_CONTENT);
            text.setLayoutParams(params);
            text.setText(data.get(i));
            contentLinear.addView(itemLayout);
            viewlist.add(itemLayout);
        }
    } 

    @Override
    public void onScrollOver(final int stopy) { 

        final int num = (stopy - headAndFootHeight + indicaterOffset)
                / cellHeight;
        if (stopy + indicaterOffset // to triger onItemSelected only one time
                - (headAndFootHeight + cellHeight * (num)) == 0) {
            if(listener!=null){
                listener.onItemSelected(viewlist.get(num), num, data.get(num));
            }
        } 

        ((Activity) mContext).runOnUiThread(new Runnable() {
            @Override
            public void run() { 

                if (stopy + indicaterOffset < headAndFootHeight) {
                    scrollview.smoothScrollTo(0, headAndFootHeight
                            - indicaterOffset);
                                } else if (stopy + indicaterOffset >= headAndFootHeight
                        + cellHeight * num
                        && stopy + indicaterOffset <= headAndFootHeight
                                + cellHeight * (data.size() - 1)) {
                    if (stopy + indicaterOffset
                            - (headAndFootHeight + cellHeight * (num)) <= cellHeight / 2) { // less 

                        scrollview.smoothScrollTo(0, headAndFootHeight
                                + cellHeight * num - indicaterOffset);
                    } else {
                        scrollview.smoothScrollTo(0, headAndFootHeight
                                + cellHeight * (num + 1) - indicaterOffset);
                    } 

                } else if (stopy + indicaterOffset > headAndFootHeight
                        + cellHeight * (data.size() - 1)) {
                    scrollview.smoothScrollTo(0, headAndFootHeight + cellHeight
                            * (data.size() - 1) - indicaterOffset);
                } else {
                } 

            }
        });
    } 

    private OnPickerItemSelectedListener listener; 

    public void setOnPickerItemSelectedListener(
            OnPickerItemSelectedListener listener) {
        this.listener = listener;
    } 

    interface OnPickerItemSelectedListener {
        /**
         * @param view: view of the a specific item (linearLayout)
         * @param pos:position
         * @param text:String of the a specific item
         * */
        void onItemSelected(View view, int pos, String text);
    }
}
 
 
 
//欢迎提出宝贵意见

相关文章: