|
|
@ -1,18 +1,27 @@
|
|
|
|
using DownKyi.Events;
|
|
|
|
using DownKyi.Core.BiliApi.VideoStream;
|
|
|
|
using DownKyi.Images;
|
|
|
|
using DownKyi.Core.Storage;
|
|
|
|
|
|
|
|
using DownKyi.Core.Utils;
|
|
|
|
using DownKyi.CustomControl;
|
|
|
|
using DownKyi.CustomControl;
|
|
|
|
|
|
|
|
using DownKyi.Events;
|
|
|
|
|
|
|
|
using DownKyi.Images;
|
|
|
|
|
|
|
|
using DownKyi.Services;
|
|
|
|
|
|
|
|
using DownKyi.Services.Download;
|
|
|
|
using DownKyi.Utils;
|
|
|
|
using DownKyi.Utils;
|
|
|
|
using DownKyi.ViewModels.PageViewModels;
|
|
|
|
using DownKyi.ViewModels.PageViewModels;
|
|
|
|
using DownKyi.ViewModels.UserSpace;
|
|
|
|
using DownKyi.ViewModels.UserSpace;
|
|
|
|
using Prism.Commands;
|
|
|
|
using Prism.Commands;
|
|
|
|
using Prism.Events;
|
|
|
|
using Prism.Events;
|
|
|
|
using Prism.Regions;
|
|
|
|
using Prism.Regions;
|
|
|
|
|
|
|
|
using Prism.Services.Dialogs;
|
|
|
|
using System;
|
|
|
|
using System;
|
|
|
|
|
|
|
|
using System.Collections;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Collections.ObjectModel;
|
|
|
|
using System.Collections.ObjectModel;
|
|
|
|
using System.Linq;
|
|
|
|
using System.Linq;
|
|
|
|
using System.Text;
|
|
|
|
using System.Threading;
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
|
|
using System.Windows;
|
|
|
|
|
|
|
|
using System.Windows.Media.Imaging;
|
|
|
|
|
|
|
|
|
|
|
|
namespace DownKyi.ViewModels
|
|
|
|
namespace DownKyi.ViewModels
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -20,6 +29,10 @@ namespace DownKyi.ViewModels
|
|
|
|
{
|
|
|
|
{
|
|
|
|
public const string Tag = "PagePublication";
|
|
|
|
public const string Tag = "PagePublication";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private readonly IDialogService dialogService;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private CancellationTokenSource tokenSource;
|
|
|
|
|
|
|
|
|
|
|
|
private long mid = -1;
|
|
|
|
private long mid = -1;
|
|
|
|
|
|
|
|
|
|
|
|
// 每页视频数量,暂时在此写死,以后在设置中增加选项
|
|
|
|
// 每页视频数量,暂时在此写死,以后在设置中增加选项
|
|
|
@ -27,6 +40,27 @@ namespace DownKyi.ViewModels
|
|
|
|
|
|
|
|
|
|
|
|
#region 页面属性申明
|
|
|
|
#region 页面属性申明
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private GifImage loading;
|
|
|
|
|
|
|
|
public GifImage Loading
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
get => loading;
|
|
|
|
|
|
|
|
set => SetProperty(ref loading, value);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private Visibility loadingVisibility;
|
|
|
|
|
|
|
|
public Visibility LoadingVisibility
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
get => loadingVisibility;
|
|
|
|
|
|
|
|
set => SetProperty(ref loadingVisibility, value);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private Visibility noDataVisibility;
|
|
|
|
|
|
|
|
public Visibility NoDataVisibility
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
get => noDataVisibility;
|
|
|
|
|
|
|
|
set => SetProperty(ref noDataVisibility, value);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private VectorImage arrowBack;
|
|
|
|
private VectorImage arrowBack;
|
|
|
|
public VectorImage ArrowBack
|
|
|
|
public VectorImage ArrowBack
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -48,18 +82,11 @@ namespace DownKyi.ViewModels
|
|
|
|
set => SetProperty(ref selectTabId, value);
|
|
|
|
set => SetProperty(ref selectTabId, value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private int countPage;
|
|
|
|
private bool isEnabled = true;
|
|
|
|
public int CountPage
|
|
|
|
public bool IsEnabled
|
|
|
|
{
|
|
|
|
{
|
|
|
|
get => countPage;
|
|
|
|
get => isEnabled;
|
|
|
|
set => SetProperty(ref countPage, value);
|
|
|
|
set => SetProperty(ref isEnabled, value);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private int currentPage;
|
|
|
|
|
|
|
|
public int CurrentPage
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
get => currentPage;
|
|
|
|
|
|
|
|
set => SetProperty(ref currentPage, value);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private CustomPagerViewModel pager;
|
|
|
|
private CustomPagerViewModel pager;
|
|
|
@ -69,16 +96,39 @@ namespace DownKyi.ViewModels
|
|
|
|
set => SetProperty(ref pager, value);
|
|
|
|
set => SetProperty(ref pager, value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private ObservableCollection<PublicationMedia> medias;
|
|
|
|
|
|
|
|
public ObservableCollection<PublicationMedia> Medias
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
get => medias;
|
|
|
|
|
|
|
|
set => SetProperty(ref medias, value);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private bool isSelectAll;
|
|
|
|
|
|
|
|
public bool IsSelectAll
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
get => isSelectAll;
|
|
|
|
|
|
|
|
set => SetProperty(ref isSelectAll, value);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
|
|
public ViewPublicationViewModel(IEventAggregator eventAggregator) : base(eventAggregator)
|
|
|
|
public ViewPublicationViewModel(IEventAggregator eventAggregator, IDialogService dialogService) : base(eventAggregator)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
this.dialogService = dialogService;
|
|
|
|
|
|
|
|
|
|
|
|
#region 属性初始化
|
|
|
|
#region 属性初始化
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 初始化loading gif
|
|
|
|
|
|
|
|
Loading = new GifImage(Properties.Resources.loading);
|
|
|
|
|
|
|
|
Loading.StartAnimate();
|
|
|
|
|
|
|
|
LoadingVisibility = Visibility.Collapsed;
|
|
|
|
|
|
|
|
NoDataVisibility = Visibility.Collapsed;
|
|
|
|
|
|
|
|
|
|
|
|
ArrowBack = NavigationIcon.Instance().ArrowBack;
|
|
|
|
ArrowBack = NavigationIcon.Instance().ArrowBack;
|
|
|
|
ArrowBack.Fill = DictionaryResource.GetColor("ColorTextDark");
|
|
|
|
ArrowBack.Fill = DictionaryResource.GetColor("ColorTextDark");
|
|
|
|
|
|
|
|
|
|
|
|
TabHeaders = new ObservableCollection<TabHeader>();
|
|
|
|
TabHeaders = new ObservableCollection<TabHeader>();
|
|
|
|
|
|
|
|
Medias = new ObservableCollection<PublicationMedia>();
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
#endregion
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -96,6 +146,9 @@ namespace DownKyi.ViewModels
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ArrowBack.Fill = DictionaryResource.GetColor("ColorText");
|
|
|
|
ArrowBack.Fill = DictionaryResource.GetColor("ColorText");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 结束任务
|
|
|
|
|
|
|
|
tokenSource.Cancel();
|
|
|
|
|
|
|
|
|
|
|
|
NavigationParam parameter = new NavigationParam
|
|
|
|
NavigationParam parameter = new NavigationParam
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ViewName = ParentView,
|
|
|
|
ViewName = ParentView,
|
|
|
@ -107,7 +160,7 @@ namespace DownKyi.ViewModels
|
|
|
|
|
|
|
|
|
|
|
|
// 左侧tab点击事件
|
|
|
|
// 左侧tab点击事件
|
|
|
|
private DelegateCommand<object> leftTabHeadersCommand;
|
|
|
|
private DelegateCommand<object> leftTabHeadersCommand;
|
|
|
|
public DelegateCommand<object> LeftTabHeadersCommand => leftTabHeadersCommand ?? (leftTabHeadersCommand = new DelegateCommand<object>(ExecuteLeftTabHeadersCommand));
|
|
|
|
public DelegateCommand<object> LeftTabHeadersCommand => leftTabHeadersCommand ?? (leftTabHeadersCommand = new DelegateCommand<object>(ExecuteLeftTabHeadersCommand, CanExecuteLeftTabHeadersCommand));
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// <summary>
|
|
|
|
/// 左侧tab点击事件
|
|
|
|
/// 左侧tab点击事件
|
|
|
@ -121,15 +174,251 @@ namespace DownKyi.ViewModels
|
|
|
|
Pager = new CustomPagerViewModel(1, (int)Math.Ceiling(double.Parse(tabHeader.SubTitle) / VideoNumberInPage));
|
|
|
|
Pager = new CustomPagerViewModel(1, (int)Math.Ceiling(double.Parse(tabHeader.SubTitle) / VideoNumberInPage));
|
|
|
|
Pager.CurrentChanged += OnCurrentChanged_Pager;
|
|
|
|
Pager.CurrentChanged += OnCurrentChanged_Pager;
|
|
|
|
Pager.CountChanged += OnCountChanged_Pager;
|
|
|
|
Pager.CountChanged += OnCountChanged_Pager;
|
|
|
|
|
|
|
|
Pager.Current = 1;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
|
|
/// 左侧tab点击事件是否允许执行
|
|
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
|
|
/// <param name="parameter"></param>
|
|
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
|
|
private bool CanExecuteLeftTabHeadersCommand(object parameter)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return IsEnabled;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 全选按钮点击事件
|
|
|
|
|
|
|
|
private DelegateCommand<object> selectAllCommand;
|
|
|
|
|
|
|
|
public DelegateCommand<object> SelectAllCommand => selectAllCommand ?? (selectAllCommand = new DelegateCommand<object>(ExecuteSelectAllCommand));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
|
|
/// 全选按钮点击事件
|
|
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
|
|
/// <param name="parameter"></param>
|
|
|
|
|
|
|
|
private void ExecuteSelectAllCommand(object parameter)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (IsSelectAll)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
foreach (var item in Medias)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
item.IsSelected = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
foreach (var item in Medias)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
item.IsSelected = false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 列表选择事件
|
|
|
|
|
|
|
|
private DelegateCommand<object> mediasCommand;
|
|
|
|
|
|
|
|
public DelegateCommand<object> MediasCommand => mediasCommand ?? (mediasCommand = new DelegateCommand<object>(ExecuteMediasCommand));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
|
|
/// 列表选择事件
|
|
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
|
|
/// <param name="parameter"></param>
|
|
|
|
|
|
|
|
private void ExecuteMediasCommand(object parameter)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!(parameter is IList selectedMedia)) { return; }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (selectedMedia.Count == Medias.Count)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
IsSelectAll = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
IsSelectAll = false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 添加选中项到下载列表事件
|
|
|
|
|
|
|
|
private DelegateCommand addToDownloadCommand;
|
|
|
|
|
|
|
|
public DelegateCommand AddToDownloadCommand => addToDownloadCommand ?? (addToDownloadCommand = new DelegateCommand(ExecuteAddToDownloadCommand));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
|
|
/// 添加选中项到下载列表事件
|
|
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
|
|
private void ExecuteAddToDownloadCommand()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
AddToDownload(true);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 添加所有视频到下载列表事件
|
|
|
|
|
|
|
|
private DelegateCommand addAllToDownloadCommand;
|
|
|
|
|
|
|
|
public DelegateCommand AddAllToDownloadCommand => addAllToDownloadCommand ?? (addAllToDownloadCommand = new DelegateCommand(ExecuteAddAllToDownloadCommand));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
|
|
/// 添加所有视频到下载列表事件
|
|
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
|
|
private void ExecuteAddAllToDownloadCommand()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
AddToDownload(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private async void AddToDownload(bool isOnlySelected)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// 收藏夹里只有视频
|
|
|
|
|
|
|
|
AddToDownloadService addToDownloadService = new AddToDownloadService(PlayStreamType.VIDEO);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 选择文件夹
|
|
|
|
|
|
|
|
string directory = addToDownloadService.SetDirectory(dialogService);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 视频计数
|
|
|
|
|
|
|
|
int i = 0;
|
|
|
|
|
|
|
|
await Task.Run(() =>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// 添加到下载
|
|
|
|
|
|
|
|
foreach (var media in Medias)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// 只下载选中项,跳过未选中项
|
|
|
|
|
|
|
|
if (isOnlySelected && !media.IsSelected) { continue; }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// 有分P的就下载全部
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 开启服务
|
|
|
|
|
|
|
|
VideoInfoService videoInfoService = new VideoInfoService(media.Bvid);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
addToDownloadService.SetVideoInfoService(videoInfoService);
|
|
|
|
|
|
|
|
addToDownloadService.GetVideo();
|
|
|
|
|
|
|
|
addToDownloadService.ParseVideo(videoInfoService);
|
|
|
|
|
|
|
|
// 下载
|
|
|
|
|
|
|
|
i += addToDownloadService.AddToDownload(eventAggregator, directory);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (directory == null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 通知用户添加到下载列表的结果
|
|
|
|
|
|
|
|
if (i == 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
eventAggregator.GetEvent<MessageEvent>().Publish(DictionaryResource.GetString("TipAddDownloadingZero"));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
eventAggregator.GetEvent<MessageEvent>().Publish($"{DictionaryResource.GetString("TipAddDownloadingFinished1")}{i}{DictionaryResource.GetString("TipAddDownloadingFinished2")}");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void OnCountChanged_Pager(int count) { }
|
|
|
|
private void OnCountChanged_Pager(int count) { }
|
|
|
|
|
|
|
|
|
|
|
|
private void OnCurrentChanged_Pager(int current)
|
|
|
|
private bool OnCurrentChanged_Pager(int old, int current)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Console.WriteLine(current);
|
|
|
|
if (!IsEnabled)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//Pager.Current = old;
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Medias.Clear();
|
|
|
|
|
|
|
|
LoadingVisibility = Visibility.Visible;
|
|
|
|
|
|
|
|
NoDataVisibility = Visibility.Collapsed;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
UpdatePublication(current);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private async void UpdatePublication(int current)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// 是否正在获取数据
|
|
|
|
|
|
|
|
// 在所有的退出分支中都需要设为true
|
|
|
|
|
|
|
|
IsEnabled = false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var tab = TabHeaders[SelectTabId];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
await Task.Run(() =>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
CancellationToken cancellationToken = tokenSource.Token;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var publications = Core.BiliApi.Users.UserSpace.GetPublication(mid, current, VideoNumberInPage, tab.Id);
|
|
|
|
|
|
|
|
if (publications == null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// 没有数据,UI提示
|
|
|
|
|
|
|
|
LoadingVisibility = Visibility.Collapsed;
|
|
|
|
|
|
|
|
NoDataVisibility = Visibility.Visible;
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var videos = publications.Vlist;
|
|
|
|
|
|
|
|
if (videos == null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// 没有数据,UI提示
|
|
|
|
|
|
|
|
LoadingVisibility = Visibility.Collapsed;
|
|
|
|
|
|
|
|
NoDataVisibility = Visibility.Visible;
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach (var video in videos)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// 查询、保存封面
|
|
|
|
|
|
|
|
string coverUrl = video.Pic;
|
|
|
|
|
|
|
|
BitmapImage cover;
|
|
|
|
|
|
|
|
if (coverUrl == null || coverUrl == "")
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
cover = new BitmapImage(new Uri($"pack://application:,,,/Resources/video-placeholder.png"));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!coverUrl.ToLower().StartsWith("http"))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
coverUrl = $"https:{video.Pic}";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
StorageCover storageCover = new StorageCover();
|
|
|
|
|
|
|
|
cover = storageCover.GetCoverThumbnail(video.Aid, video.Bvid, -1, coverUrl, 200, 125);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 播放数
|
|
|
|
|
|
|
|
string play = string.Empty;
|
|
|
|
|
|
|
|
if (video.Play > 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
play = Format.FormatNumber(video.Play);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
play = "--";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DateTime startTime = TimeZone.CurrentTimeZone.ToLocalTime(new DateTime(1970, 1, 1)); // 当地时区
|
|
|
|
|
|
|
|
DateTime dateCTime = startTime.AddSeconds(video.Created);
|
|
|
|
|
|
|
|
string ctime = dateCTime.ToString("yyyy-MM-dd");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
App.PropertyChangeAsync(new Action(() =>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
PublicationMedia media = new PublicationMedia
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Avid = video.Aid,
|
|
|
|
|
|
|
|
Bvid = video.Bvid,
|
|
|
|
|
|
|
|
Cover = cover,
|
|
|
|
|
|
|
|
Duration = video.Length,
|
|
|
|
|
|
|
|
Title = video.Title,
|
|
|
|
|
|
|
|
PlayNumber = play,
|
|
|
|
|
|
|
|
CreateTime = ctime
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
medias.Add(media);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
LoadingVisibility = Visibility.Collapsed;
|
|
|
|
|
|
|
|
NoDataVisibility = Visibility.Collapsed;
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 判断是否该结束线程,若为true,跳出循环
|
|
|
|
|
|
|
|
if (cancellationToken.IsCancellationRequested)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}, (tokenSource = new CancellationTokenSource()).Token);
|
|
|
|
|
|
|
|
IsEnabled = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// <summary>
|
|
|
@ -182,6 +471,7 @@ namespace DownKyi.ViewModels
|
|
|
|
Pager = new CustomPagerViewModel(1, (int)Math.Ceiling(double.Parse(selectTab.SubTitle) / VideoNumberInPage));
|
|
|
|
Pager = new CustomPagerViewModel(1, (int)Math.Ceiling(double.Parse(selectTab.SubTitle) / VideoNumberInPage));
|
|
|
|
Pager.CurrentChanged += OnCurrentChanged_Pager;
|
|
|
|
Pager.CurrentChanged += OnCurrentChanged_Pager;
|
|
|
|
Pager.CountChanged += OnCountChanged_Pager;
|
|
|
|
Pager.CountChanged += OnCountChanged_Pager;
|
|
|
|
|
|
|
|
Pager.Current = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|