博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
自定义控件为了虚拟化表结构
阅读量:6413 次
发布时间:2019-06-23

本文共 6628 字,大约阅读时间需要 22 分钟。

I’ve just Copied the Article of paul van bladel for sharing, original link:

 

Introduction

LightSwitch has a powerful and robust set of standard controls which are doing a great job. Apart from that there is always the possibility the create your own custom controls.

That’s what we will do in this post.

I want to demonstrate a way to visualize data of rooms and their corresponding reservations on a kind of “plan board”. This differs radically from a normal datagrid because the visualization that we have in mind has kind of undefined amount of “columns.

The Data model

We have a pretty simple Parent-child relationship between rooms and reservations.

For completeness, here the Reservation entity design:

As you can see a reservation has a slot property, which is the reservation date. A room can only reserved for at least a full day. Apart from the link to the room in question, a reservation has as well a state property. In my simple example this can be A, B or C, but you can use your imagination to think about something more realistic.

The classic list-detail representation

How do we want to visualize the room reservations?

I will not focus here on a graphical masterpiece, I limit things to a spartan representation in such a way all attention can go to the necessary plumbing.

You can click on a current reservation and a modal form will pop up:

The necessary ingredients

The Xaml

You’ll notice that my control is basically a datagrid with 2 columns where the first column (a DataGridTextColumn)  is bound to the room visual collection and the second column ( a DataGridTemplateColumn) is in fact a stackpanel which “horizontalises” the reservations for the current room.

One difficulty is here that a room does not necessary have reservations for the complete time frame for which the overview is requested. Also finding out the right way to do the binding was, at least for me, a challenge.

The Xaml Code behind

public partial class ReservationSilverlightControl : UserControl    {        public ReservationSilverlightControl()        {            InitializeComponent();            PeriodParameters.DateList = new ObservableCollection
(); } private void TextBlock_MouseLeftButtonDown(object sender, MouseButtonEventArgs e) { TextBlock textBlock = sender as TextBlock; var context = (IContentItem)this.DataContext; var screen = (IScreenObject)context.Screen; if (textBlock.Tag != null) { int myReservation = int.Parse(textBlock.Tag.ToString()); screen.Details.Dispatcher.BeginInvoke(() => { screen.Details.Properties["CurrentReservationId"].Value = myReservation; screen.Details.Methods["EditDetails"].CreateInvocation(null).Execute(); }); } else { //here we could call a create reservation screen. } } private void LayoutRoot_Loaded(object sender, RoutedEventArgs e) { if (((sender as Grid).DataContext as SimpleCustomControl).StartDate.HasValue) { PeriodParameters.StartDate = ((sender as Grid).DataContext as SimpleCustomControl).StartDate.Value.Date; } else { PeriodParameters.StartDate = DateTime.Now.Date; } if (((sender as Grid).DataContext as SimpleCustomControl).EndDate.HasValue) { PeriodParameters.EndDate = ((sender as Grid).DataContext as SimpleCustomControl).EndDate.Value.Date; } else { PeriodParameters.EndDate = DateTime.Now.AddDays(31).Date; } TimeSpan span = PeriodParameters.EndDate - PeriodParameters.StartDate; for (int i = 0; i <= span.Days; i++) { PeriodParameters.DateList.Add(PeriodParameters.StartDate.AddDays(i).Day.ToString()); } } }

The row ValueConverter
public class PeriodParameters    {        public PeriodParameters() { }        public static ObservableCollection
DateList { get; set; } public static DateTime StartDate { get; set; } public static DateTime EndDate { get; set; } } public class ReservationValueConverter : IValueConverter { public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) { ObservableCollection
reservationObservableCollection = new ObservableCollection
(); Room currentRoom = value as Room; var query = currentRoom.ReservationsQuery as IExecutableWithResult; query.ExecuteCompleted += new EventHandler
((s, e) => { IEnumerable
reservationList = query.Result as IEnumerable
; DateTime startDate = PeriodParameters.StartDate.Date; DateTime endDate = PeriodParameters.EndDate.Date; TimeSpan span = endDate - startDate; for (int i = 0; i <= span.Days; i++) { Reservation reservation = reservationList.Where(r => r.Slot.Date == startDate.AddDays(i)).SingleOrDefault(); reservationObservableCollection.Add(reservation); } }); query.ExecuteAsync(); return reservationObservableCollection; } public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) { return value; } }

As you can see, the row IValueConverter will load for each room row the corresonding reservation data in an asynchronous way. So, if you have a lot of reservation data, the loading can take a few seconds, but it will never block the screen.

The LightSwitch screen.

The LightSwitch screen containing the reservation control is very light and contains only the code for showing the modal form for editing the current reservation:

public partial class SimpleCustomControl   {       partial void EditDetails_Execute()       {           this.OpenModalWindow("CurrentReservation");       }   }

Sample Project

You can find here  the sample project: . It contains also functionality to generate some working test data.

Enjoy !

Many thanks to for the help on the LightSwitch forum.

转载于:https://www.cnblogs.com/otomii/archive/2012/06/01/2530949.html

你可能感兴趣的文章
Delphi TColor和16进制颜色的相互转换
查看>>
mysql 的安装(二进制安装)
查看>>
上云利器,K8S应用编排设计器之快到极致
查看>>
袋鼠云服务案例系列 | 从DB2到MySQL,某传统金融平台的互联网转型之路
查看>>
RealServer配置脚本
查看>>
九月份技术指标 华为交换机的简单配置
查看>>
马哥linux作业--第八周
查看>>
dubbo01
查看>>
vm虚拟机如何安装Mac10.10
查看>>
如何快速调用接口短信?
查看>>
Python进阶之路 3.1 神奇的print函数
查看>>
python 写json格式字符串到文件
查看>>
QXORM 使用记录 ( 二 )
查看>>
分布式文件系统MogileFS
查看>>
电力线通信载波模块
查看>>
Jdk源码学习之:ArrayList
查看>>
linux vim详解
查看>>
Java23种设计模式案例:策略模式(strategy)
查看>>
XML解析之DOM4J
查看>>
图解微服务架构演进
查看>>