सिल्वरलाइट - वीडियो और ऑडियो

इस अध्याय में, हम देखेंगे कि सिल्वरलाइट सुविधाएं वीडियो और ऑडियो कैसे चला रही हैं। MediaElementसिल्वरलाइट में सभी वीडियो और ऑडियो का दिल है। यह आपको अपने एप्लिकेशन में ऑडियो और वीडियो को एकीकृत करने की अनुमति देता है। MediaElement कक्षा उसी तरह काम करती है जैसे कि Imageकक्षा। आप बस इसे मीडिया पर इंगित करते हैं और यह ऑडियो और वीडियो प्रस्तुत करता है।

मुख्य अंतर यह है कि यह एक चलती छवि होगी, लेकिन यदि आप इसे उस फ़ाइल की ओर इंगित करते हैं जिसमें केवल ऑडियो और कोई वीडियो नहीं है जैसे कि एमपी 3, तो यह स्क्रीन पर कुछ भी दिखाए बिना इसे चलाएगा।

UI तत्व के रूप में MediaElement

MediaElementरूपरेखा तत्व से व्युत्पन्न है, जो सभी सिल्वरलाइट उपयोगकर्ता इंटरफ़ेस तत्वों का आधार वर्ग है। इसका मतलब यह सभी मानक गुण प्रदान करता है, इसलिए आप इसकी अस्पष्टता को संशोधित कर सकते हैं, आप क्लिप सेट कर सकते हैं, या इसे बदल सकते हैं और इसी तरह।

आइए हम एक सरल उदाहरण देखें MediaElement

Visual Studio के लिए Microsoft Blend खोलें और एक नया Silverlight अनुप्रयोग प्रोजेक्ट बनाएँ।

अब ब्लेंड डिज़ाइन की सतह में वीडियो और ऑडियो फ़ाइल को खींचें।

यह सतह पर एक MediaElement जोड़ देगा और आपके प्रोजेक्ट में वीडियो फ़ाइल की एक प्रति भी जोड़ देगा। आप इसे सॉल्यूशन एक्सप्लोरर में देख सकते हैं।

आप इसे चारों ओर ले जा सकते हैं, इसका आकार बदल सकते हैं, आप चीजों को घुमा सकते हैं जैसे घुमाव आदि।

अब, यह आपके लिए संबंधित XAML उत्पन्न करेगा MainPage.xaml नीचे दी गई फ़ाइल की तरह।

<UserControl x:Class = "MediaElementDemo.MainPage" 
   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" 
   d:DesignHeight = "300" d:DesignWidth = "400">
   
   <Grid x:Name = "LayoutRoot" Background = "White">
	
      <MediaElement x:Name = "Microsoft_Silverlight_DEMO_mp4"  
         Margin = "51,49,53,53"  
         Source = "/Microsoft Silverlight DEMO.mp4"  
         Stretch = "Fill" RenderTransformOrigin = "0.5,0.5">
			
         <MediaElement.RenderTransform> 
            <CompositeTransform Rotation = "-18.384"/>
         </MediaElement.RenderTransform> 
			
      </MediaElement>  
		
   </Grid> 
	
</UserControl>

जब उपरोक्त एप्लिकेशन को संकलित और निष्पादित किया जाता है, तो आप देखेंगे कि वीडियो आपके वेब पेज पर चल रहा है।

को नियंत्रित करना

MediaElementसिर्फ मीडिया प्रस्तुत करता है। यह किसी भी मानक खिलाड़ी नियंत्रण प्रदान नहीं करता है। यह स्वचालित रूप से खेलना शुरू कर देता है और अंत तक पहुंचने पर रुक जाता है, और ऐसा कुछ भी नहीं है जिसे उपयोगकर्ता रोक सकता है या अन्यथा नियंत्रित कर सकता है। इसलिए व्यवहार में अधिकांश अनुप्रयोग उपयोगकर्ता को उससे थोड़ा अधिक नियंत्रण प्रदान करना चाहते हैं।

आप सेटिंग करके स्वचालित प्लेबैक को अक्षम कर सकते हैं AutoPlay सेवा False। इसका मतलब है कि मीडिया प्लेयर तब तक कुछ नहीं खेलेगा जब तक आप उसे नहीं पूछते।

<MediaElement x:Name = "Microsoft_Silverlight_DEMO_mp4" 
   AutoPlay = "False" 
   Margin = "51,49,53,53"  
   Source = "/Microsoft Silverlight DEMO.mp4"  
   Stretch = "Fill" RenderTransformOrigin = "0.5,0.5">

इसलिए जब आप वीडियो चलाना चाहते हैं, तो आप बस कॉल कर सकते हैं MediaElement Play() method। यह स्टॉप और पॉज़ विधियाँ भी प्रदान करता है।

आइए हम फिर से उसी उदाहरण पर एक नज़र डालें और थोड़ा नियंत्रण संशोधित करने के लिए इसे थोड़ा संशोधित करें। संलग्न करेंMouseLeftButtonDown में हैंडलर MediaElement जैसा कि नीचे XAML कोड में दिखाया गया है।

<UserControl x:Class = "MediaElementDemo.MainPage" 
   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" 
   d:DesignHeight = "300" d:DesignWidth = "400">
   
   <Grid x:Name = "LayoutRoot" Background = "White"> 
	
      <MediaElement x:Name = "Microsoft_Silverlight_DEMO_mp4" 
         AutoPlay = "False" 
         MouseLeftButtonDown = "Microsoft_Silverlight_DEMO_mp4_MouseLeftButtonDown" 
         Margin = "51,49,53,53"  
         Source = "/Microsoft Silverlight DEMO.mp4"  
         Stretch = "Fill" RenderTransformOrigin = "0.5,0.5"> 
      </MediaElement>  
		
   </Grid> 
	
</UserControl>

यहाँ पर कार्यान्वयन है MouseLeftButtonDown ईवेंट हैंडलर जिसमें यह जांच करेगा कि यदि मीडिया तत्व की वर्तमान स्थिति चढ़ाना है, तो यह वीडियो को रोक देगा अन्यथा यह वीडियो खेलना शुरू कर देगा।

using System.Windows.Controls; 
using System.Windows.Input; 
using System.Windows.Media;

namespace MediaElementDemo { 

   public partial class MainPage : UserControl {
	
      public MainPage() { 
         InitializeComponent(); 
      }  
		
      private void Microsoft_Silverlight_DEMO_mp4_MouseLeftButtonDown
         (object sender, MouseButtonEventArgs e) {
		
         if (Microsoft_Silverlight_DEMO_mp4.CurrentState == MediaElementState.Playing) { 
            Microsoft_Silverlight_DEMO_mp4.Pause(); 
         } else { 
            Microsoft_Silverlight_DEMO_mp4.Play(); 
         } 
      } 
   } 
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आप रिक्त वेब पेज देखेंगे क्योंकि हमने सेट किया है AutoPlay के लिए संपत्ति False। जब आप वेब पेज पर क्लिक करेंगे, तो यह वीडियो शुरू कर देगा।

जब आप वेब पेज पर फिर से क्लिक करेंगे, तो यह वीडियो को रोक देगा।