この記事は2019年06月17日に投稿しました。
目次

新・標準プログラマーズライブラリ なるほどなっとく C#入門
- 作者: 出井秀行
- 出版社/メーカー: 技術評論社
- 発売日: 2019/03/16
- メディア: 単行本(ソフトカバー)
- この商品を含むブログを見る
1. はじめに
こんにちは、iOSのエディタアプリPWEditorの開発者の二俣です。
今回は業務で使用しているC#のDatePickerで表示された内容を変更する方法についてです。
2. C#のDatePickerで表示された内容を変更する
C#のDatePickerで表示された内容を変更する方法ですが、DatePickerのSelectedDateプロパティに変更したい日時のDateTimeを設定します。
実装例
前日ボタン、次日ボタンを押下するとそれぞれ1日ずつDatePickerの日付をずらします。
MainWindow.xaml
<Window x:Class="WPFDatePickerSelectedDate.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:WPFDatePickerSelectedDate" xmlns:System="clr-namespace:System;assembly=mscorlib" mc:Ignorable="d" Title="MainWindow" Height="450" Width="800"> <StackPanel Orientation="Horizontal" Height="30" HorizontalAlignment="Center" VerticalAlignment="Top"> <Button Name="buttonPrev" Content="前日" Width="50" Margin="4" Click="ButtonPrev_Click" /> <DatePicker Name="datePicker" Margin="4" SelectedDate="{Binding Source={x:Static System:DateTime.Today}, Mode=OneTime}" /> <Button Name="buttonNext" Content="次日" Width="50" Margin="4" Click="ButtonNext_Click" /> </StackPanel> </Window>
MainWindow.xaml.cs
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Navigation; using System.Windows.Shapes; namespace WPFDatePickerSelectedDate { /// <summary> /// MainWindow.xaml の相互作用ロジック /// </summary> public partial class MainWindow : Window { public MainWindow() { InitializeComponent(); } /** * @brief 前日ボタンが押下されたときに呼び出される。 * * @param [in] sender 前日ボタン * @param [in] e イベント */ private void ButtonPrev_Click(object sender, RoutedEventArgs e) { // 選択された日付を変更します。 ChangeSelecteDate(-1); } /** * @brief 次日ボタンが押下されたときに呼び出される。 * * @param [in] sender 次日ボタン * @param [in] e イベント */ private void ButtonNext_Click(object sender, RoutedEventArgs e) { // 選択された日付を変更します。 ChangeSelecteDate(1); } /** * @brief 選択された日付を変更します。 * * @param [in] offset 日付をずらすオフセット(前日、次日ボタンが押下された時に指定されます) */ private void ChangeSelecteDate(int offset = 0) { // 選択された日付を取得します。 var selectedDate = datePicker.SelectedDate; var dateTime = selectedDate ?? DateTime.Now; // オフセットが指定されている場合、オフセット分日付をずらします。 dateTime = dateTime.AddDays(offset); // DatePickerの選択日付と表示日付を更新します。 datePicker.SelectedDate = dateTime; } } }
3. おわりに
前回
でDateTimeの日付のずらし方はわかりましたが、それをDatePickerにどう設定すればよいかわかりませんでした。
調べてみると
前々回
のSelectedDateプロパティに設定すればよいことがわかりました。
フリーランスにもIT技術にも詳しいコンサルタントだから安心!【ポテパンフリーランス】

確かな力が身につくC#「超」入門 (Informatics&IDEA)
- 作者: 北村愛実
- 出版社/メーカー: SBクリエイティブ
- 発売日: 2017/07/26
- メディア: 単行本
- この商品を含むブログを見る
紹介している一部の記事のコードはGitlabで公開しています。
興味のある方は覗いてみてください。
私が勤務しているニューラルでは、主に組み込み系ソフトの開発を行っております。
弊社製品のハイブリッドOS Bi-OSは高い技術力を評価されており、特に制御系や通信系を得意としています。
私自身はiOSモバイルアプリやウィンドウズアプリを得意としております。
ソフトウェア開発に関して相談などございましたら、お気軽にご連絡ください。
また一緒に働きたい技術者の方も随時募集中です。
興味がありましたらご連絡ください。
EMAIL : info-nr@newral.co.jp / m-futamata@newral.co.jp
TEL : 042-523-3663
FAX : 042-540-1688