中文意義就是每日時間間隔計劃生成app
WithInterval:指定要生成觸發器的時間單位和間隔。ui
WithIntervalInHours:指定要生成觸發器的間隔按小時來this
WithIntervalInMinutes:指定要生成觸發器的間隔按分鐘來spa
WithIntervalInSeconds:指定要生成觸發器的間隔按秒來3d
和前面的SimpleSceduleBuilder、CalendarIntervalScheduleBuilder同樣的code
OnDaysOfTheWeek:設置觸發器一週中的哪幾天blog
OnMondayThroughFriday:從星期一到星期五rem
OnSaturdayAndSunday:週六和週日get
OnEveryDay:天天源碼
天天10:00到23:10.00的每一分鐘執行一次
var trigger = TriggerBuilder.Create().WithDailyTimeIntervalSchedule( w => w.OnEveryDay() //設置天天 .StartingDailyAt(TimeOfDay.HourAndMinuteOfDay(10, 00)) //設置天天開始於幾點 .EndingDailyAt(TimeOfDay.HourMinuteAndSecondOfDay(23, 10, 0)) //設置每日結束於幾點 .WithIntervalInMinutes(1)//間隔分鐘 ).Build();
一週當中的星期二和星期三每秒執行一次
List<DayOfWeek> dayOfWeeks = new List<DayOfWeek>(); dayOfWeeks.Add(DayOfWeek.Wednesday); dayOfWeeks.Add(DayOfWeek.Tuesday); trigger = TriggerBuilder.Create().WithDailyTimeIntervalSchedule( w=>w.OnDaysOfTheWeek(dayOfWeeks)//.OnDaysOfTheWeek(new DayOfWeek[2] { DayOfWeek.Wednesday,DayOfWeek.Tuesday}) .WithIntervalInSeconds(1) ).Build();
源碼實現
/// <summary> /// Set the trigger to fire on the given days of the week. /// </summary> /// <param name="onDaysOfWeek">a Set containing the integers representing the days of the week, defined by <see cref="DayOfWeek.Sunday"/> - <see cref="DayOfWeek.Saturday"/>. /// </param> /// <returns>the updated DailyTimeIntervalScheduleBuilder</returns> public DailyTimeIntervalScheduleBuilder OnDaysOfTheWeek(IReadOnlyCollection<DayOfWeek> onDaysOfWeek) { if (onDaysOfWeek == null || onDaysOfWeek.Count == 0) { throw new ArgumentException("Days of week must be an non-empty set."); } foreach (DayOfWeek day in onDaysOfWeek) { if (!AllDaysOfTheWeek.Contains(day)) { throw new ArgumentException("Invalid value for day of week: " + day); } } daysOfWeek = new HashSet<DayOfWeek>(onDaysOfWeek); return this; } /// <summary> /// Set the trigger to fire on the given days of the week. /// </summary> /// <param name="onDaysOfWeek">a variable length list of week days representing the days of the week</param> /// <returns>the updated DailyTimeIntervalScheduleBuilder</returns> public DailyTimeIntervalScheduleBuilder OnDaysOfTheWeek(params DayOfWeek[] onDaysOfWeek) { return OnDaysOfTheWeek((IReadOnlyCollection<DayOfWeek>) onDaysOfWeek); } /// <summary> /// Set the trigger to fire on the days from Monday through Friday. /// </summary> /// <returns>the updated DailyTimeIntervalScheduleBuilder</returns> public DailyTimeIntervalScheduleBuilder OnMondayThroughFriday() { daysOfWeek = new HashSet<DayOfWeek>(MondayThroughFriday); return this; } /// <summary> /// Set the trigger to fire on the days Saturday and Sunday. /// </summary> /// <returns>the updated DailyTimeIntervalScheduleBuilder</returns> public DailyTimeIntervalScheduleBuilder OnSaturdayAndSunday() { daysOfWeek = new HashSet<DayOfWeek>(SaturdayAndSunday); return this; } /// <summary> /// Set the trigger to fire on all days of the week. /// </summary> /// <returns>the updated DailyTimeIntervalScheduleBuilder</returns> public DailyTimeIntervalScheduleBuilder OnEveryDay() { daysOfWeek = new HashSet<DayOfWeek>(AllDaysOfTheWeek); return this; }
StartingDailyAt:開始時間於
EndingDailyAt:結束時間於
源碼實現
/// <summary> /// The TimeOfDay for this trigger to start firing each day. /// </summary> /// <param name="timeOfDayUtc"></param> /// <returns>the updated DailyTimeIntervalScheduleBuilder</returns> public DailyTimeIntervalScheduleBuilder StartingDailyAt(TimeOfDay timeOfDayUtc) { startTimeOfDayUtc = timeOfDayUtc ?? throw new ArgumentException("Start time of day cannot be null!"); return this; } /// <summary> /// The TimeOfDay for this trigger to end firing each day. /// </summary> /// <param name="timeOfDayUtc"></param> /// <returns>the updated DailyTimeIntervalScheduleBuilder</returns> public DailyTimeIntervalScheduleBuilder EndingDailyAt(TimeOfDay timeOfDayUtc) { endTimeOfDayUtc = timeOfDayUtc; return this; }
EndingDailyAfterCount:使用count、interval和StarTimeOfDay計算並設置EndTimeOfDay。
源碼實現
/// <summary> /// Calculate and set the EndTimeOfDay using count, interval and StarTimeOfDay. This means /// that these must be set before this method is call. /// </summary> /// <param name="count"></param> /// <returns>the updated DailyTimeIntervalScheduleBuilder</returns> public DailyTimeIntervalScheduleBuilder EndingDailyAfterCount(int count) { if (count <= 0) { throw new ArgumentException("Ending daily after count must be a positive number!"); } if (startTimeOfDayUtc == null) { throw new ArgumentException("You must set the StartDailyAt() before calling this EndingDailyAfterCount()!"); } DateTimeOffset today = SystemTime.UtcNow(); DateTimeOffset startTimeOfDayDate = startTimeOfDayUtc.GetTimeOfDayForDate(today).Value; DateTimeOffset maxEndTimeOfDayDate = TimeOfDay.HourMinuteAndSecondOfDay(23, 59, 59).GetTimeOfDayForDate(today).Value; //apply proper offsets according to timezone TimeZoneInfo targetTimeZone = timeZone ?? TimeZoneInfo.Local; startTimeOfDayDate = new DateTimeOffset(startTimeOfDayDate.DateTime, TimeZoneUtil.GetUtcOffset(startTimeOfDayDate.DateTime, targetTimeZone)); maxEndTimeOfDayDate = new DateTimeOffset(maxEndTimeOfDayDate.DateTime, TimeZoneUtil.GetUtcOffset(maxEndTimeOfDayDate.DateTime, targetTimeZone)); TimeSpan remainingMillisInDay = maxEndTimeOfDayDate - startTimeOfDayDate; TimeSpan intervalInMillis; if (intervalUnit == IntervalUnit.Second) { intervalInMillis = TimeSpan.FromSeconds(interval); } else if (intervalUnit == IntervalUnit.Minute) { intervalInMillis = TimeSpan.FromMinutes(interval); } else if (intervalUnit == IntervalUnit.Hour) { intervalInMillis = TimeSpan.FromHours(interval); } else { throw new ArgumentException("The IntervalUnit: " + intervalUnit + " is invalid for this trigger."); } if (remainingMillisInDay < intervalInMillis) { throw new ArgumentException("The startTimeOfDay is too late with given Interval and IntervalUnit values."); } long maxNumOfCount = remainingMillisInDay.Ticks / intervalInMillis.Ticks; if (count > maxNumOfCount) { throw new ArgumentException("The given count " + count + " is too large! The max you can set is " + maxNumOfCount); } TimeSpan incrementInMillis = TimeSpan.FromTicks((count - 1) * intervalInMillis.Ticks); DateTimeOffset endTimeOfDayDate = startTimeOfDayDate.Add(incrementInMillis); if (endTimeOfDayDate > maxEndTimeOfDayDate) { throw new ArgumentException("The given count " + count + " is too large! The max you can set is " + maxNumOfCount); } DateTime cal = SystemTime.UtcNow().Date; cal = cal.Add(endTimeOfDayDate.TimeOfDay); endTimeOfDayUtc = TimeOfDay.HourMinuteAndSecondOfDay(cal.Hour, cal.Minute, cal.Second); return this; }