Thursday, June 9, 2011

Android wheel picker example

Android wheel picker example

Now you can with Android-Wheel  WheelPicker for Android:
Download Source Code Here

Android-Wheel: 
It comes with a handy ScrollListener for listen to touch events on the wheel component.


source code

package com.vijay;


import com.vijay.wheel.ArrayWheelAdapter;
import com.vijay.wheel.OnWheelChangedListener;
import com.vijay.wheel.OnWheelScrollListener;
import com.vijay.wheel.WheelView;

import android.app.Activity;
import android.os.Bundle;
import android.widget.EditText;
import android.widget.TextView;

public class MainActivity extends Activity
    {
        // TODO: Externalize string-array
        String wheelMenu1[] = new String[]{"name 1", "name 2", "name 3", "name 4", "name 5", "name 6","name 7","name 8","name 9"};
        String wheelMenu2[] = new String[]{"age 1", "age 2", "age 3"};
        String wheelMenu3[] = new String[]{"10", "20","30","40","50","60"};

        // Wheel scrolled flag
        private boolean wheelScrolled = false;

        private TextView text;
        private EditText text1;
        private EditText text2;
        private EditText text3;

        @Override
        public void onCreate(Bundle savedInstanceState)
            {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.main);

                initWheel1(R.id.p1);
                initWheel2(R.id.p2);
                initWheel3(R.id.p3);

                text1 = (EditText) this.findViewById(R.id.r1);
                text2 = (EditText) this.findViewById(R.id.r2);
                text3 = (EditText) this.findViewById(R.id.r3);
                text = (TextView) this.findViewById(R.id.result);
            }

        // Wheel scrolled listener
        OnWheelScrollListener scrolledListener = new OnWheelScrollListener()
            {
                public void onScrollStarts(WheelView wheel)
                    {
                        wheelScrolled = true;
                    }

                public void onScrollEnds(WheelView wheel)
                    {
                        wheelScrolled = false;
                        updateStatus();
                    }
            };

        // Wheel changed listener
        private final OnWheelChangedListener changedListener = new OnWheelChangedListener()
            {
                public void onChanged(WheelView wheel, int oldValue, int newValue)
                    {
                        if (!wheelScrolled)
                            {
                                updateStatus();
                            }
                    }
            };

        /**
         * Updates entered PIN status
         */
        private void updateStatus()
            {
                text1.setText(wheelMenu1[getWheel(R.id.p1).getCurrentItem()]);
                text2.setText(wheelMenu2[getWheel(R.id.p2).getCurrentItem()]);
                text3.setText(wheelMenu3[getWheel(R.id.p3).getCurrentItem()]);

                text.setText(wheelMenu1[getWheel(R.id.p1).getCurrentItem()] + " - " + wheelMenu2[getWheel(R.id.p2).getCurrentItem()] + " - " + wheelMenu3[getWheel(R.id.p3).getCurrentItem()]);
            }

        /**
         * Initializes wheel
         *
         * @param id
         *          the wheel widget Id
         */

        private void initWheel1(int id)
            {
                WheelView wheel = (WheelView) findViewById(id);
                wheel.setAdapter(new ArrayWheelAdapter<String>(wheelMenu1));
                wheel.setVisibleItems(2);
                wheel.setCurrentItem(0);
                wheel.addChangingListener(changedListener);
                wheel.addScrollingListener(scrolledListener);
            }

        private void initWheel2(int id)
            {
                WheelView wheel = (WheelView) findViewById(id);
                wheel.setAdapter(new ArrayWheelAdapter<String>(wheelMenu2));
                wheel.setVisibleItems(2);
                wheel.setCurrentItem(0);
                wheel.addChangingListener(changedListener);
                wheel.addScrollingListener(scrolledListener);
            }

        private void initWheel3(int id)
            {
                WheelView wheel = (WheelView) findViewById(id);

                wheel.setAdapter(new ArrayWheelAdapter<String>(wheelMenu3));
                wheel.setVisibleItems(2);
                wheel.setCurrentItem(0);
                wheel.addChangingListener(changedListener);
                wheel.addScrollingListener(scrolledListener);
            }

        /**
         * Returns wheel by Id
         *
         * @param id
         *          the wheel Id
         * @return the wheel with passed Id
         */
        private WheelView getWheel(int id)
            {
                return (WheelView) findViewById(id);
            }

        /**
         * Tests wheel value
         *
         * @param id
         *          the wheel Id
         * @param value
         *          the value to test
         * @return true if wheel value is equal to passed value
         */
        private int getWheelValue(int id)
            {
                return getWheel(id).getCurrentItem();
            }
    }

main.xml

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:background="@drawable/layout_bg">


    <LinearLayout
        android:layout_marginTop="24dp"
        android:layout_gravity="center_horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">

        <com.vijay.wheel.WheelView
            android:id="@+id/p1"
            android:layout_height="wrap_content"
            android:layout_width="wrap_content" />
        <com.vijay.wheel.WheelView
            android:id="@+id/p2"
            android:layout_height="wrap_content"
            android:layout_width="wrap_content" />
        <com.vijay.wheel.WheelView
            android:id="@+id/p3"
            android:layout_height="wrap_content"
            android:layout_width="wrap_content" />
    </LinearLayout>

    <LinearLayout
        android:orientation="horizontal"
        android:layout_gravity="center_horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="24dp">
        <EditText
            android:id="@+id/r1"
            android:layout_width="100dip"
            android:layout_height="wrap_content"
            android:layout_marginTop="24dp"
            android:layout_gravity="center_horizontal"
            android:textSize="18sp"
            android:textColor="#000">
        </EditText>
        <EditText
            android:id="@+id/r2"
            android:layout_width="80dip"
            android:layout_height="wrap_content"
            android:layout_marginTop="24dp"
            android:layout_gravity="center_horizontal"
            android:textSize="18sp"
            android:textColor="#000">
        </EditText>
        <EditText
            android:id="@+id/r3"
            android:layout_width="80dip"
            android:layout_height="wrap_content"
            android:layout_marginTop="24dp"
            android:layout_gravity="center_horizontal"
            android:textSize="18sp"
            android:textColor="#000">
        </EditText>
    </LinearLayout>

    <TextView
        android:id="@+id/result"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="24dp"
        android:layout_gravity="center_horizontal"
        android:textSize="18sp"
        android:textColor="#FFF"
        android:text="Your choice">
    </TextView>
</LinearLayout>






41 comments:

  1. Looks like a nice widget, a good solution for devices < honeycomb. Possibly you might want to make it more combatible with the standard number picker so that it can just be replaced in resources for devices <3.0.

    ReplyDelete
  2. code you please post the full code or send it to my my email , i have been trying to download the code from google code usin svn however it's not working !!

    ReplyDelete
  3. http://www.megaupload.com/?d=SORK7YDK... check this url u can get full source code

    ReplyDelete
    Replies
    1. Hi Vijay,

      can u pls send full code to my email as well.
      its will realy help me.
      tomersadi@gmail.com
      Thanks alot for your help and time,

      Tomer

      Delete
  4. Hi, i cannot download the src code from megaupload , because my country is banned by megaupload:(
    could you mind to upload to other server?

    ReplyDelete
  5. How do I get your project into eclipse to actually use???
    How do I get your widget to show up as something I can drag onto the canvas?? I'm lost

    What are the steps??

    Sorry , im just an extreme nubee ?

    ReplyDelete
  6. Proud of you tamilan :)
    Super machi..

    ReplyDelete
  7. Hi....
    code you please post the full code or send it to my my email..

    email : mokdokyun@naver.com

    ReplyDelete
  8. can i disable wheel do scroll ? show display alone??

    e-mail pathomphong@spi.co.th

    Thank for answer...

    ReplyDelete
  9. can any one send complete source code of this my email id is ramki429@gmail.com

    ReplyDelete
    Replies
    1. Hi ram
      soon i will upload another server

      Delete
    2. Can you upload this in "mediafire"? It's very fast. Thank you!

      Delete
  10. hai vijay please send source code of wheelview sruthibn@gmail.com

    ReplyDelete
  11. send me source code ...sruthibn@gmail.com

    ReplyDelete
  12. please any one give me the source code ramzi.slimeni@gmail.com

    ReplyDelete
  13. hi
    can u send me source code .....to my mail Surya.bondadaa@gmail.com

    ReplyDelete
  14. hai vijay please send source code of wheelview solutino.salu@gmail.com

    ReplyDelete
  15. can any one send complete source code of this my email id is only340@naver.com

    please answer me

    ReplyDelete
  16. Thanks a lot for the clear example. Your code helped me big time.. thanks!!

    ReplyDelete
  17. Can u provide the wheel in horizontal ?
    ............

    ReplyDelete
  18. Hi Could You Please send me the full source code to my email mmaidul.islam@gmail.com
    Thanks for your post.Hope in future you would be good asset for android OS.
    Thanks a lot.

    ReplyDelete
  19. HI could you please send me the source code to ganesh.rrp@gmail.com.

    ReplyDelete
  20. Hello Guys..

    I uploaded different Server Please Check it.

    ReplyDelete
  21. Hello!

    Pls send me source code to kovacsp.regens@gmail.com

    ReplyDelete
  22. Hi, could you send me the full source code to my email: thanhha0409@gmail.com?

    Thank you so much!

    ReplyDelete
  23. Hi Unknown,

    you can able to download through that above link.. i hope u can ...

    ReplyDelete
  24. Hi Vijay
    u did a nice job but m afraid that ur link is broken kindly repair it or email me the source code. It 'll be very great full.
    THANX

    Regards
    Bilal Rabbani
    bilalrabbani1@live.com

    ReplyDelete
  25. HI Vijay

    could you please send me the source code on ankit361@gmail.com

    Thank you

    ReplyDelete
  26. Hello Friends,

    I uploaded source in different server.so now you can able to download.

    ReplyDelete
  27. thanks vijayakumar ur blog is really helpfull..and very nice

    ReplyDelete
  28. could you please send me the source code on phoommy@gmail.com

    THANK YOU ^^

    ReplyDelete
  29. this code is not working please any one help me send me code on sharmakunal312@gmail.com

    thanks

    ReplyDelete
  30. This comment has been removed by a blog administrator.

    ReplyDelete
  31. could you please send me the source code on quangle52pm@gmail.com

    THANK YOU ^^

    Reply

    ReplyDelete
  32. initWheel1(R.id.p1);
    what is intiwheel1??

    ReplyDelete
  33. How to use this code for horizontal wheel picker

    ReplyDelete
  34. hi
    this is ashok
    can u plz send full source code to my mail plz.
    vadluri.ashok@gmail.com
    thank you

    ReplyDelete
  35. please any one give me the source code thanarat305@gmail.com

    ReplyDelete

Check out this may be help you

Related Posts Plugin for WordPress, Blogger...