• 大小: 75KB
    文件类型: .rar
    金币: 2
    下载: 1 次
    发布日期: 2021-06-23
  • 语言: C/C++
  • 标签: Hough变换  

资源简介

该C++程序有效实现图像中的直线检测和圆的检测,程序运行稳定无bug。

资源截图

代码片段和文件信息

//  dibapi.cpp
//
//  Source file for Device-Independent Bitmap (DIB) API.  Provides
//  the following functions:
//
//  PaintDIB()          - Painting routine for a DIB
//  CreateDIBPalette()  - Creates a palette from a DIB
//  FindDIBBits()       - Returns a pointer to the DIB bits
//  DIBWidth()          - Gets the width of the DIB
//  DIBHeight()         - Gets the height of the DIB
//  PaletteSize()       - Gets the size required to store the DIB‘s palette
//  DIBNumColors()      - Calculates the number of colors
//                        in the DIB‘s color table
//  CopyHandle()        - Makes a copy of the given global memory block
//
// This is a part of the Microsoft Foundation Classes C++ library.
// Copyright (C) 1992-1997 Microsoft Corporation
// All rights reserved.
//
// This source code is only intended as a supplement to the
// Microsoft Foundation Classes Reference and related
// electronic documentation provided with the library.
// See these sources for detailed information regarding the
// Microsoft Foundation Classes product.

#include “stdafx.h“
#include “dibapi.h“
#include 
#include 
#include 

#define DIB_HEADER_MARKER   ((WORD) (‘M‘ << 8) | ‘B‘)

#ifdef _MAC
#define SWAPWORD(x) MAKEWORD(HIBYTE(x) LOBYTE(x))
#define SWAPLONG(x) MAKELONG(SWAPWORD(HIWORD(x)) SWAPWORD(LOWORD(x)))
void ByteSwapHeader(BITMAPFILEHEADER* bmiHeader);
void ByteSwapInfo(LPSTR lpHeader BOOL fWin30Header);
#endif

/*************************************************************************
 *
 * PaintDIB()
 *
 * Parameters:
 *
 * HDC hDC          - DC to do output to
 *
 * LPRECT lpDCRect  - rectangle on DC to do output to
 *
 * HDIB hDIB        - handle to global memory with a DIB spec
 *                    in it followed by the DIB bits
 *
 * LPRECT lpDIBRect - rectangle of DIB to output into lpDCRect
 *
 * CPalette* pPal   - pointer to CPalette containing DIB‘s palette
 *
 * Return Value:
 *
 * BOOL             - TRUE if DIB was drawn FALSE otherwise
 *
 * Description:
 *   Painting routine for a DIB.  Calls StretchDIBits() or
 *   SetDIBitsToDevice() to paint the DIB.  The DIB is
 *   output to the specified DC at the coordinates given
 *   in lpDCRect.  The area of the DIB to be output is
 *   given by lpDIBRect.
 *
 ************************************************************************/

BOOL WINAPI PaintDIB(HDC     hDC
LPRECT  lpDCRect
HDIB    hDIB
LPRECT  lpDIBRect
CPalette* pPal)
{
LPSTR    lpDIBHdr;            // Pointer to BITMAPINFOHEADER
LPSTR    lpDIBBits;           // Pointer to DIB bits
BOOL     bSuccess=FALSE;      // Success/fail flag
HPALETTE hPal=NULL;           // Our DIB‘s palette
HPALETTE hOldPal=NULL;        // Previous palette

/* Check for valid DIB handle */
if (hDIB == NULL)
return FALSE;

/* Lock down the DIB and get a pointer to the beginning of the bit
 *  buffer
 */
l

 属性            大小     日期    时间   名称
----------- ---------  ---------- -----  ----

     文件     110414  2014-04-07 15:51  hough变化\测试图片\result.bmp

     文件     110416  2014-04-07 15:51  hough变化\测试图片\source.bmp

     文件     143504  2014-04-07 15:51  hough变化\源代码\Debug\MyDIP.exe

     文件      23782  2014-04-07 15:51  hough变化\源代码\dibapi.cpp

     文件       1876  2014-04-07 15:51  hough变化\源代码\dibapi.h

     文件       2506  2014-04-07 15:51  hough变化\源代码\MainFrm.cpp

     文件       1581  2014-04-07 15:51  hough变化\源代码\MainFrm.h

     文件       3157  2014-04-07 15:51  hough变化\源代码\mydib.cpp

     文件         72  2014-04-07 15:51  hough变化\源代码\mydib.h

     文件      31288  2014-04-07 15:51  hough变化\源代码\MyDIP.aps

     文件       2615  2014-04-07 15:51  hough变化\源代码\MyDIP.clw

     文件       4158  2014-04-07 15:51  hough变化\源代码\MyDIP.cpp

     文件       4781  2014-04-07 15:51  hough变化\源代码\MyDIP.dsp

     文件        533  2014-04-07 15:51  hough变化\源代码\MyDIP.dsw

     文件       1345  2014-04-07 15:51  hough变化\源代码\MyDIP.h

     文件     164864  2014-04-07 15:51  hough变化\源代码\MyDIP.ncb

     文件      49664  2014-04-07 15:51  hough变化\源代码\MyDIP.opt

     文件       2731  2014-04-07 15:51  hough变化\源代码\MyDIP.plg

     文件        352  2014-04-07 15:51  hough变化\源代码\MyDIP.positions

     文件      12279  2014-04-07 15:51  hough变化\源代码\MyDIP.rc

     文件       4007  2014-04-07 15:51  hough变化\源代码\MyDIPDoc.cpp

     文件       1830  2014-04-07 15:51  hough变化\源代码\MyDIPDoc.h

     文件      10056  2014-04-07 15:51  hough变化\源代码\MyDIPView.cpp

     文件       1948  2014-04-07 15:51  hough变化\源代码\MyDIPView.h

     文件       4287  2014-04-07 15:51  hough变化\源代码\ReadMe.txt

     文件       1078  2014-04-07 15:51  hough变化\源代码\res\MyDIP.ico

     文件        397  2014-04-07 15:51  hough变化\源代码\res\MyDIP.rc2

     文件       1078  2014-04-07 15:51  hough变化\源代码\res\MyDIPDoc.ico

     文件       1078  2014-04-07 15:51  hough变化\源代码\res\Toolbar.bmp

     文件        827  2014-04-07 15:51  hough变化\源代码\Resource.h

............此处省略10个文件信息

评论

共有 条评论