我在之前的文章《Silverlight4Beta之鼠标右键支持》中提到sl4终于支持鼠标右键了。虽然未提供上下文菜单控件,但是想来实现也并不难。而上下文菜单最普遍的操作便是复制/粘贴/剪切此类的功能,今儿我们就来说说Silverlight4Beta的另外一个简单的新特性:与剪切板通信(在之前的sl版本中,因为没有内置对剪切板通信的支持,我们只能通过调用js的手段实现sl与剪切板的通信)
没错,sl4确实是支持剪切板了,不过功能倒是少的可怜。
剪切板的所有功能位于System.Windows.Clipboard这个类之下,让我们看一下它的成员定义:
public static bool ContainsText(); 剪切板中是否包含文本 public static string GetText(); 得到剪切板中的文本内容
public static void SetText(string text); 设置剪切板的文本内容
仅此三个方法而已。成员当真少的可怜,功能也着实简单的过分。正如上面我加的注释一样,sl4只支持处理剪切板中的文本信息,什么图片啦、其他多媒体信息啦就一概别想了。
接下来我们做一个简单的例子,代码均简单的很,就不详细解释了。
XAML如下
<Grid x:Name="LayoutRoot" Background="White"> <StackPanel Orientation="Horizontal" Height="40"> <TextBox AcceptsReturn="True" x:Name="txtText" Width="150" /> <Button Content="复制" Click="Copy" /> <Button Content="粘贴" Click="Paste" /> </StackPanel> </Grid>
C#代码如下
public partial class MainPage : UserControl { public MainPage() { InitializeComponent(); } private void Paste(object sender, RoutedEventArgs e) { if (Clipboard.ContainsText()) txtText.Text = Clipboard.GetText(); } private void Copy(object sender, RoutedEventArgs e) { if (!string.IsNullOrEmpty(txtText.Text.Trim())) Clipboard.SetText(txtText.Text); } }
运行效果如下:
另外出去安全问题,当sl第一次与剪切板通信时需要用户同意
关于安全的详细解释可以参见我的这篇博文:《Silverlight4Beta之操作摄像头/麦克风》中的相关内容。
OK,have fun~