首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法向具有不同颜色的数据网格添加多行WPF c#

无法向具有不同颜色的数据网格添加多行WPF c#
EN

Stack Overflow用户
提问于 2012-05-29 05:42:04
回答 2查看 293关注 0票数 0

我有一个绑定到JobItems的ObservableCollection的DataGrid。JobItems有一个DueDate属性,根据currentDate与DueDate的接近程度,行的颜色也会相应地改变。当用户通过UI将项添加到ObservableCollection时,它可以很好地工作,但当我在后面的代码中创建多个虚拟JobItem以在程序开始时填充此数据网格时,它就不起作用了。但是,我添加的第一个虚拟对象没有任何问题。这一点很重要,因为当我的数据库就位时,我最终将需要它。

下面是我的代码后面的样子:

代码语言:javascript
复制
ObservableCollection <JobItem> JobItemList = new ObservableCollection<JobItem>();
public AdminView(Employee currEmployee)
    {
        this.Title = "Administrator View - " + currEmployee.Name;
        InitializeComponent();
        jobItemDataGrid.DataContext = JobItemList;

        LoadDummies();


    }

    private void LoadDummies()
    {
        JobItem j1 = new JobItem();
        JobItem j2 = new JobItem();
        JobItem j3 = new JobItem();

        j1.WorkOrderNo = "W12-021";
        j2.WorkOrderNo = "W12-037";
        j3.WorkOrderNo = "W12-234";


        j1.DateReceived = DateTime.Now.ToString();
        j2.DateReceived = DateTime.Now.ToString();
        j3.DateReceived = DateTime.Now.ToString();

        j1.DueDate = (DateTime.Now.AddDays(2)).ToString();
        j2.DueDate = (DateTime.Now.AddDays(2)).ToString();
        j3.DueDate = (DateTime.Now.AddDays(9)).ToString();

        j1.RushPriority = true;

        j1.Status = "Completed";
        j2.Status = "Accepted";  
        j3.Status = "Completed";

        JobItemList.Add(j1);
        JobItemList.Add(j2);
        JobItemList.Add(j3);
    }

    private void newJobBtn_Click(object sender, RoutedEventArgs e)
    {
        NewJobDialog newJobWindow = new NewJobDialog(workOrderCounter);

        newJobWindow.ShowDialog();

        if (newJobWindow.DialogResult == true)
        {
            if (newJobWindow.HasContent && newJobWindow.DialogResult.Value)
            {
                JobItemList.Add(newJobWindow.newJob);
                workOrderCounter++;

            }

        }

    }

    /*Formats each row in the data grid depending on how close the due date of each
     * job is.  Each color corresponds to how close the due date is from today.
     * Blue: Job is due in more than 7 days
     * Green: Job is due between 4-7 days
     * Yellow: Job is due in 0-3 days
     * Red:
     * */
    private void jobItemDataGrid_LoadingRow(object sender, DataGridRowEventArgs e)
    {
        DateTime currentDate = DateTime.Now;
        DateTime dateValue = new DateTime();
        TimeSpan elapsed;
        Double daysLeft;
        Double enoughTime = 7;
        Double dueSoon = 3;
        Double dueToday = 0;


        foreach (JobItem item in jobItemDataGrid.ItemsSource)
        {

            var row = jobItemDataGrid.ItemContainerGenerator.ContainerFromItem(item) as DataGridRow;
            //subtracting the two dates to get an elapsed amount of days
            if ((DateTime.TryParse(item.DueDate.ToString(),out dateValue) == true))
            {

                //dateValue = DateTime.Parse(item.DueDate.ToString());
                elapsed = dateValue.Subtract(currentDate);
                daysLeft = elapsed.TotalDays;
                //MessageBox.Show("due date: " + dateValue.ToString() + " current date: " + currentDate.ToString() + " days left: " + daysLeft.ToString() + "rounded: "  + daysLeftRound.ToString());

                if (item.RushPriority == true)
                {
                    row.Background = new SolidColorBrush(Colors.Black);
                    row.Foreground = new SolidColorBrush(Colors.White);
                }
                else if (daysLeft > enoughTime)
                {
                    row.Background = new SolidColorBrush(Colors.Blue);
                    row.Foreground = new SolidColorBrush(Colors.White);
                }
                else if (daysLeft <= enoughTime && daysLeft > dueSoon)
                {
                    row.Background = new SolidColorBrush(Colors.Green);
                    row.Foreground = new SolidColorBrush(Colors.White);
                }
                else if (daysLeft <= dueSoon && daysLeft >= dueToday)
                {
                    row.Background = new SolidColorBrush(Colors.Yellow);
                }
                else if (daysLeft < dueToday)
                {
                    row.Background = new SolidColorBrush(Colors.Red);
                    row.Foreground = new SolidColorBrush(Colors.White);
                }

            }

        } 
    }

I当我从LoadDummies()添加多个虚项时,我得到错误:"NullReferenceException未处理。对象引用未设置为Object的实例。“

感谢所有的帮助!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-06-04 22:09:47

在下面的if语句中,在行中添加null检查

代码语言:javascript
复制
if ((DateTime.TryParse(item.DueDate.ToString(), out dateValue) == true) && row != null) 
票数 0
EN

Stack Overflow用户

发布于 2012-05-29 06:14:28

我想你忘记创建你的JobItemList了。尝试将以下代码放入您的构造函数:

代码语言:javascript
复制
JobItemList = new List<JobItem>();
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10790700

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档