WPF摄像头拍照+选择是否保存

参考:http://www.cnblogs.com/zhangwang/archive/2013/01/03/2843327.html

第一步:添加WPFMediaKit.dll 文件到项目中

第二步:把WPFMediaKit.dll文件引用进来。

步骤  右击引用—>添加引用—>浏览选项卡—>选择WPFMediaKit.dll文件所在的位置.

第三步:在窗口顶端加入如下代码(注意不要该意记)就像using一个类样。

       xmlns:wpfmedia="clr-namespace:WPFMediaKit.DirectShow.Controls;assembly=WPFMediaKit"

如图:



第四步:添加VideoCaptureElement控件 用来显示一个预览的画面 (需要手写,因为工具箱没有这个控件)

如图:

接下来就是后台代码

    private void Window_Loaded(object sender, RoutedEventArgs e)
        {
            cbCameras.ItemsSource = MultimediaUtil.VideoInputNames;
            if (MultimediaUtil.VideoInputNames.Length > 0)
            {
                cbCameras.SelectedIndex = 0;//第0个摄像头为默认摄像头
            }
            else
            {
                MessageBox.Show("电脑没有安装任何可用摄像头");
            }
        }


        private void cbCameras_SelectionChanged(object sender, SelectionChangedEventArgs e)
        {
            captureElement.VideoCaptureSource = (string)cbCameras.SelectedItem;
        }

        /// <summary>
        /// 拍照
        /// </summary>

        private void btnCapture_Click(object sender, RoutedEventArgs e)
        {
            //captureElement. 怎么抓取高清的原始图像           
            RenderTargetBitmap bmp = new RenderTargetBitmap(
                (int)captureElement.ActualWidth,
                (int)captureElement.ActualHeight,
                96, 96, PixelFormats.Default);

            //为避免抓不全的情况,需要在Render之前调用Measure、Arrange
            //为避免VideoCaptureElement显示不全,需要把
            //VideoCaptureElement的Stretch="Fill"
            captureElement.Measure(captureElement.RenderSize);
            captureElement.Arrange(new Rect(captureElement.RenderSize));
            bmp.Render(captureElement);

            BitmapEncoder encoder = new JpegBitmapEncoder();
            encoder.Frames.Add(BitmapFrame.Create(bmp));
            encoder.Save(ms);
            captureElement.Pause();
        }

        /// <summary>
        /// 重拍
        /// </summary>

        private void btnanew_Click(object sender, RoutedEventArgs e)
        {
            captureElement.Play();
        }

        /// <summary>
        /// 确定
        /// </summary>

        private void btnOK_Click(object sender, RoutedEventArgs e)
        {
            CaptureData = ms.ToArray();
            ms.Dispose();
            DialogResult = true;
        }
转自的内容

下面是自己在此基础上的修改

//为避免抓不全的情况,需要在Render之前调用Measure、Arrange重新更新布局
                videoCapElement.Measure(videoCapElement.RenderSize);
                videoCapElement.Arrange(new Rect(videoCapElement.RenderSize));

因上段Measure.Arrange的布局设置后,VideoCaptureElement的布局重置会到左上角所以在VideoCaptureElement的外面加了StackPanel

<StackPanel Grid.Row="0" Orientation="Horizontal" HorizontalAlignment="Center" Margin="188,42,188,131">
        <Controls:VideoCaptureElement Name="videoCapElement" Height="480" Width="640" Stretch="Fill" HorizontalAlignment="Center" Margin="0,0,0,0">
        <!--预览照片-->
        </Controls:VideoCaptureElement>
</StackPanel>

VideoCaptureElement.Play();//拍摄

VideoCaptureElement.Pause();//暂停

posted @ 2013-10-10 09:20  Jimmy_5  阅读(575)  评论(0编辑  收藏  举报