稳扎稳打Silverlight(66) - 5.0其它之自定义 XAML 扩展标记, 通过 XNA 处理声音效果, 支持矢量打印, 统计连击的次数

[索引页]
[源码下载]


稳扎稳打Silverlight(66) - 5.0其它之自定义 XAML 扩展标记, 通过 XNA 处理声音效果, 支持矢量打印, 连击的次数



作者:webabcd


介绍
Silverlight 5.0

  • IMarkupExtension - 自定义 XAML 扩展标记
  • 通过 XNA 处理声音效果
  • 支持矢量打印
  • 统计连击的次数



在线DEMO
http://www.cnblogs.com/webabcd/archive/2012/03/05/2379862.html


示例
1、IMarkupExtension(自定义 XAML 扩展标记)
XAML/ConcatMarkupExtension.cs

using System;
using System.Net;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Ink;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;

using System.Xaml;

namespace Silverlight50.XAML
{
/// <summary>
/// 实现自定义 XAML 扩展标记,需要实现 IMarkupExtension<out T> 接口
/// 自定义 XAML 扩展标记以“Extension”结尾,XAML 书写时可以不必带“Extension”
///
/// 本例中的 ConcatMarkup 扩展标记,用于合并两个字符串
/// </summary>
public class ConcatMarkupExtension : IMarkupExtension<string>
{
public object String1 { get; set; }
public object String2 { get; set; }

/// <summary>
/// 需要实现的方法,返回 ConcatMarkup 的计算结果
/// </summary>
public string ProvideValue(IServiceProvider serviceProvider)
{
return String1.ToString() + String2.ToString();
}
}
}

XAML/IMarkupExtension.xaml

<navigation:Page x:Class="Silverlight50.XAML.IMarkupExtension" 
xmlns
="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d
="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc
="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable
="d"
xmlns:navigation
="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
d:DesignWidth
="640" d:DesignHeight="480"
Title
="IMarkupExtension Page"

xmlns:local
="clr-namespace:Silverlight50.XAML">

<Grid x:Name="LayoutRoot">

<!--
演示自定义的 XAML 扩展标记 ConcatMarkup,本例的结果是 wanglei
-->
<TextBlock Text="{local:ConcatMarkup String1=wang, String2=lei}" />

</Grid>
</navigation:Page>


2、SoundEffectDemo(通过 XNA 处理声音效果)
Media/SoundEffectDemo.xaml

<navigation:Page x:Class="Silverlight50.Media.SoundEffectDemo" 
xmlns
="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d
="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc
="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable
="d"
xmlns:navigation
="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
d:DesignWidth
="640" d:DesignHeight="480"
Title
="SoundEffectDemo Page">
<StackPanel HorizontalAlignment="Left">

<StackPanel Orientation="Horizontal">
<TextBlock Name="lblVolume" Width="100" Text="音量" TextAlignment="Center" />
<TextBlock Name="lblPitch" Width="100" Text="高音" TextAlignment="Center" />
<TextBlock Name="lblPan" Width="100" Text="平衡" TextAlignment="Center" />
</StackPanel>

<StackPanel Orientation="Horizontal">
<Slider Name="sliderVolume" Width="100" Height="200" Orientation="Vertical" Minimum="0" Maximum="1" Value="0.5" />
<Slider Name="sliderPitch" Width="100" Height="200" Orientation="Vertical" Maximum="1" Minimum="-1" Value="0" />
<Slider Name="sliderPan" Width="100" Height="200" Orientation="Vertical" Maximum="1" Minimum="-1" Value="0" />
</StackPanel>

<StackPanel Orientation="Horizontal">
<TextBlock Name="txtVolume" Width="100" TextAlignment="Center" />
<TextBlock Name="txtPitch" Width="100" TextAlignment="Center" />
<TextBlock Name="txtPan" Width="100" TextAlignment="Center" />
</StackPanel>

</StackPanel>
</navigation:Page>

Media/SoundEffectDemo.xaml.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;
using System.Windows.Navigation;

using Microsoft.Xna.Framework.Audio;
using System.Windows.Resources;

namespace Silverlight50.Media
{
/// <summary>
/// Silverlight 5 支持通过 SoundEffect 处理 wav 音效文件
/// 本例演示:如何控制音量,高低音,左右声道平衡
/// </summary>
public partial class SoundEffectDemo : Page
{
/*
* SoundEffect - 音效对象
* SoundEffect.Play(float volume, float pitch, float pan) - 播放音效
* volume - 音量值,0 到 1 之间
* pitch - 高音值, -1 到 1 之间,-1 是纯低音,1 是纯高音
* pan - 左右声道平衡值,-1 到 1 之间,-1 是仅左声道有声,1 是仅右声道有声
* SoundEffect.Duration - 音效的时长
* SoundEffect.Name - 音效对象的名称
*/

/*
* SoundEffectInstance - SoundEffect 的对象实例
* SoundEffect.CreateInstance() - 返回 SoundEffect 对象
* SoundEffectInstance.Volume - 音量值,0 到 1 之间
* SoundEffectInstance.Pitch - 高音值, -1 到 1 之间,-1 是纯低音,1 是纯高音
* SoundEffectInstance.Pan - 左右声道平衡值,-1 到 1 之间,-1 是仅左声道有声,1 是仅右声道有声
* SoundEffectInstance.IsLooped - 是否循环播放
* SoundEffectInstance.Play() - 播放
* SoundEffectInstance.Pause() - 暂停
* SoundEffectInstance.Resume() - 继续播放
* SoundEffectInstance.Stop() - 停止
* SoundEffectInstance.State - 返回音效对象的当前状态 [Microsoft.Xna.Framework.Audio.SoundState 枚举]
* SoundState.Playing - 正在播放状态
* SoundState.Paused - 暂停状态
* SoundState.Stopped - 停止状态
*/

/*
SoundEffectInstance soundEffectInstance = soundEffect.CreateInstance();
soundEffectInstance.Volume = 0.5f;
soundEffectInstance.Pitch = -1f;
soundEffectInstance.Pan = 0f;
soundEffectInstance.IsLooped = true;
soundEffectInstance.Play();
soundEffectInstance.Pause();
soundEffectInstance.Resume();
soundEffectInstance.Stop();
SoundState soundState = soundEffectInstance.State;
*/

private SoundEffect _soundEffect;
private SoundEffectInstance _instance;

public SoundEffectDemo()
{
InitializeComponent();

this.Loaded += new RoutedEventHandler(SoundEffectDemo_Loaded);
}

void SoundEffectDemo_Loaded(object sender, RoutedEventArgs e)
{
this.sliderVolume.ValueChanged += new RoutedPropertyChangedEventHandler<double>(sliderVolume_ValueChanged);
this.sliderPitch.ValueChanged += new RoutedPropertyChangedEventHandler<double>(sliderPitch_ValueChanged);
this.sliderPan.ValueChanged += new RoutedPropertyChangedEventHandler<double>(sliderPan_ValueChanged);

// 获取 wav 文件流
StreamResourceInfo musicStream = Application.GetResourceStream(new Uri("Media/rockyou.wav", UriKind.RelativeOrAbsolute));
_soundEffect = SoundEffect.FromStream(musicStream.Stream);

// 设置音效的初始属性
_instance = _soundEffect.CreateInstance();
_instance.IsLooped = true;
_instance.Pitch = 0f;
_instance.Pan = 0f;
_instance.Volume = .5f;
_instance.Play();
}

// 控制音量
private void sliderVolume_ValueChanged(object sender, RoutedPropertyChangedEventArgs<double> e)
{
_instance.Volume = (float)e.NewValue;
txtVolume.Text = e.NewValue.ToString("f2");
}

// 控制高低音
private void sliderPitch_ValueChanged(object sender, RoutedPropertyChangedEventArgs<double> e)
{
_instance.Pitch = (float)e.NewValue; ;
txtPitch.Text = e.NewValue.ToString("f2");
}

// 控制左右声道平衡
private void sliderPan_ValueChanged(object sender, RoutedPropertyChangedEventArgs<double> e)
{
_instance.Pan = (float)e.NewValue; ;
txtPan.Text = e.NewValue.ToString("f2");
}
}
}


3、VectorPrinting(支持矢量打印)

<navigation:Page x:Class="Silverlight50.Other.VectorPrinting" 
xmlns
="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d
="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc
="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable
="d"
xmlns:navigation
="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
d:DesignWidth
="640" d:DesignHeight="480"
Title
="VectorPrinting Page">
<Grid x:Name="LayoutRoot">

<TextBlock Text="支持矢量打印了" />

</Grid>
</navigation:Page>


4、ClickCount(统计连击的次数)
Other/ClickCount.xaml

<navigation:Page x:Class="Silverlight50.Other.ClickCount" 
xmlns
="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d
="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc
="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable
="d"
xmlns:navigation
="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
d:DesignWidth
="640" d:DesignHeight="480"
Title
="ClickCount Page">
<StackPanel x:Name="LayoutRoot">

<Rectangle Name="rectangle" Width="100" Height="30" Fill="Gray" MouseLeftButtonDown="rectangle_MouseLeftButtonDown" />
<TextBlock Name="txt" />

</StackPanel>
</navigation:Page>

Other/ClickCount.xaml.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;
using System.Windows.Navigation;

namespace Silverlight50.Other
{
public partial class ClickCount : Page
{
public ClickCount()
{
InitializeComponent();
}

protected override void OnNavigatedTo(NavigationEventArgs e)
{

}

private void rectangle_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
{
/*
* MouseButtonEventArgs.ClickCount - 获取连击的次数
* 注:连击的最大间隔时间是由操作系统的"控制面板"-->"鼠标"-->"双击速度"设置的
*/

if (e.ClickCount == 1) // Single Click
txt.Text = "Left Mouse Click Counter:" + e.ClickCount.ToString();
else if (e.ClickCount == 2) // Double Click
txt.Text = "Left Mouse Click Counter:" + e.ClickCount.ToString();
else // More Click
txt.Text = "Left Mouse Click Counter:" + e.ClickCount.ToString();
}
}
}



OK
[源码下载]

posted @ 2012-03-19 08:47  webabcd  阅读(4587)  评论(4编辑  收藏  举报