Androidで日時ピッカーを作成する方法は?[閉まっている]


128

日付と時刻を同時に選択できるAndroidウィジェットはありますか?基本的な時間ピッカー日付ピッカーはすでに使用しています。

しかし、それらはそれほどセクシーでユーザーフレンドリーではありません(私は見つけました)。日付と時刻の両方を含むウィジェットが存在するかどうか知っていますか?

どうもありがとう、Luc

回答:


52

これを提供するAndroidには何も組み込まれていません。

編集:Andriodは組み込みのピッカーを提供するようになりました。@Odedの回答を確認する


2
この回答は1年以上前のものですが、この回答は更新する必要があると思います。以下のすべての方法でRabiによって参照されるDateSliderライブラリは、これに最適であるようです。
Stephan Branczyk 2011

これは素晴らしいウィジェットなので、この回答は更新する必要があります。ただし、Rabiが指すコードはすでに少し古く、非推奨のメソッドがいくつか含まれていますshowDialog。たぶん、もっと新しいものがやって来るでしょう。
Eugene van der Merwe

13
実際の答えは正しいので更新すべきではありません。AndroidDateSliderが存在する場合でも、その機能を提供するAndroidに組み込まれたものはありません。
クリスティアン

4
Googleがビジネスアプリケーションで最も広く使用されているコントロールのいずれもサポートしていないという事実に困惑しているのは私だけですか?
l46kok 2015年

76

両方DatePickerTimePickerレイアウトXMLに入れます。

date_time_picker.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:padding="8dp"
    android:layout_height="match_parent">

    <DatePicker
        android:id="@+id/date_picker"
        android:layout_width="match_parent"
        android:calendarViewShown="true"
        android:spinnersShown="false"
        android:layout_weight="4"
        android:layout_height="0dp" />

    <TimePicker
        android:id="@+id/time_picker"
        android:layout_weight="4"
        android:layout_width="match_parent"
        android:layout_height="0dp" />

    <Button
        android:id="@+id/date_time_set"
        android:layout_weight="1"
        android:layout_width="match_parent"
        android:text="Set"
        android:layout_height="0dp" />

</LinearLayout>

コード:

final View dialogView = View.inflate(activity, R.layout.date_time_picker, null);
final AlertDialog alertDialog = new AlertDialog.Builder(activity).create();

dialogView.findViewById(R.id.date_time_set).setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View view) {

         DatePicker datePicker = (DatePicker) dialogView.findViewById(R.id.date_picker);
         TimePicker timePicker = (TimePicker) dialogView.findViewById(R.id.time_picker);

         Calendar calendar = new GregorianCalendar(datePicker.getYear(),
                            datePicker.getMonth(),
                            datePicker.getDayOfMonth(),
                            timePicker.getCurrentHour(),
                            timePicker.getCurrentMinute());

         time = calendar.getTimeInMillis();
         alertDialog.dismiss();
    }});
alertDialog.setView(dialogView);
alertDialog.show();

2
素晴らしい例、ありがとう。ワンポイント...おそらくalertDialog.dismiss(); onClick実装の最後。
ジョナサン

この例では年を選択できません。
lostintranslation 2015年

ただ1つの問題... android Lで使用すると、日付と時刻のピッカーが画面に収まりません。そのため、scrollViewにlinearLayoutを配置します...今問題は、レイアウトがスクロールする時間を変更しようとすると、 scrollView..Any solution for thisのため
Dominic D'Souza

助けてください、それは横向きモードに適合しません、それを修正する方法
Awadesh

1
Android
6.0以降

64

この関数を使用すると、日付と時刻を1つずつ選択して、グローバル変数日付に設定できます。ライブラリもXMLもありません。

Calendar date;
public void showDateTimePicker() {
   final Calendar currentDate = Calendar.getInstance();
   date = Calendar.getInstance();
   new DatePickerDialog(context, new DatePickerDialog.OnDateSetListener() {
       @Override
       public void onDateSet(DatePicker view, int year, int monthOfYear, int dayOfMonth) {
            date.set(year, monthOfYear, dayOfMonth);
            new TimePickerDialog(context, new TimePickerDialog.OnTimeSetListener() {
                @Override
                public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
                    date.set(Calendar.HOUR_OF_DAY, hourOfDay);
                    date.set(Calendar.MINUTE, minute);
                    Log.v(TAG, "The choosen one " + date.getTime());
                }
            }, currentDate.get(Calendar.HOUR_OF_DAY), currentDate.get(Calendar.MINUTE), false).show();
       }
   }, currentDate.get(Calendar.YEAR), currentDate.get(Calendar.MONTH), currentDate.get(Calendar.DATE)).show();
}

最も単純な方法の1つ
Vicky Thakor

3
コールは、APIレベル24が必要です
RRaj

27

AndroidのDialogFragmentでのDatePickerとTimePickerの組み合わせ

これを行うためのライブラリを作成しました。色もカスタマイズ可能です!

使い方はとても簡単です。

まず、リスナーを作成します。

private SlideDateTimeListener listener = new SlideDateTimeListener() {

    @Override
    public void onDateTimeSet(Date date)
    {
        // Do something with the date. This Date object contains
        // the date and time that the user has selected.
    }

    @Override
    public void onDateTimeCancel()
    {
        // Overriding onDateTimeCancel() is optional.
    }
};

次に、ダイアログを作成して表示します。

new SlideDateTimePicker.Builder(getSupportFragmentManager())
    .setListener(listener)
    .setInitialDate(new Date())
    .build()
    .show();

お役に立てれば幸いです。


本当に良いもの!私の時間を節約しました!ありがとう!しかし、gradle依存文字列が有効ではないと思うので、コードを複製する必要がありましたか?
kuldeep、2015

@ k2ibeginプロジェクトのgitページでは、モジュール全体をインポートするか、「コードを複製する」と言われていますが、それはポイントです。彼は素晴らしいリポジトリを公開していません。JDJ素晴らしい仕事人、素晴らしいlib。
Ninja Coding

@JDJ申し訳ありませんが、ライブラリをプロジェクトに追加できませんでした。方法を説明していただけますか?
セバスチャンデルガード2016

3
手順1 [クローンまたはダウンロード]をクリックしてプロジェクト全体をダウンロードし、[ZIPをダウンロード] 手順2 zipコンテンツを抽出するか、ZIP \ SlideDateTimePicker-master \ slideDateTimePickerフォルダーのみを既存のプロジェクトのルートフォルダーコンテナーにコピーします。プラグインを追加したい。ステップ3 コンパイルプロジェクト( ':slideDateTimePicker')またはAndroid StudioでGradleを介して依存関係を追加します。[ファイル]> [新規]> [プロジェクトのインポート]を選択し、抽出されたフォルダーを選択して、プロジェクトのインポートを構成します。
Ninja Coding

2
@JDJバグがあります。LollipopまたはMarshmallowでは、ネイティブのDatePickerおよびTimePickerは表示されず、代わりにpre-lollipopコンポーネントが表示されます。
Ninja Coding

20

DatePicker更新時間メソッドで時間ピッカーダイアログを呼び出します。同時には呼び出されませんが、DatePickerセットボタンを押すと呼び出されます。タイムピッカーダイアログが開きます。その方法を以下に示します。

package com.android.date;

import java.util.Calendar;

import android.app.Activity;
import android.app.DatePickerDialog;
import android.app.Dialog;
import android.app.TimePickerDialog;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.DatePicker;
import android.widget.TextView;
import android.widget.TimePicker;

public class datepicker extends Activity {

    private TextView mDateDisplay;
    private Button mPickDate;
    private int mYear;
    private int mMonth;
    private int mDay;
    private TextView mTimeDisplay;
    private Button mPickTime;

    private int mhour;
    private int mminute;

    static final int TIME_DIALOG_ID = 1;

    static final int DATE_DIALOG_ID = 0;

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

        mDateDisplay =(TextView)findViewById(R.id.date);
        mPickDate =(Button)findViewById(R.id.datepicker);
        mTimeDisplay = (TextView) findViewById(R.id.time);
        mPickTime = (Button) findViewById(R.id.timepicker);

        //Pick time's click event listener
        mPickTime.setOnClickListener(new View.OnClickListener(){

            @Override
            public void onClick(View v) {
                showDialog(TIME_DIALOG_ID);
            }
        });

        //PickDate's click event listener 
        mPickDate.setOnClickListener(new View.OnClickListener() {
            public void onClick(View v) {
                showDialog(DATE_DIALOG_ID);
            }
        });

        final Calendar c = Calendar.getInstance();
        mYear = c.get(Calendar.YEAR);
        mMonth = c.get(Calendar.MONTH);
        mDay = c.get(Calendar.DAY_OF_MONTH);
        mhour = c.get(Calendar.HOUR_OF_DAY);
        mminute = c.get(Calendar.MINUTE);
    }

    //-------------------------------------------update date---//    
    private void updateDate() {
        mDateDisplay.setText(
            new StringBuilder()
                    // Month is 0 based so add 1
                    .append(mDay).append("/")
                    .append(mMonth + 1).append("/")
                    .append(mYear).append(" "));
        showDialog(TIME_DIALOG_ID);
    }

      //-------------------------------------------update time---//    
    public void updatetime() {
        mTimeDisplay.setText(
                new StringBuilder()
                        .append(pad(mhour)).append(":")
                        .append(pad(mminute))); 
    }

    private static String pad(int c) {
        if (c >= 10)
            return String.valueOf(c);
        else
            return "0" + String.valueOf(c);


    //Datepicker dialog generation  

    private DatePickerDialog.OnDateSetListener mDateSetListener =
        new DatePickerDialog.OnDateSetListener() {

            public void onDateSet(DatePicker view, int year, 
                                  int monthOfYear, int dayOfMonth) {
                mYear = year;
                mMonth = monthOfYear;
                mDay = dayOfMonth;
                updateDate();
            }
        };


     // Timepicker dialog generation
        private TimePickerDialog.OnTimeSetListener mTimeSetListener =
            new TimePickerDialog.OnTimeSetListener() {
                public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
                    mhour = hourOfDay;
                    mminute = minute;
                    updatetime();
                }
            };

        @Override
        protected Dialog onCreateDialog(int id) {
            switch (id) {
            case DATE_DIALOG_ID:
                return new DatePickerDialog(this,
                            mDateSetListener,
                            mYear, mMonth, mDay);

            case TIME_DIALOG_ID:
                return new TimePickerDialog(this,
                        mTimeSetListener, mhour, mminute, false);

            }
            return null;
        }
}

main.xmlを以下に示します

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">

    <TextView  
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content" 
        android:text="@string/hello"/>

    <TextView android:id="@+id/time"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text=""/>

    <Button
        android:id="@+id/timepicker"
        android:text="Change Time" 
        android:layout_height="wrap_content" 
        android:layout_width="wrap_content"/>

    <TextView 
        android:id="@+id/date"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text=""/>

    <Button android:id="@+id/datepicker"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="200dp"
        android:text="Change the date"/>

</LinearLayout>

14

また、DatePickerとTimePickerを組み合わせたいと思っていました。そこで、1つのインターフェイスで両方を処理するAPIを作成します。:)

https://github.com/Kunzisoft/Android-SwitchDateTimePicker

ここに画像の説明を入力してください

SublimePickerを使用することもできます


とても素敵でエレガントなソリューション。よく働く。私が遭遇したいくつかの小さな詳細.. 1)AM / PMラベルが切り捨てられていたため、スタイルでより小さいフォントサイズを<item name="android:textSize">11sp</item> 設定し、太字の設定を削除する必要がありました。2)setDefaultDateTime(..)呼び出す必要があるように見えるか、ランタイム例外が発生するように見えるのでCalendar.getInstance().getTime()、パラメーターとして呼び出します。これまでに見た日付ピッカーにとって最高のgithubプロジェクト-共有してくれてありがとう
Gene Bo

13

リンクするURLは、時間ピッカーのあるダイアログと日付ピッカーのある別のダイアログをポップアップする方法を示します。ただし、これらのUIウィジェットを独自のレイアウトで直接使用できることに注意する必要があります。TimePickerとDatePickerの両方を含む独自のダイアログを同じビューに作成して、私が探していると思うことを達成することができます。

つまり、TimePickerDialogおよびDatePickerDialogを使用する代わりに、UIウィジェットTimePickerおよびDatePickerを独自のダイアログまたはアクティビティで直接使用します。


1
@Jaydeep Khamarの解決策は求められているものではなく、2つの別々のダイアログを開いていることに同意します。これがすでに組み合わされている基本的なサンプルコードを確認することをお勧めします。
Eugene van der Merwe

9

私は自分のプロジェクトの1つで同じ問題に直面していたため、日付と時刻の両方のピッカーを1つの使いやすいダイアログに表示するカスタムウィジェットを作成することにしました。http://code.google.com/p/datetimepicker/で、サンプルとともにソースコードを取得できます。コードはApache 2.0でライセンスされています。



5

wdullaer / MaterialDateTimePickerのいずれかを使用できますDatePicker library

  • 最初にDatePickerを表示します。

    private void showDatePicker() {
    Calendar now = Calendar.getInstance();
    DatePickerDialog dpd = DatePickerDialog.newInstance(
            HomeActivity.this,
            now.get(Calendar.YEAR),
            now.get(Calendar.MONTH),
            now.get(Calendar.DAY_OF_MONTH)
    );
    dpd.show(getFragmentManager(), "Choose Date:");
    }
  • その後 onDateSet callback store date & show TimePicker

    @Override
    public void onDateSet(DatePickerDialog view, int year, int monthOfYear, int dayOfMonth) {
    Calendar cal = Calendar.getInstance();
    cal.set(year, monthOfYear, dayOfMonth);
    filter.setDate(cal.getTime());
    new Handler().postDelayed(new Runnable() {
        @Override
        public void run() {
            showTimePicker();
        }
    },500);
    }
  • オンonTimeSet callbackストア時間

     @Override
     public void onTimeSet(RadialPickerLayout view, int hourOfDay, int minute) {
    Calendar cal = Calendar.getInstance();
    if(filter.getDate()!=null)
        cal.setTime(filter.getDate());
    cal.set(Calendar.HOUR_OF_DAY,hourOfDay);
    cal.set(Calendar.MINUTE,minute);
    }


2

別のオプションは、iOSのUIDatePickerダイアログをかなり閉じるandroid-wheelプロジェクトです。

それは何でも(日付と時刻を含む)選択する垂直スライダーを提供します。水平スライダーを使用する場合は、Rabiが参照するDateSliderの方が適しています。


リンク切れ。これがandroid-wheelのフォークです
jk7


1

日付ピッカーと時間ピッカーを組み合わせたアラートダイアログを作成しました。https://github.com/nguyentoantuit/androidでコードを取得できます 注:DateTimePickerはライブラリです


1
リンクのみの回答は推奨されないことに注意してください。SOの回答は、ソリューションの検索のエンドポイントである必要があります。参照としてリンクを維持しながら、ここにスタンドアロンの概要を追加することを検討してください。
クレオパトラ2013

1

これは、1つのダイアログを次々に表示するというJaydeepのアイデアのよりコンパクトなバージョンです。依存関係がないため、このソリューションが好きです。

        Date value = new Date();
        final Calendar cal = Calendar.getInstance();
        cal.setTime(value);
        new DatePickerDialog(this,
            new DatePickerDialog.OnDateSetListener() {
                @Override public void onDateSet(DatePicker view, 
                        int y, int m, int d) {
                    cal.set(Calendar.YEAR, y);
                    cal.set(Calendar.MONTH, m);
                    cal.set(Calendar.DAY_OF_MONTH, d);

                    // now show the time picker
                    new TimePickerDialog(NoteEditor.this,
                        new TimePickerDialog.OnTimeSetListener() {
                            @Override public void onTimeSet(TimePicker view, 
                                    int h, int min) {
                                cal.set(Calendar.HOUR_OF_DAY, h);
                                cal.set(Calendar.MINUTE, min);
                                value = cal.getTime();
                            }
                        }, cal.get(Calendar.HOUR_OF_DAY), 
                            cal.get(Calendar.MINUTE), true).show();
                 }
            }, cal.get(Calendar.YEAR), cal.get(Calendar.MONTH),
            cal.get(Calendar.DAY_OF_MONTH)).show();
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.