// showpicDlg.cpp : 实现文件

//
#include "stdafx.h"
#include "showpic.h"
#include "showpicDlg.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
 
// 用于应用程序“关于”菜单项的 CAboutDlg 对话框
class CAboutDlg : public CDialog
{
public:
 CAboutDlg();
// 对话框数据
 enum { IDD = IDD_ABOUTBOX };
 protected:
 virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV 支持
// 实现
protected:
 DECLARE_MESSAGE_MAP()
};
CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
}
void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
 CDialog::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
END_MESSAGE_MAP()
 
// CshowpicDlg 对话框
 
 
CshowpicDlg::CshowpicDlg(CWnd* pParent /*=NULL*/)
 : CDialog(CshowpicDlg::IDD, pParent)
{
 m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}
void CshowpicDlg::DoDataExchange(CDataExchange* pDX)
{
 CDialog::DoDataExchange(pDX);
 DDX_Control(pDX, IDC_SCREEN, m_screen);
}
BEGIN_MESSAGE_MAP(CshowpicDlg, CDialog)
 ON_WM_SYSCOMMAND()
 ON_WM_PAINT()
 ON_WM_QUERYDRAGICON()
 //}}AFX_MSG_MAP
 ON_BN_CLICKED(IDC_BUTTON1, &CshowpicDlg::OnBnClickedButton1)
 ON_BN_CLICKED(IDC_BUTTON2, &CshowpicDlg::OnBnClickedButton2)
 ON_WM_TIMER()
END_MESSAGE_MAP()
 
// CshowpicDlg 消息处理程序
BOOL CshowpicDlg::OnInitDialog()
{
 CDialog::OnInitDialog();
 // 将“关于...”菜单项添加到系统菜单中。
 // IDM_ABOUTBOX 必须在系统命令范围内。
 ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
 ASSERT(IDM_ABOUTBOX < 0xF000);
 CMenu* pSysMenu = GetSystemMenu(FALSE);
 if (pSysMenu != NULL)
 {
  CString strAboutMenu;
  strAboutMenu.LoadString(IDS_ABOUTBOX);
  if (!strAboutMenu.IsEmpty())
  {
   pSysMenu->AppendMenu(MF_SEPARATOR);
   pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
  }
 }
 // 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
 //  执行此操作
 SetIcon(m_hIcon, TRUE);   // 设置大图标
 SetIcon(m_hIcon, FALSE);  // 设置小图标
 // TODO: 在此添加额外的初始化代码
 m_screen.SetWindowPos(&CWnd::wndBottom,0,0,960,720, SWP_NOMOVE | SWP_SHOWWINDOW);
 return TRUE;  // 除非将焦点设置到控件,否则返回 TRUE
}
void CshowpicDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
 if ((nID & 0xFFF0) == IDM_ABOUTBOX)
 {
  CAboutDlg dlgAbout;
  dlgAbout.DoModal();
 }
 else
 {
  CDialog::OnSysCommand(nID, lParam);
 }
}
// 如果向对话框添加最小化按钮,则需要下面的代码
//  来绘制该图标。对于使用文档/视图模型的 MFC 应用程序,
//  这将由框架自动完成。
void CshowpicDlg::OnPaint()
{
 if (IsIconic())
 {
  CPaintDC dc(this); // 用于绘制的设备上下文
  SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
  // 使图标在工作矩形中居中
  int cxIcon = GetSystemMetrics(SM_CXICON);
  int cyIcon = GetSystemMetrics(SM_CYICON);
  CRect rect;
  GetClientRect(&rect);
  int x = (rect.Width() - cxIcon + 1) / 2;
  int y = (rect.Height() - cyIcon + 1) / 2;
  // 绘制图标
  dc.DrawIcon(x, y, m_hIcon);
 }
 else
 {
  CDialog::OnPaint();
 }
}
//当用户拖动最小化窗口时系统调用此函数取得光标显示。
//
HCURSOR CshowpicDlg::OnQueryDragIcon()
{
 return static_cast<HCURSOR>(m_hIcon);
}
BYTE *buf[6];
CBitmap m_bitmap;
void CshowpicDlg::OnBnClickedButton1()
{
 // TODO: 在此添加控件通知处理程序代码
 for(int i=0;i<6;i++)
 {
  HBITMAP m_hBitmap;//位图句柄
  BITMAP bm;//存放位图信息的结构
  CString strFilename,str;
  CFileDialog openBox(TRUE,NULL,_T(""),OFN_HIDEREADONLY,_T("bmp(*.bmp)|*.bmp|ALLFiles(*.*)|*.*||"),NULL);
  openBox.m_ofn.lpstrTitle=_T("打开数据文件640*480_bmp");
  INT_PTR nResult = openBox.DoModal();
  // 如果文件打开则准备播放
  if (nResult == IDOK)
  {
   strFilename=openBox.GetPathName();
  }
  else
  {
   return;
  }
  strFilename.ReleaseBuffer();
  str =strFilename;
  m_hBitmap = (HBITMAP)::LoadImage(NULL,str,IMAGE_BITMAP,0,0,LR_LOADFROMFILE);   //装载位图
  if(m_bitmap.m_hObject)
   m_bitmap.DeleteObject();
  m_bitmap.Attach(m_hBitmap);//将句柄与CBitmap关联起来
  m_bitmap.GetBitmap(&bm);
  int  height = bm.bmHeight;//图像的宽高
  int  width = bm.bmWidth;
  int  widthBytes=bm.bmWidthBytes;//图像一行数据所占的字节数
  
  int size=height*widthBytes;
  buf[i]=new BYTE[size];
  m_bitmap.GetBitmapBits(size,buf[i]);//得到RGB数据
 }
}
#include <ddraw.h>
#pragma comment (lib,"ddraw.lib")
#pragma comment (lib,"dxguid.lib")
LPDIRECTDRAW         lpdd=NULL;
LPDIRECTDRAW7        lpdd7=NULL;
LPDIRECTDRAWSURFACE7 lpddsback;
LPDIRECTDRAWSURFACE7 lpddsprimary=NULL;
LPDIRECTDRAWSURFACE7 lpddsmypage[6];
LPDIRECTDRAWPALETTE  lpddpal=NULL;
DDSURFACEDESC2       ddsd;
LPDIRECTDRAWCLIPPER  lpDDClipper = NULL;
//
#define  _RGB32BIT(a,r,g,b)  ((b) + ((g) << 8) + ((r) << 16) + ((a) << 24))
//#define  SCREEN_WIDTH  640
//#define  SCREEN_HEIGHT 480
RECT rcRectSrc;
RECT rcRectDest;
int   index_y = 0, index_x = 0;
int height,width,widthBytes;
int R, G, B;
int SCREEN_WIDTH,SCREEN_HEIGHT;
HWND main_window_handle;
void CshowpicDlg::OnBnClickedButton2()
{
 // TODO: 在此添加控件通知处理程序代码
 height=width=widthBytes=0;
 main_window_handle = m_screen.GetSafeHwnd();
 if(DD_OK!=(DirectDrawCreate(NULL, &lpdd, NULL)))
 {
  return ;
 }
 //获取DIRECTDRAW7 接口
    if(DD_OK != (lpdd->QueryInterface(IID_IDirectDraw7,(LPVOID*)&lpdd7)))
 {
  return ;
 }
 // set the cooperative level for full-screen mode
 if(DD_OK != lpdd7->SetCooperativeLevel(main_window_handle, DDSCL_NORMAL))
 {
  return ;
 }
 
 // set the display mode to 640x480x256
#if 0 //设置分辨率
    if(DD_OK!=(lpdd7->SetDisplayMode(800,600,32,0,0)))
 {  
  AfxMessageBox("dsf");
  return ;
 }
#endif
 // clear ddsd and set size
 memset(&ddsd,0,sizeof(ddsd));
 ddsd.dwSize = sizeof(ddsd);
 
 // enable valid fields
 ddsd.dwFlags=DDSD_CAPS;
 ddsd.ddsCaps.dwCaps = DDSCAPS_PRIMARYSURFACE;
 // create the primary surface
 
 /* 
 ddsd.ddsCaps.dwCaps=DDSCAPS_BACKBUFFER;
 if (FAILED(lpddsprimary->GetAttachedSurface(&ddsd.ddsCaps,&lpddsback)))
 {
  return -1;
 }
 */
 
 if(DD_OK!=(lpdd7->CreateSurface(&ddsd, &lpddsprimary, NULL)))
 {
  return ;
 }
 
 // 创建裁剪器
 if (FAILED(lpdd7->CreateClipper(0, &lpDDClipper, NULL)))
  return ; 
 // 与窗口工作区关联
 if (FAILED(lpDDClipper->SetHWnd(0, main_window_handle)))
 {
  lpDDClipper->Release();
  return ;
 } 
 
 if (FAILED(lpddsprimary->SetClipper(lpDDClipper)))
 {
  lpDDClipper->Release();
  return ;
 }
 {
  SCREEN_WIDTH = 640 ;SCREEN_HEIGHT = 480;
 }
 //
 memset(&ddsd,0,sizeof(ddsd));
 ddsd.dwSize = sizeof(ddsd);
 
 ddsd.dwFlags = DDSD_CAPS | DDSD_WIDTH | DDSD_HEIGHT;
 ddsd.dwWidth = SCREEN_WIDTH;
 ddsd.dwHeight = SCREEN_HEIGHT;
 ddsd.ddsCaps.dwCaps = DDSCAPS_OFFSCREENPLAIN; 
 //
 
    SetTimer(1,1000,NULL);
 return; //执行成功
}
int index=0;
void CshowpicDlg::OnTimer(UINT_PTR nIDEvent)
{
 // TODO: 在此添加消息处理程序代码和/或调用默认值
 int tmp = 0;
    for(int i=0;i<6;i++)
 {
  if(DD_OK!=(lpdd7->CreateSurface(&ddsd, &lpddsmypage[i], NULL)))
  {
   return ;
  }
  POINT p;
  
  p.x = 0; p.y = 0;
  m_screen.ClientToScreen(&p);
  tmp = (i+index)%6;
 // m_screen.GetClientRect(&rcRectDest);
        if(i==5)
      {rcRectDest.left = 0;  rcRectDest.top=0;  rcRectDest.right = 640;  rcRectDest.bottom = 480;}
  else if(i==4)
   {rcRectDest.left = 640;  rcRectDest.top=0;  rcRectDest.right = 960;  rcRectDest.bottom = 240;}
  else if(i==3)
   {rcRectDest.left = 640;  rcRectDest.top=240;  rcRectDest.right = 960;  rcRectDest.bottom = 480;}
  else if(i==2)
   {rcRectDest.left = 640;  rcRectDest.top=480;  rcRectDest.right = 960;  rcRectDest.bottom = 720;}
  else if(i==1)
   {rcRectDest.left = 320;  rcRectDest.top=480;  rcRectDest.right = 640;  rcRectDest.bottom = 720;}
  else if(i==0)
   {rcRectDest.left = 0;  rcRectDest.top=480;  rcRectDest.right = 320;  rcRectDest.bottom = 720;}
  OffsetRect(&rcRectDest, p.x, p.y);
  
  SetRect(&rcRectSrc, 0, 0, SCREEN_WIDTH, SCREEN_HEIGHT);
  /////////////////////////////////////////////////////////////
 
  if(DD_OK != lpddsmypage[i]->Lock(NULL,&ddsd,DDLOCK_WAIT|DDLOCK_SURFACEMEMORYPTR,NULL))
  {
   return ;
  }
  
  DWORD *bmp_buffer = (DWORD *)ddsd.lpSurface;
  
  memcpy(bmp_buffer,buf[tmp],SCREEN_WIDTH*SCREEN_HEIGHT*4);
  if(DD_OK != lpddsmypage[i]->Unlock(NULL))
  {
   return ;
  }
  if(DD_OK != lpddsprimary->Blt( &rcRectDest, lpddsmypage[i], &rcRectSrc, DDBLT_WAIT, NULL))
  {
   return ;
  }
  if(lpddsmypage)
  {
   lpddsmypage[i]->Release();
   lpddsmypage[i]=NULL;
  }
 }
 index++;
 CDialog::OnTimer(nIDEvent);
}v

directdraw的多画面显示rgb的更多相关文章

  1. DirectDraw 直接显示RGB图象的最简单实现

      来自:   #include "DDraw.h" class CDDraw { public: void CleanUp(); void DrawDIB(BITMAPINFOH ...

  2. 如何使用DirectDraw直接显示RGB、YUV视频数据(播放yuv)

    #include "draw.h"void CTest100Dlg::OnButton1() { // TODO: Add your control notification ha ...

  3. 谈谈“色彩空间表示方法”——RGB、YUY2、YUYV、YVYU、UYVY、AYUV

    转自:http://bbs.chinavideo.org/viewthread.php?tid=4143 还可参考http://www.fourcc.org/yuv.php 小知识:RGB与YUV-- ...

  4. 最简单的视音频播放示例7:SDL2播放RGB/YUV

    本文记录SDL播放视频的技术.在这里使用的版本是SDL2.实际上SDL本身并不提供视音频播放的功能,它只是封装了视音频播放的底层API.在Windows平台下,SDL封装了Direct3D这类的API ...

  5. 最简单的视音频播放示例3:Direct3D播放YUV,RGB(通过Surface)

    上一篇文章记录了GDI播放视频的技术.打算接下来写两篇文章记录Direct3D(简称D3D)播放视频的技术.Direct3D应该Windows下最常用的播放视频的技术.实际上视频播放只是Direct3 ...

  6. DirectDraw

    一.DirectDraw接口 DirectDraw接口图如下: 1.IUnknown:所有COM对象都必须从这个基本接口派生 2.IDirectDraw:这是开始使用DirectDraw时必须创建的主 ...

  7. 《Windows游戏编程技巧大师》就DirectDraw而创建DirectDraw知识笔记

    1.DirectDraw 这可能是Directx中最重要的技术,由于它是2D图形赖以实现的渠道.也是Direct3D构建于其上的帧缓冲层. 2.DirectDraw是由非常多借口组成的.共同拥有5个接 ...

  8. 使用DirectDraw直接显示YUV视频数据

    最近在编写一个进行视频播放的ActiveX控件,工作已经接近尾声,现将其中显示YUV数据的使用DirectDraw的一些经验总结如下:(解码部分不是我编写的,我负责从网络接收数据,将数据传给解码器,并 ...

  9. 初次接触:DirectDraw

    第六章 初次接触:DirectDraw 本章,你将初次接触DirectX中最重要的组件:DirectDraw.DirectDraw可能是DirectX中最强大的技术,因为其贯穿着2D图形绘制同时其帧缓 ...

随机推荐

  1. 【Vijos】【1923】漫长的等待

    可持久化线段树 这次是询问一段区间内权值 在给定范围内的点的数量,同样是可持久化线段树简单操作…… //Vijos 1923 #include<vector> #include<cs ...

  2. iOS开发之深入探讨runtime机制02-runtime的简单使用

    runtime机制为我们提供了一系列的方法让我们可以在程序运行时动态修改类.对象中的所有属性.方法. 下面就介绍运行时一种很常见的使用方式,字典转模型.当然,你可能会说,“我用KVO直接 setVal ...

  3. hdu 4901

    一个简单的dp,比赛的时候太坚信自己的小聪明没用二维数组一直WA到死: #include<cstdio> #include<cstring> #define maxn 1009 ...

  4. Json.net/Newtonsoft 3.0 新特性JObject/Linq to Json

    原文:http://www.cnblogs.com/chsword/archive/2008/09/19/Newtonsoft_new_3_0.html http://www.cnblogs.com/ ...

  5. 一个很吊的swing循环生成窗口。

    import javax.swing.*; import java.awt.event.ActionListener; import java.awt.event.ActionEvent; publi ...

  6. 【设计模式六大原则1】单一职责原则(Single Responsibility Principle)

        http://blog.csdn.net/zhengzhb/article/category/926691/1 图片素材来源,java学习手册 ps.内容为自己整理   定义:不要存在多于一个 ...

  7. JsRender系列demo(6)-无名

    <!DOCTYPE html> <html> <head> <script src="http://code.jquery.com/jquery.j ...

  8. 文件夹和文件、Path类、流、序列化

    循环访问目录树 参考: http://msdn.microsoft.com/zh-cn/library/bb513869.aspx 循环访问目录树”的意思是在指定的根文件夹下,访问每个嵌套子目录中任意 ...

  9. POJ 2407 Relatives(欧拉函数)

    题目链接 题意 : 求小于等于n中与n互质的数的个数. 思路 : 看数学的时候有一部分是将欧拉函数的,虽然我没怎么看懂,但是模板我记得了,所以直接套了一下模板. 这里是欧拉函数的简介. #includ ...

  10. 使用预处理PreparedStatement执行Sql语句

    /** * 使用预处理的方式执行Sql * @param sql Sql语句 * @param obj 变量值数组 * @return 查询结果 * @throws SQLException */ p ...