directdraw的多画面显示rgb

// 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,码迷,mamicode.com

时间: 2024-10-12 09:40:14

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

乐学成语项目的实现

首先给软件取名为HappyIdiom,在开始编码之前,需要先对程序进行需求分析,想一想HappyIdiom中应该具备哪些功能.将这些功能全部整理出来之后,我们才好动手一一实现.这里我认为HappyIdiom中至少应该具备以下功能: 1.成语分类学习:你可以根据自己喜欢的分类(动物类.人物类.季节类.自然类.数字类.语言类.其他类)来进行学习. 2.乐猜成语:学习之余玩玩猜成语游戏,寓教于乐. 3.成语收藏:当用户遇到自己想要保存的成语,点击保存按钮,即保存到收藏页面以方便用户再次查看,对已经掌握

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

  来自: #include "DDraw.h" class CDDraw { public: void CleanUp(); void DrawDIB(BITMAPINFOHEADER* pBI,char* pData,RECT*rt); BOOL Init(HWND hWnd,int nWidth,int nHeight); CDDraw(); virtual ~CDDraw(); private: HWND m_hDrawWnd; LPDIRECTDRAW lpDD; // Di

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

上一篇文章记录了GDI播放视频的技术.打算接下来写两篇文章记录Direct3D(简称D3D)播放视频的技术.Direct3D应该Windows下最常用的播放视频的技术.实际上视频播放只是Direct3D的"副业",它主要用于3D游戏制作.当前主流的游戏几乎都是使用Direct3D制作的,例如<地下城与勇士>,<穿越火线>,<英雄联盟>,<魔兽世界>,<QQ飞车>等等.使用Direct3D可以用两种方式渲染视频:Surface和

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

转自:http://bbs.chinavideo.org/viewthread.php?tid=4143 还可参考http://www.fourcc.org/yuv.php 小知识:RGB与YUV----摘自<DirectShow实务精选> 作者:陆其明 计算机彩色显示器显示色彩的原理与彩色电视机一样,都是采用R(Red).G(Green).B(Blue)相加混色的原理:通过发射出三种不同强度的电子束,使屏幕内侧覆盖的红.绿.蓝磷光材料发光而产生色彩.这种色彩的表示方法称为RGB色彩空间表示(

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

===================================================== 最简单的视音频播放演示样例系列文章列表: 最简单的视音频播放演示样例1:总述 最简单的视音频播放演示样例2:GDI播放YUV, RGB 最简单的视音频播放演示样例3:Direct3D播放YUV,RGB(通过Surface) 最简单的视音频播放演示样例4:Direct3D播放RGB(通过Texture) 最简单的视音频播放演示样例5:OpenGL播放RGB/YUV 最简单的视音频播放演示样例

RGB, YUV及相关标准

最近在一次排查问题的过程中发现色彩空间及色彩空间转换也有很多技术细节,而理清这些细节能帮助我们更准确的定位视频方面的问题. 1. 色彩空间 色彩空间一词源于英文的“Color Space”,色彩学中,人们建立了多种色彩模型,以一维.二维.三维甚至四维空间坐标来表示某一色彩,这种用坐标系统来定义的色彩范围即色彩空间. 例如计算机监视器上显示颜色的时候,通常使用 RGB(红色.绿色.蓝色)色彩空间定义,红色.绿色.蓝色被当作 X.Y 和 Z坐标轴.另外一个生成同样颜色的方法是使用色相(X 轴).饱和

使用OpenCV滑动条写成的简单调色器,实时输出RGB值

好久没有写博客了,最近在看OpenCV,于是动手写了个简单的RGB调色器,在终端实时输出RGB的值.通过这个程序学习滑动条的使用.程序中主要用到cvCreateTrackbar ,其用法如下: cvCreateTrackbar 创建trackbar并将它添加到指定的窗口. CV_EXTERN_C_FUNCPTR( void (*CvTrackbarCallback)(int pos) ); int cvCreateTrackbar( const char* trackbar_name, cons

如何将24位RGB颜色转换16位RGB颜色

有许多朋友第一次使用16位彩色显示屏会遇到如何将24位RGB颜色转换为对应的16位RGB颜色的问题,通过查阅相关资料,就写一下其中的转换原理吧,希望对大家会有所帮助. 我们知道24位RGB是分别由8位红色,8位绿色以及8位蓝色组成: RRRRRRRR GGGGGGGG BBBBBBBB 例如:24位RGB红色表示方法为 11111111 00000000 00000000        (十六进制表示为:0xFF0000) 而对应的16位RGB颜色则是由5位红色,6位绿色以及5位红色组成: RR

UIColor RGB 调色注意

/比如rgb 色值为73. 148 .230  那么ios 里面要在后面加.0f 再除以255 [bline setBackgroundColor:[UIColor colorWithRed:73.0f/255.0f green:148.0f/255.0f blue:230.0f/255.0f alpha:0.5]];