WinForm(C#)倒计时(年月日时分秒)

简介:

一个朋友提到这个问题,就随手写了一个,本以为很容易,却写了差不多半个小时,关键是年月的判断,现把代码贴出来供需要的朋友参考,也希望能看到大家的计算方法,先在WinForm窗体上放一个label控件(ID为lblShow) 和一个Timer控件(ID为timerMain),后台代码如下:

     public   partial   class  FormTime : Form
    {
        
public  FormTime()
        {
            InitializeComponent();
        }

        
private   void  FormTime_Load( object  sender, EventArgs e)
        {
            timerMain.Enabled 
=   true ;
            timerMain.Interval 
=   1000 ;
            timerMain.Start();
        }

        
private   void  timerMain_Tick( object  sender, EventArgs e)
        {
            DateTime observeTime 
=  DateTime.Parse( " 2023-11-22 22:45:30 " ); // 倒计时日期
            DateTime now  =  DateTime.Now;     // 当前时间
            TimeSpan ts  =  observeTime.Subtract(now);     // 两个时间之差
            StringBuilder result = new  StringBuilder();    // 存放结果
             int  year = observeTime.Year  -  now.Year;        // 得到相差的年
             int  month  =  observeTime.Month  -  now.Month;   // 得到相差的月
             int  day  =  observeTime.Day  -  now.Day;         // 得到相差的日

            
int  hmh = (observeTime.Hour - now.Hour) * 3600 + (observeTime.Minute - now.Minute) * 60 + (observeTime.Second - now.Second);

            
// 如果时分秒比现在的时间晚
             if (hmh <= 0 )
            {
                
// 向日借一
                day -- ;
                
if ((day <= 0 && month > 0 ) || (day <= 0 && year > 0 ))
                {
                    
// 如果天数小于0向月借一
                    day = GetDay(now.Year, now.Month) -  now.Day  +  observeTime.Day;
                    month
-- ;
                    
if (month < 0 && year > 0 )
                    {
                        
// 如果月数小于0,向年借一,同时把月专为正数
                        month  +=   12 ;
                        year
-- ;
                    }
                }
            }


            
// 如果天数小于0向月借一
             if  ((day  <   0   &&  month  >   0 ||  (day  <   0   &&  year  >   0 ))
            {
                day 
=  GetDay(now.Year, now.Month)  -  now.Day  +  observeTime.Day;
                month
-- ;
                
if  (month  <   0   &&  year  >   0 )
                {
                    
// 如果月数小于0,向年借一,同时把月专为正数
                    month  +=   12 ;
                    year
-- ;
                }
            }

            
// 如果月数小于0,向年借一,同时把月专为正数
             if  (month  <   0   &&  year  >   0 )
            {
                month 
+=   12 ;
                year
-- ;
            }

            
if  (year < 0 || (year  ==   0   &&  month  <   0 ) || (year  ==   0   &&  month == 0 && day < 0 ))
            {
                lblShow.Text 
=   " 已超过日期 " ;
                
return ;
            }

            
if  (year >   0 )
            {
                result.Append(year
+   " " );
            }
            
if  (month >   0 )
            {
                result.Append(month
+   " " );
            }
            
if  (day >   0 )
            {
                result.Append(day
+   " " );
            }
            
if  (ts.Hours  >   0 )
            {
                result.Append(ts.Hours 
+   " " );
            }
            
if  (ts.Minutes  >   0 )
            {
                result.Append(ts.Minutes 
+   " " );
            }
            
if  (ts.Seconds  >   0 )
            {
                result.Append(ts.Seconds 
+   " " );
            }
            
if (result.Length == 0 )
            {
                result.Append(
" 已超过日期 " );
            }
            lblShow.Text 
=  result.ToString();
        }

        
// 输入月份后获得该月天数
         private   int  GetDay( int  year,  int  month)
        {
            
int  result  =   31 ;
            
switch  (month)                           
            {
                
case   4 :
                
case   6 :
                
case   9 :
                
case   11 :
                    result 
=   30 ;
                    
break ;
                
case   2 :
                    
if  ((year  %   100   !=   0 &&  (year %   4   ==   0 ||  (year %   400   ==   0 ))
                    {
                        result 
=   29 ;
                    }
                    
else
                    {
                        result 
=   28 ;
                    }
                    
break ;
            }
            
return  result;
        }
    }

 

 效果图:

 



本文转自Artwl博客园博客,原文链接:http://www.cnblogs.com/artwl/,如需转载请自行联系原作者

相关文章
|
C#
C# 如何使用倒计时
C# 如何使用倒计时
358 0
C#编程-13:ProgressBar制作时间进度倒计时
C#编程-13:ProgressBar制作时间进度倒计时
295 0
C#编程-13:ProgressBar制作时间进度倒计时
|
开发框架 前端开发 .NET
C#编程与Web开发
【4月更文挑战第21天】本文探讨了C#在Web开发中的应用,包括使用ASP.NET框架、MVC模式、Web API和Entity Framework。C#作为.NET框架的主要语言,结合这些工具,能创建动态、高效的Web应用。实际案例涉及企业级应用、电子商务和社交媒体平台。尽管面临竞争和挑战,但C#在Web开发领域的前景将持续拓展。
457 3
|
SQL 开发框架 安全
C#编程与多线程处理
【4月更文挑战第21天】探索C#多线程处理,提升程序性能与响应性。了解C#中的Thread、Task类及Async/Await关键字,掌握线程同步与安全,实践并发计算、网络服务及UI优化。跟随未来发展趋势,利用C#打造高效应用。
332 3
|
10月前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
191 3
|
9月前
|
存储 安全 编译器
学懂C#编程:属性(Property)的概念定义及使用详解
通过深入理解和使用C#的属性,可以编写更清晰、简洁和高效的代码,为开发高质量的应用程序奠定基础。
488 12
|
10月前
|
设计模式 C# 图形学
Unity 游戏引擎 C# 编程:一分钟浅谈
本文介绍了在 Unity 游戏开发中使用 C# 的基础知识和常见问题。从 `MonoBehavior` 类的基础用法,到变量和属性的管理,再到空引用异常、资源管理和性能优化等常见问题的解决方法。文章还探讨了单例模式、事件系统和数据持久化等高级话题,旨在帮助开发者避免常见错误,提升游戏开发效率。
378 4
|
安全 程序员 编译器
C#一分钟浅谈:泛型编程基础
在现代软件开发中,泛型编程是一项关键技能,它使开发者能够编写类型安全且可重用的代码。C# 自 2.0 版本起支持泛型编程,本文将从基础概念入手,逐步深入探讨 C# 中的泛型,并通过具体实例帮助理解常见问题及其解决方法。泛型通过类型参数替代具体类型,提高了代码复用性和类型安全性,减少了运行时性能开销。文章详细介绍了如何定义泛型类和方法,并讨论了常见的易错点及解决方案,帮助读者更好地掌握这一技术。
186 11
|
12月前
|
API C#
C# 一分钟浅谈:文件系统编程
在软件开发中,文件系统操作至关重要。本文将带你快速掌握C#中文件系统编程的基础知识,涵盖基本概念、常见问题及解决方法。文章详细介绍了`System.IO`命名空间下的关键类库,并通过示例代码展示了路径处理、异常处理、并发访问等技巧,还提供了异步API和流压缩等高级技巧,帮助你写出更健壮的代码。
119 2
|
12月前
|
SQL 开发框架 安全
并发集合与任务并行库:C#中的高效编程实践
在现代软件开发中,多核处理器普及使多线程编程成为提升性能的关键。然而,传统同步模型在高并发下易引发死锁等问题。为此,.NET Framework引入了任务并行库(TPL)和并发集合,简化并发编程并增强代码可维护性。并发集合允许多线程安全访问,如`ConcurrentQueue&lt;T&gt;`和`ConcurrentDictionary&lt;TKey, TValue&gt;`,有效避免数据不一致。TPL则通过`Task`类实现异步操作,提高开发效率。正确使用这些工具可显著提升程序性能,但也需注意任务取消和异常处理等常见问题。
140 1