// 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, S
WP_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图象的最简单实现
来自: #include "DDraw.h" class CDDraw { public: void CleanUp(); void DrawDIB(BITMAPINFOH ...
- 如何使用DirectDraw直接显示RGB、YUV视频数据(播放yuv)
#include "draw.h"void CTest100Dlg::OnButton1() { // TODO: Add your control notification ha ...
- 谈谈“色彩空间表示方法”——RGB、YUY2、YUYV、YVYU、UYVY、AYUV
转自:http://bbs.chinavideo.org/viewthread.php?tid=4143 还可参考http://www.fourcc.org/yuv.php 小知识:RGB与YUV-- ...
- 最简单的视音频播放示例7:SDL2播放RGB/YUV
本文记录SDL播放视频的技术.在这里使用的版本是SDL2.实际上SDL本身并不提供视音频播放的功能,它只是封装了视音频播放的底层API.在Windows平台下,SDL封装了Direct3D这类的API ...
- 最简单的视音频播放示例3:Direct3D播放YUV,RGB(通过Surface)
上一篇文章记录了GDI播放视频的技术.打算接下来写两篇文章记录Direct3D(简称D3D)播放视频的技术.Direct3D应该Windows下最常用的播放视频的技术.实际上视频播放只是Direct3 ...
- DirectDraw
一.DirectDraw接口 DirectDraw接口图如下: 1.IUnknown:所有COM对象都必须从这个基本接口派生 2.IDirectDraw:这是开始使用DirectDraw时必须创建的主 ...
- 《Windows游戏编程技巧大师》就DirectDraw而创建DirectDraw知识笔记
1.DirectDraw 这可能是Directx中最重要的技术,由于它是2D图形赖以实现的渠道.也是Direct3D构建于其上的帧缓冲层. 2.DirectDraw是由非常多借口组成的.共同拥有5个接 ...
- 使用DirectDraw直接显示YUV视频数据
最近在编写一个进行视频播放的ActiveX控件,工作已经接近尾声,现将其中显示YUV数据的使用DirectDraw的一些经验总结如下:(解码部分不是我编写的,我负责从网络接收数据,将数据传给解码器,并 ...
- 初次接触:DirectDraw
第六章 初次接触:DirectDraw 本章,你将初次接触DirectX中最重要的组件:DirectDraw.DirectDraw可能是DirectX中最强大的技术,因为其贯穿着2D图形绘制同时其帧缓 ...
随机推荐
- [设计模式] 4 原型模式 prototype
设计模式:可复用面向对象软件的基础>(DP)本文介绍原型模式和模板方法模式的实现.首先介绍原型模式,然后引出模板方法模式. DP书上的定义为:用原型实例指定创建对象的种类,并且通过拷贝这些原型创 ...
- 企业运营对 DevOps 的「傲慢与偏见」
摘要:出于各种原因,并非所有人都信任 DevOps .有些人觉得 DevOps 只不过给开发者改善产品提供了一个途径而已,还有的人觉得 DevOps 是一堆悦耳的空头支票,甚至有人认为 DevOps ...
- sql over()---转载
1.使用over子句与rows_number()以及聚合函数进行使用,可以进行编号以及各种操作.而且利用over子句的分组效率比group by子句的效率更高. 2.在订单表(order)中统计中,生 ...
- URAL 1297 Palindrome 最长回文子串
POJ上的,ZOJ上的OJ的最长回文子串数据量太大,用后缀数组的方法非常吃力,所以只能挑个数据量小点的试下,真要做可能还是得用manacher.贴一下代码 两个小错,一个是没弄懂string类的sub ...
- LightOj 1096 - nth Term (矩阵快速幂,简单)
题目 这道题是很简单的矩阵快速幂,可惜,在队内比赛时我不知什么时候抽风把模版中二分时判断的 ==1改成了==0 ,明明觉得自己想得没错,却一直过不了案例,唉,苦逼的比赛状态真让人抓狂!!! #incl ...
- hdu 2112 HDU Today (最短路,字符处理)
题目 题目很简单,只是多了对地名转化为数字的处理,好吧,这我也是参考网上的处理办法,不过大多数的人采用map来处理 注意初始化注意范围,不然会wa!!!(这是我当时wa的原因org) 大家容易忽视的地 ...
- Network Saboteur(Rand版)
poj2531:http://poj.org/problem?id=2531 题意:给你一个图,图中点之间会有边权,现在问题是把图分成两部分,使得两部分之间边权之和最大.题解:随机算法 #includ ...
- POJ2632Crashing Robots
做模拟题做的我直接睡着了,题并不难,就是一个细心的问题,有一些细节问题注意了就差不多了,代码写的精美的一般找错误也好找一些,应该学着些好看的代码 #include<cstdio> #inc ...
- 【转载】Ssh整合开发介绍和简单的登入案例实现
Ssh整合开发介绍和简单的登入案例实现 Ssh整合开发介绍和简单的登入案例实现 一 介绍: Ssh是strtus2-2.3.1.2+ spring-2.5.6+hibernate-3.6.8整合的开 ...
- 独立IP与共享IP的区别
做网站选择独立IP还是共享IP,相信很多站长都在此纠结过,自己不使用服务器的时候从来没有关心过独立IP和共享IP的究竟有什么具体的差别.但当自己真正用到的时候,才发现:同样都是 IP,差别不是一般的大 ...