我如何计算百分比并将其报告给后台工作人员?

时间:2016-02-05 17:10:04

标签: c# .net winforms

现在,我正在报告我正在搜索的每个文件名,并且它正常运行。 但是现在我还想报告我在设计师中所取得的进步百分比进度。计算还应包括程序是否进入while循环。我添加了一个counterFiles变量,但不知道该怎么做。

我有这个方法:

public List<string> FindLines(string DirName, string TextToSearch)
{
    int countFiles = 0;
    int counter = 0;
    List<string> findLines = new List<string>();
    DirectoryInfo di = new DirectoryInfo(DirName);

   if (di != null && di.Exists)
   {
        if (CheckFileForAccess(DirName) == true)
        {
            foreach (FileInfo fi in di.EnumerateFiles("*", SearchOption.AllDirectories))
            {
                if (string.Compare(fi.Extension, ".cs", true) == 0)
                {
                    countFiles++;
                   //countFiles / 
                    backgroundWorker1.ReportProgress(0, fi.Name);
                    System.Threading.Thread.Sleep(200);
                    using (StreamReader sr = fi.OpenText())
                    {
                        string s = "";
                        while ((s = sr.ReadLine()) != null)
                        {
                            if (s.Contains(TextToSearch))
                            {
                                counter++;
                                findLines.Add(s);
                            }
                        }
                    }
                }
            }
        }
    }
    return findLines;
}

在backgroundworker dowork和progresschanged事件中

private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
        FindLines(@"d:\c-sharp", "string s1 = treeView1.SelectedNode.Tag as string;");
}

private void backgroundWorker1_ProgressChanged(object sender, ProgressChangedEventArgs e)
{
    label2.Text = e.UserState.ToString();
}

1 个答案:

答案 0 :(得分:0)

您需要在Jquery中使用AJAX来执行此操作。

在你的cs文件中:

宣告:

    public static int DownloadPercent { get; set; }

然后使用Upload方法,进度更改方法和完整方法:

private void StartDownload(string DownloadSource, string SaveLocation)
    {
        try
        {
            Thread thread = new Thread(() =>
            {
                WebClient client = new WebClient();
                client.DownloadProgressChanged += new DownloadProgressChangedEventHandler(client_DownloadProgressChanged);
                client.DownloadFileCompleted += new AsyncCompletedEventHandler(client_DownloadFileCompleted);
                client.DownloadFileAsync(new Uri(DownloadSource), SaveLocation);
            });
            thread.Name = "aFieldDownload";
            thread.Start();
        }
        catch (Exception err)
        {
            DownloadPercent = 999;
        }
    }
    void client_DownloadProgressChanged(object sender, DownloadProgressChangedEventArgs e)
    {
        byteHasBeenDownloaded = true;
        try
        {
            double bytesIn = double.Parse(e.BytesReceived.ToString());
            double totalBytes = double.Parse(e.TotalBytesToReceive.ToString());
            double percentage = bytesIn / totalBytes * 100;
            DownloadPercent = int.Parse(Math.Truncate(percentage).ToString());
        }
        catch (Exception err)
        {
            DownloadPercent = 999;
        }
    }
    void client_DownloadFileCompleted(object sender, AsyncCompletedEventArgs e)
    {
        if (byteHasBeenDownloaded)
        {
            DownloadFinishTime = DateTime.Now;
            UpdateActionDuration(false);
        }
    }

然后添加此方法,您将使用AJAX调用以更新百分比:

    [WebMethod]
    public static int GetDownloadPercentage()
    {
        return DownloadPercent;
    }

对于JavaScript,在文档加载时使用它:

$(document).ready(function () {
    setTimeout(updateDownProgress, 100);
});

使用此JavaScript函数作为更新程序:

function updateDownProgress() {
$.ajax({
    type: "POST",
    url: "Home.aspx/GetDownloadPercentage",
    data: "{}",
    contentType: "application/json; charset=utf-8",
    dataType: "json",
    async: true,
    success: function (msg) {
        $("#cp_MAIN_CONTENT_DownPercentage").text(msg.d + "% DOWNLOADED");
        $("#cp_MAIN_CONTENT_progressBarDown").val(msg.d);
        if (msg.d < 100) {
            setTimeout(updateDownProgress, 100);
            if (msg.d > 0) { $(".StartDownloadButton").prop("disabled", true); }
            else { $(".StartDownloadButton").prop("disabled", false); }
        }
        else if (msg.d > 100) {
            //Use for Error codes
        }
    }
});
}

最后......将此HTML用于进度条:

<asp:Panel ID="pDownLoading" CssClass="loading" runat="server">
            <progress id="progressBarDown" runat="server" value="0" max="100"></progress> <asp:Label ID="DownPercentage" runat="server"></asp:Label>
        </asp:Panel>