2023兔年日历怎么画
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2023兔年日历怎么画相关的知识,希望对你有一定的参考价值。
参考技术A2023兔年日历的画法如下:
材料准备:纸、笔、彩色笔。
操作步骤:
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兔年日历怎么画的主要内容,如果未能解决你的问题,请参考以下文章