2023兔年日历怎么画

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2023兔年日历怎么画相关的知识,希望对你有一定的参考价值。

参考技术A

2023兔年日历的画法如下:

材料准备:纸、笔、彩色笔。

操作步骤:

1、先画两个平行四边形,前面画一个飘起来的方形,侧面上下画两个圆。

2、圆上长长兔耳朵,圆脸中间写个W,下面半圆画嘴,上面圆圈画眼,左手直线往上,右手弧线往下,画出打鼓动态,跳过右手画鼓面鼓身。

3、同样的方法再画一个小兔子,双手弯曲向前做拱手礼。

4、顺着铅笔线画日历,前面画五个月亮形。

5、在飘起来的方形对角方向写前途无量空心字和2023空心字,波浪线折线叠加出山石丛林,高低错落前后遮挡,最后棒棒糖线画云彩。

6、再涂上颜色就完成啦。

方法二:

1、首先,我们要做的是确定2023年兔年的日期。由于每一年都是不一样的,所以在日历表的绘制上也有所不同。通常是将2023年兔年的日期从农历正月一日开始,到农历腊月三十一日结束。接下来,我们可以通过查询日历软件或网站,获取具体每月日期。

2、其次,我们应当针对不同日期进行相应的安排。现在很多学校都会为每一个月,每个季度和每一年安排诸如“国庆节”、“端午节”、“中秋节”、“春节”和“中和节”等重要活动。这些活动需要标记在2023年兔年的日历表上,以便于学生准确的知道他们的假日到底什么时候。

3、最后,在日历表上我们还可以利用颜色,表示特别的活动,比如放假的活动可以用红色,上课的活动用蓝色表示。孩子们更容易记住每一个日子的任务安排,体会兔年的活泼灵动,使用一只兔子或一盏灯作为每一页日历表的美化插画,也是很不错的选择。

4、总而言之,2023年兔年的日历表画法主要有,确定兔年的开始和结束日期,其次根据放假和上课安排确定每天的活动,最后运用颜色和图案进行美化补充,就可以完成一张精美的日历表,从而熟练记住每一天的活动,做出不一样的节日气氛。

WPF 自己画日历

比较尴尬微软提供得日历控件不能很好得修改日按钮,导致一些需求完成不了。。。为为了不重复造轮子网上各种找,最后没找到还是自己造轮子吧。目前只完成当月得显示。

先看效果图

技术分享图片

嗯!就是这样子,还没来的及美化。首先界面代码:

<GroupBox Margin="0,0,10,10" Grid.Column="1">
                <GroupBox.Header>
                    <TextBlock FontSize="20" VerticalAlignment="Top" Text="{Binding NowTime}" />
                </GroupBox.Header>
                <Grid>
                    <DataGrid Name="dgDataSource" AutoGenerateColumns="False"  HeadersVisibility="Column"  ItemsSource="{Binding WeekList}"  IsReadOnly="True"   Grid.Row="0" Margin="0,0,0,26">

                        <DataGrid.Columns>
                            <DataGridTemplateColumn Width="*" Header="星期一"  >
                                <DataGridTemplateColumn.CellTemplate>
                                    <DataTemplate>
                                        <StackPanel>
                                            <TextBlock Text="{Binding Monday}"></TextBlock>
                                            
                                        </StackPanel>
                                        
                                    </DataTemplate>
                                </DataGridTemplateColumn.CellTemplate>


                            </DataGridTemplateColumn>
                            <DataGridTemplateColumn Width="*" Header="星期二"  >
                                <DataGridTemplateColumn.CellTemplate>
                                    <DataTemplate>
                                        <StackPanel>
                                            <TextBlock Text="{Binding Tuesday}"></TextBlock>

                                        </StackPanel>

                                    </DataTemplate>
                                </DataGridTemplateColumn.CellTemplate>


                            </DataGridTemplateColumn>
                            <DataGridTemplateColumn Width="*" Header="星期三"  >
                                <DataGridTemplateColumn.CellTemplate>
                                    <DataTemplate>
                                        <StackPanel>
                                            <TextBlock Text="{Binding Wednesday}"></TextBlock>

                                        </StackPanel>

                                    </DataTemplate>
                                </DataGridTemplateColumn.CellTemplate>


                            </DataGridTemplateColumn>
                            <DataGridTemplateColumn Width="*" Header="星期四"  >
                                <DataGridTemplateColumn.CellTemplate>
                                    <DataTemplate>
                                        <StackPanel>
                                            <TextBlock Text="{Binding Thursday}"></TextBlock>

                                        </StackPanel>

                                    </DataTemplate>
                                </DataGridTemplateColumn.CellTemplate>


                            </DataGridTemplateColumn>
                            <DataGridTemplateColumn Width="*" Header="星期五"  >
                                <DataGridTemplateColumn.CellTemplate>
                                    <DataTemplate>
                                        <StackPanel>
                                            <TextBlock Text="{Binding Friday}"></TextBlock>

                                        </StackPanel>

                                    </DataTemplate>
                                </DataGridTemplateColumn.CellTemplate>


                            </DataGridTemplateColumn>
                            <DataGridTemplateColumn Width="*" Header="星期六"  >
                                <DataGridTemplateColumn.CellTemplate>
                                    <DataTemplate>
                                        <StackPanel>
                                            <TextBlock Text="{Binding Saturday}"></TextBlock>

                                        </StackPanel>

                                    </DataTemplate>
                                </DataGridTemplateColumn.CellTemplate>


                            </DataGridTemplateColumn>
                            <DataGridTemplateColumn Width="*" Header="星期天"  >
                                <DataGridTemplateColumn.CellTemplate>
                                    <DataTemplate>
                                        <StackPanel>
                                            <TextBlock Text="{Binding Sunday}"></TextBlock>

                                        </StackPanel>

                                    </DataTemplate>
                                </DataGridTemplateColumn.CellTemplate>


                            </DataGridTemplateColumn>
                        </DataGrid.Columns>

                    </DataGrid>
                </Grid>
            </GroupBox>

好吧,看看后台计算得代码:

public void CreadDateTimeList(DateTime dt)
        {
            WeekList.Clear();
            var days = dt.GetMothDays();
            NowTime = dt.Year + "" + dt.Month+"";
            var nowday = dt.AddDays(1 - dt.Day);
            int i = 0;
            while (i < days)
            {
                Weeks item = new Weeks();
                while (i < days)
                {
                    var weebel = nowday.AddDays(i).GetDateWeekEl();
                    item.GetType().GetProperty(weebel).SetValue(item, (nowday.Day + i).ToString(), null);
                    i++;
                    if (weebel == "Sunday")
                    {
                        break;
                    }
                }
                WeekList.Add(item);
            }
        }

大概说下,用了内嵌循环,因为一周就7天所以每次判断获取得时间是否是星期天,如果是就再创对象,想得脑壳痛代码就写得很随意,命名也没注意,不如这个“Sunday”应该用个变量命名一下,后期别人看似乎更清晰,嗯!

再勒,用了反射,因为有七个属性,我比较懒懒得用swich case,看着也蛋疼,下面也贴下扩展方法:

/// <summary>
        /// 返回周几
        /// </summary>
        /// <param name="dt">年月日</param>
        /// <returns></returns>
        public static string GetDateWeekEl(this DateTime dt)
        {
            string[] Weeks = new string[] { "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday" };
            return Weeks[Convert.ToInt32(dt.DayOfWeek)];
        }

这个就无须多说,看看定义得每周得类:

public class Weeks : NotifyObj
        {

            #region 一周得时间变量
            /// <summary>
            /// 周一
            /// </summary>
            private string _Monday;
            public string Monday
            {
                get { return _Monday; }
                set
                {
                    if (value != _Monday)
                        _Monday = value;
                    //RaisepertyChanged("Monday");
                }
            }
            /// <summary>
            /// 周二
            /// </summary>
            private string _Tuesday;
            public string Tuesday
            {
                get { return _Tuesday; }
                set
                {
                    if (value != _Tuesday)
                        _Tuesday = value;
                    //RaisepertyChanged("Tuesday");
                }
            }
            /// <summary>
            /// 周三
            /// </summary>
            private string _Wednesday;
            public string Wednesday
            {
                get { return _Wednesday; }
                set
                {
                    if (value != _Wednesday)
                        _Wednesday = value;
                    //RaisepertyChanged("Wednesday");
                }
            }
            /// <summary>
            /// 周四
            /// </summary>
            private string _Thursday;
            public string Thursday
            {
                get { return _Thursday; }
                set
                {
                    if (value != _Thursday)
                        _Thursday = value;
                    // RaisepertyChanged("Thursday");
                }
            }
            /// <summary>
            /// 周五
            /// </summary>
            private string _Friday;
            public string Friday
            {
                get { return _Friday; }
                set
                {
                    if (value != _Friday)
                        _Friday = value;
                    //  RaisepertyChanged("Friday");
                }
            }
            /// <summary>
            /// 周六
            /// </summary>
            private string _Saturday;
            public string Saturday
            {
                get { return _Saturday; }
                set
                {
                    if (value != _Saturday)
                        _Saturday = value;
                    // RaisepertyChanged("Saturday");
                }
            }
            /// <summary>
            /// 周天
            /// </summary>
            private string _Sunday;
            public string Sunday
            {
                get { return _Sunday; }
                set
                {
                    if (value != _Sunday)
                        _Sunday = value;
                    // RaisepertyChanged("Sunday");
                }
            }

            #endregion 一周得日期变量结束
        }

这里继承得NotifyOb类就无须多说,MVVM了解一下,注释掉的事件是因为目前这些字段不需要双向绑定,但是后期要加得预约功能需要加别的值,所以还是继承一下这个类脑壳痛。。。。

 原文地址:https://www.cnblogs.com/GetMoney/p/10305492.html

以上是关于2023兔年日历怎么画的主要内容,如果未能解决你的问题,请参考以下文章

2023年的新日历怎么做?

2021年全年日历一张,怎么做日历简单又漂亮?

2023年节日调休日历表

2021年日历表打印版,2021年日历表

2023年1月放假日历表

买它!程序员专属,技术人必备——编程日历2023限量预售