MFC第二十七天 通过动态链表实现游戏角色动态增加、WM_ERASEBKGND背景刷新的原理、RegisterClass注册窗口与框架程序开发

news2025/1/8 14:44:09

文章目录

  • 通过动态链表实现游戏角色动态增加
    • CMemoryDC.h
    • CFlashDlg.h
    • CFlashDlg.cpp
  • WM_ERASEBKGND背景刷新的原理
  • RegisterClass注册窗口与框架程序开发
    • CFrameRegister

通过动态链表实现游戏角色动态增加

CMemoryDC.h

	#pragma once
	#include "resource.h"

	/*内存DC类简介: 
	1、BOOL LoadBitmap(UINT nBitmapID,CDC* pDC = NULL)
	从资源中按照,按位图ID加载位图
	2、BOOL LoadFile(LPCTSTR sFile, CDC* pDC = NULL)
	从exe外部加载图片(调用LoadImage)
	3、BOOL Create(int cx, int cy, CDC* pDC = NULL)
	创建空白位图(默认是全黑)
	4、总共有4种构造函数,包含以上3种还有空构造:
	CMemoryDC(UINT nBitmapID)//从资源按照位图编号来加载
	CMemoryDC(LPCTSTR sFile, CDC* pDC = NULL)//从exe外部加载
	CMemoryDC(int cx, int cy, CDC* pDC=NULL)//指定高宽创建空白位图

	5、void MakeRgn(CRgn& r,COLORREF col)
	生成透明区域
	6、int GetWidth() const
	int GetHeight() const
	方便地获取图片高宽:
	7、
	透明显示:BitTrans和StrecthTrans
	*/
	class CMemoryDC :public CDC
	{
		CSize m_size;
	public:
		CMemoryDC();
 

		int GetWidth() const
		{
			return m_size.cx;
		}
		int GetHeight() const
		{
			return m_size.cy;
		}
 
		CSize GetSize() const
		{
			return m_size;
		}

		void BitTrans(
			int nXDest,		// 目标起点X
			int nYDest,		// 目标起点Y
			int nWidthDest,	// 目标宽度
			int nHeightDest,// 目标高度
			CDC* pDC,		// 目标DC
			int nXSrc,		// 来源起点X
			int nYSrc,		// 来源起点Y
			COLORREF crTrans// 透明色
		)
		{
			CMemoryDC dcImage(nWidthDest, nHeightDest, pDC);//临时DC
			CBitmap bmpMask;
			bmpMask.CreateBitmap(nWidthDest, nHeightDest, 1, 1, NULL);            // 创建单色掩码位图
			CDC dcMask;//掩码DC 
			dcMask.CreateCompatibleDC(pDC);
			dcMask.SelectObject(bmpMask);
			//将载入位图的内存DC中的位图,拷贝到临时DC中
			dcImage.BitBlt(0, 0, nWidthDest, nHeightDest, this, nXSrc, nYSrc, SRCCOPY);

			// 设置临时DC的透明色
			dcImage.SetBkColor(crTrans);
			//掩码DC的透明区域为白色其它区域为黑色
			dcMask.BitBlt(0, 0, nWidthDest, nHeightDest, &dcImage, 0, 0, SRCCOPY);

			//临时DC透明区域为黑色,其它区域保持不变
			dcImage.SetBkColor(RGB(0, 0, 0));
			dcImage.SetTextColor(RGB(255, 255, 255));
			dcImage.BitBlt(0, 0, nWidthDest, nHeightDest, &dcMask, 0, 0, SRCAND);

			// 目标DC透明部分保持屏幕不变,其它部分变成黑色
			pDC->SetBkColor(RGB(255, 255, 255));
			pDC->SetTextColor(RGB(0, 0, 0));
			pDC->BitBlt(nXDest, nYDest, nWidthDest, nHeightDest, &dcMask, 0, 0, SRCAND);
			pDC->BitBlt(nXDest, nYDest, nWidthDest, nHeightDest, &dcImage, 0, 0, SRCPAINT);
		}
		void StretchTrans(
			int nXDest,			// 目标起点X
			int nYDest,			// 目标起点Y
			int nWidthDest,     // 目标宽度
			int nHeightDest,    // 目标高度
			CDC* pDC,			// 目标DC
			int nXSrc,			// 来源起点X
			int nYSrc,			// 来源起点Y
			int nWidthSrc,		// 来源宽度
			int nHeightSrc,		// 来源高度
			COLORREF crTrans	// 透明色
		)
		{
			CMemoryDC dcImage(nWidthDest, nHeightDest, pDC);//临时DC
			CBitmap bmpMask;
			// 创建单色掩码位图
			bmpMask.CreateBitmap(nWidthDest, nHeightDest, 1, 1, NULL);
			CDC dcMask;
			dcMask.CreateCompatibleDC(pDC);
			dcMask.SelectObject(bmpMask);

			// 将载入位图的内存DC中的位图,拷贝到临时DC中
			if (nWidthDest == nWidthSrc && nHeightDest == nHeightSrc)
				dcImage.BitBlt(0, 0, nWidthDest, nHeightDest, this, nXSrc, nYSrc, SRCCOPY);
			else
				dcImage.StretchBlt(0, 0, nWidthDest, nHeightDest,
					this, nXSrc, nYSrc, nWidthSrc, nHeightSrc, SRCCOPY);

			// 设置临时DC的透明色
			dcImage.SetBkColor(crTrans);
			//掩码DC的透明区域为白色其它区域为黑色
			dcMask.BitBlt(0, 0, nWidthDest, nHeightDest, &dcImage, 0, 0, SRCCOPY);

			//临时DC透明区域为黑色,其它区域保持不变
			dcImage.SetBkColor(RGB(0, 0, 0));
			dcImage.SetTextColor(RGB(255, 255, 255));
			dcImage.BitBlt(0, 0, nWidthDest, nHeightDest, &dcMask, 0, 0, SRCAND);

			// 目标DC透明部分保持屏幕不变,其它部分变成黑色
			pDC->SetBkColor(RGB(255, 255, 255));
			pDC->SetTextColor(RGB(0, 0, 0));
			pDC->BitBlt(nXDest, nYDest, nWidthDest, nHeightDest, &dcMask, 0, 0, SRCAND);
			pDC->BitBlt(nXDest, nYDest, nWidthDest, nHeightDest, &dcImage, 0, 0, SRCPAINT);
		}

		//创建空位图
		BOOL Create(int cx, int cy, CDC* pDc = NULL)
		{
			if (!CreateCompatibleDC(NULL))
				return FALSE;
			CBitmap bmp;
			if (pDc)
			{
				if (!bmp.CreateCompatibleBitmap(pDc, cx, cy)) 
				{
					DeleteDC();
					return FALSE;
				}
			}
			else
			{
				if (!bmp.CreateCompatibleBitmap(&CClientDC(NULL), cx, cy))
				{
					DeleteDC();
					return FALSE;
				}
			}
			this->SelectObject(&bmp);
			m_size.SetSize(cx, cy);
			return TRUE;
		}
		//加载一张exe外部位图
		BOOL LoadFile(LPCTSTR sFile, CDC* pDC = NULL)
		{
			HBITMAP hBitmap = (HBITMAP)LoadImage(NULL, sFile, IMAGE_BITMAP, 0, 0, LR_LOADFROMFILE);
			if (!hBitmap)
				return FALSE;	
			if (!CreateCompatibleDC(NULL))
			{
				DeleteObject(hBitmap);
				return FALSE;
			}
			
			SelectObject(hBitmap);

			BITMAP bm;
			GetObject(hBitmap, sizeof(bm), &bm);
			m_size.SetSize(bm.bmWidth, bm.bmHeight);
			DeleteObject(hBitmap);
			return TRUE;
		}

		//加载一张资源位图
		BOOL LoadBitmap(UINT nBitmapID, CDC* pDC = NULL)
		{
			if (!CreateCompatibleDC(NULL))
				return FALSE;
			CBitmap bmp;
			if (!bmp.LoadBitmap(nBitmapID))
			{
				DeleteDC();
				return FALSE;
			}
			SelectObject(&bmp);

			BITMAP bm;
			bmp.GetBitmap(&bm);
			m_size.SetSize(bm.bmWidth, bm.bmHeight);
			return TRUE;
		}
		CMemoryDC(UINT nBitmapID)
		{
			LoadBitmap(nBitmapID);
		}
		CMemoryDC(LPCTSTR sFile,CDC* pDC = NULL)
		{
			LoadFile(sFile, pDC);
		}
		CMemoryDC(int cx,int cy,CDC* pDC=NULL)
		{
			Create(cx, cy, pDC);
		}
		void MakeRgn(CRgn& r, COLORREF col)
		{
			r.CreateRectRgn(0, 0, 0, 0);
			int i = -1, cx = m_size.cx;
			int j = -1, cy = m_size.cy;
			while (++j<cy)
			{
				i = -1;
				while (++i<cx)
				{
					if (GetPixel(i, j) != col)
					{
						CRgn r1;
						r1.CreateRectRgn(i, j, i + 1, j + 1); //1*1像素
						r.CombineRgn(&r, &r1, RGN_OR);
					}
				}
			}

		}
	};

CFlashDlg.h

#pragma once
#include "CMemoryDC.h"
class CCFlashDlg : public CDialogEx{ 
	struct sData {
		int nIndex;
		CPoint pos, dir{ 5,5 };
	};
	CList<sData> m_list;  //使用动态链表实现 角色的动态增加
// 构造
	enum {Fly_nCount =7}; //图片总数
	CMemoryDC m_dcBack{_T("./res/back.bmp")}; //背景图片
	CMemoryDC m_dcFlys[Fly_nCount]; //蝴蝶
	CRgn m_rs[Fly_nCount]; //取出背景颜色
	void LoadPictures();
	CDC m_dc; //作一个缓冲dc
// 实现
protected:
	HICON m_hIcon;
	// 生成的消息映射函数
	virtual BOOL OnInitDialog();
	afx_msg void OnPaint();
	afx_msg HCURSOR OnQueryDragIcon();
	DECLARE_MESSAGE_MAP()
public:
	afx_msg void OnTimer(UINT_PTR nIDEvent);
	afx_msg void OnLButtonDown(UINT nFlags, CPoint point);
	afx_msg void OnSize(UINT nType, int cx, int cy);
	afx_msg BOOL OnEraseBkgnd(CDC* pDC);
};

CFlashDlg.cpp

#include "pch.h"
#include "framework.h"
#include "CFlash.h"
#include "CFlashDlg.h"
#include "afxdialogex.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif
CCFlashDlg::CCFlashDlg(CWnd* pParent /*=nullptr*/)
	: CDialogEx(IDD_CFLASH_DIALOG, pParent)
{
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CCFlashDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialogEx::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CCFlashDlg, CDialogEx)
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_WM_TIMER()
	ON_WM_LBUTTONDOWN()
	ON_WM_SIZE()
	ON_WM_ERASEBKGND()
END_MESSAGE_MAP()
BOOL CCFlashDlg::OnInitDialog()
{
	CDialogEx::OnInitDialog();
	
	int cx = GetSystemMetrics(SM_CXSCREEN);
	int cy = GetSystemMetrics(SM_CYSCREEN);
	  
	SetWindowPos(NULL, 0, 0, cx/2, cy/2, SWP_NOZORDER);

	LoadPictures();	
	SetTimer(1, 16, NULL);
	srand((int)time(NULL));
	return TRUE;  // 除非将焦点设置到控件,否则返回 TRUE
}
void CCFlashDlg::OnPaint()
{
	CPaintDC dc(this); // 用于绘制的设备上下文
	CRect rect;
	GetClientRect(rect);

	m_dc.SetStretchBltMode(STRETCH_HALFTONE); //拉伸图片质量的
	m_dc.StretchBlt(0, 0, rect.Width(), rect.Height(), &m_dcBack, 0, 0, m_dcBack.GetWidth(), m_dcBack.GetHeight(), SRCCOPY);
	
	CMemoryDC mdc(300,280); //创建默认的黑色
	if (mdc.GetSafeHdc())
		m_dc.BitBlt(200, 150, 300, 280, &mdc, 0, 0, SRCCOPY);
	//CRgn r;
	//r.CreateRectRgn(0, 0, 0, 0); //基址
	//r.CopyRgn(m_rs+m_nIndex);  //往那个跑先复制出来 不要破坏它 形状
	//r.OffsetRgn(m_pos); //你要输出到那个位置
	//dc.SelectObject(&r);
	auto pos = m_list.GetHeadPosition();
	int i = 0;
	while (pos)
	{
		sData& d = m_list.GetNext(pos);
		auto pDC = m_dcFlys + d.nIndex;
 
	pDC->BitTrans(d.pos.x, d.pos.y, pDC->GetWidth(), pDC->GetHeight(), &m_dc, 0, 0, 0xff00ff);

	if (++d.nIndex >= Fly_nCount)
		d.nIndex = 0 ;

	d.pos.Offset(d.dir);

	if (d.pos.x + m_dcFlys->GetWidth() > rect.right || d.pos.x < 0)
		d.dir.x *= -1;
	if (d.pos.y + m_dcFlys->GetHeight() > rect.bottom || d.pos.y < 0)
		d.dir.y *= -1;
	CString str;
	str.Format(_T("%d"), i++);
	m_dc.TextOut(d.pos.x,d.pos.y,str);
	}										//闪烁 是因为交替输出 
	dc.BitBlt(0, 0, rect.Width(), rect.Height(), &m_dc, 0, 0, SRCCOPY); //双缓冲技术 防止闪烁 采用一次性输出全部由m_dc输出  
}
void CCFlashDlg::LoadPictures()	{
	int i = -1;
	CString str;
	while (++i<_countof(m_dcFlys))	
	{
		str.Format(_T("./res/%03d.bmp"), i + 1);
		m_dcFlys[i].LoadFile(str);
		m_dcFlys[i].MakeRgn(m_rs[i],0x00ff00ff);
	}
}
void CCFlashDlg::OnTimer(UINT_PTR nIDEvent)
{
	Invalidate(TRUE); //制造了闪烁 因为前景输出 会触发再一次的交替输出
	CDialogEx::OnTimer(nIDEvent);
}
void CCFlashDlg::OnLButtonDown(UINT nFlags, CPoint point)  {
	sData d;
	d.nIndex = rand() % Fly_nCount;

	int n = rand() % 2 ? 1 : -1;
	d.dir.x = 5 * n;
	n = rand() % 2 ? 1 : -1;
	d.dir.y = 5 * n;
	d.pos = point;
	d.pos.x -= m_dcFlys->GetWidth() / 2; //中心点
	d.pos.y -= m_dcFlys->GetHeight() / 2; //中心点

	m_list.AddTail(d);
	CDialogEx::OnLButtonDown(nFlags, point);
}
void CCFlashDlg::OnSize(UINT nType, int cx, int cy)
{
	CDialogEx::OnSize(nType, cx, cy);
	m_dc.DeleteDC();
	m_dc.CreateCompatibleDC(NULL);

	CBitmap bmp;
	bmp.CreateBitmap(cx, cy, 1, 32, NULL);
	m_dc.SelectObject(&bmp);
}
BOOL CCFlashDlg::OnEraseBkgnd(CDC* pDC)
{
	return TRUE; //给夺权了
}

在这里插入图片描述


WM_ERASEBKGND背景刷新的原理

WM_ERASEBKGND是一种消息类型,它是在窗口需要重绘背景时发送给窗口的。背景刷新的原理是在窗口绘制之前,系统首先向窗口发送WM_ERASEBKGND消息,窗口可以在处理此消息时进行背景擦除操作,即清除原有的背景后。系统会发送WM_PAINT消息,窗口可以在处理此消息时进行绘制操作,即绘制新的背景。

具体的背景刷新流程如下:

  1. 当窗口需要重绘背景时,系统发送WM_ERASEBKGND消息给窗口。
  2. 窗口接收到WM_ERASEBKGND消息后,可以执行背景擦除操作,清除原有的背景。常见的擦除操作包括用背景色填充窗口区域、绘制背景图片等。
  3. 完成背景擦除后,窗口可以返回非零值,表示背景已经擦除完毕。
  4. 系统接收到非零返回值后,发送WM_PAINT消息给窗口。
  5. 窗口接收到WM_PAINT消息后,可以执行绘制操作,即绘制新的背景。
  6. 绘制完成后,窗口可以调用ValidateRect或InvalidateRect函数,通知系统该区域已经被绘制完成,系统不再发送WM_PAINT消息。

通过以上流程,窗口可以在接收到WM_ERASEBKGND和WM_PAINT消息时分别进行背景擦除和绘制操作,实现背景的刷新。
在这里插入图片描述

RegisterClass注册窗口与框架程序开发

classname注册窗口类型名:有3种方式注册
a)原始API:ATOM RegisterClass(const WNDCLASS *lpWndClass); 注册窗口类型
b)MFC封装之后叫做AfxRegisterClass,类似于AfxMessageBox封装了MessageBox(API)
c)MFC再次封装了一个真正的简易注册函数叫做:AfxRegisterWndClass
返回值是自动生成字符串,字符串的内容包括三要素的句柄sprintf生成的文字

注册的内容主要包括:背景颜色,图标,光标,另外还有的类型包含有菜单

typedef struct tagWNDCLASS {
  UINT      style;
  WNDPROC   lpfnWndProc;
  int       cbClsExtra;
  int       cbWndExtra;
  HINSTANCE hInstance;
  HICON     hIcon;
  HCURSOR   hCursor;
  HBRUSH    hbrBackground;
  LPCTSTR   lpszMenuName;
  LPCTSTR   lpszClassName;
} WNDCLASS, *PWNDCLASS;
typedef struct tagWNDCLASSEX {
  UINT      cbSize;
  UINT      style;
  WNDPROC   lpfnWndProc;
  int       cbClsExtra;
  int       cbWndExtra;
  HINSTANCE hInstance;
  HICON     hIcon;
  HCURSOR   hCursor;
  HBRUSH    hbrBackground;
  LPCTSTR   lpszMenuName;
  LPCTSTR   lpszClassName;
  HICON     hIconSm;
} WNDCLASSEX, *PWNDCLASSEX;
LPCTSTR  AfxRegisterWndClass( 
   UINT nClassStyle, 
   HCURSOR hCursor = 0, 
   HBRUSH hbrBackground = 0, 
   HICON hIcon = 0  
);
AfxRegisterClass比API就是多了GetClassInfo探测一下是否已注册过了。
BOOL AFXAPI AfxRegisterClass(WNDCLASS* lpWndClass)	{
	WNDCLASS wndcls;
	if (GetClassInfo(lpWndClass->hInstance, lpWndClass->lpszClassName,
		&wndcls))
	{
		return TRUE;	// class already registered
	}
	if (!RegisterClass(lpWndClass))
	{
		TRACE(traceAppMsg, 0, _T("Can't register window class named %Ts\n"),
			lpWndClass->lpszClassName);
		return FALSE;
	}

注册的背景色的原理:
a)RegisterClass指定的背景色,依靠什么输出的呢?
b)WM_ERASEBKGND消息,是默认的背景输出管理消息。
c)WM_ERASEBKGND消息对比WM_PAINT,是微软设计的前景和背景管理消息。
d)他当年设计的原理是想要背景覆盖前景,方便刷新。 但是这个设计可能会制造闪烁问题?
解决办法
a)Invalidate函数代入TRUE,表示先触发WM_ERASEBKGRND再触发WM_PAINT消息。
b)Invalidate函数代入FALSE,表示不触发WM_ERASEBKGRND只触发WM_PAINT消息。
c)因此,好彻底解决闪烁问题还要注意,尽量Invalidate代入FALSE;
d)另外,也尽量把WM_ERASEBKGRND消息映射函数清空,只留WM_PAINT 的输出。

inline static bool IsWindowClassRegistered(LPCTSTR sClass) //用于检测注册类名 是否会重复
{
	WNDCLASSEX wcex;
	return  (GetClassInfoEx(NULL, sClass, &wcex) != 0);
}
BOOL CLadderCtrl::OnEraseBkgnd(CDC* pDC) 
 //	RegisterClass(&wc); wc.hbrBackground = m_brBack; 背景颜色依靠这个消息输出的
{
	return CWnd::OnEraseBkgnd(pDC); //默认背景输出	
}
BOOL CLadderCtrl::Create(DWORD dwStyle, CRect rect, CWnd* pParent, int nID)
{
	if (!IsWindowClassRegistered(_T("Ladder_XQ"))) //用于判断注册类名会不会重复
	{
		WNDCLASS wc = { CS_HREDRAW | CS_VREDRAW };  //注册窗口类型名
		wc.hCursor = theApp.LoadStandardCursor(IDC_HAND);
		wc.hbrBackground = m_brBack;
		wc.lpszClassName = _T("Ladder_XQ");
		wc.lpfnWndProc = ::DefWindowProc;
		RegisterClass(&wc);
	}
	return CWnd::Create(_T("Ladder_XQ"), NULL, dwStyle, rect, pParent, nID);
}
BOOL Clvxin21Dlg::OnEraseBkgnd(CDC* pDC)
{ 
	CRect rect;
	GetClientRect(rect);
	pDC->FillSolidRect(rect, GetSysColor(COLOR_BTNFACE));
	return TRUE;
}

CFrameRegister

MFC环境下创建框架窗口的必备条件:
a)InitInstance必须return TRUE;
b)theApp.m_pMainWnd 必须指向主窗口对象地址:
c)主窗口对象必须是堆空间或者生命期足够。

#include "CApp.h"
#include "CMainFrame.h"
CApp thApp;

//CWnd* pFrame = new CWnd;
 can't use for desktop or pop-up windows (use CreateEx instead) create不允许用于创建主窗口
//pFrame->Create(NULL, _T("我的世界"), WS_VISIBLE, CRect(100, 100, 800, 600), NULL, 9999);
	
//CWnd* pFrame = new CWnd;
使用CreatEx时 首先要 make sure the default window class is registered no WNDCLASS provided - use child window default  没有的默认为子窗口创建
//pFrame->CreateEx(0, NULL, _T("我的世界"), WS_VISIBLE, CRect(100, 100, 800, 600), NULL, 9999);
BOOL CApp::InitInstance(){
	/*LPCTSTR sClass = _T("MY_WORLD");
	WNDCLASS wc{ CS_HREDRAW | CS_VREDRAW | CS_DBLCLKS };
	wc.lpfnWndProc = ::DefWindowProc;
	wc.lpszClassName = sClass;
	wc.hCursor = LoadStandardCursor(IDC_CROSS);
	wc.hIcon = LoadStandardIcon(IDI_INFORMATION);
	wc.hbrBackground = (HBRUSH)GetStockObject(LTGRAY_BRUSH);
	RegisterClass(&wc);*/
	auto pFrame = new CMainFrame;
	BOOL b = pFrame->CreateEx(0, NULL, _T("我的世界"),
	WS_VISIBLE | WS_MAXIMIZEBOX |WS_MINIMIZEBOX| WS_SYSMENU, 100, 100, 800, 600, NULL, NULL);
	m_pMainWnd = pFrame;
	return TRUE;
}
#include "CMainFrame.h"
BOOL CMainFrame::PreCreateWindow(CREATESTRUCT& cs)
{
	//if (!CWnd::PreCreateWindow(cs)) //给子框架用来注册的,对主框架不好使
	//	return FALSE;

	cs.lpszClass = AfxRegisterWndClass(0); 
	 //自己添加的使用的AfxRegisterWndClass 也可以继续在添加属性  预处理

	return CWnd::PreCreateWindow(cs);
}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/841995.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Shell】基础语法(二)

文章目录 一、Shell基本语法文件名代换命令代换算术代换转义字符引号 二、Shell脚本语法条件测试分支结构循环 三、总结 一、Shell基本语法 文件名代换 用于匹配的字符称为通配符&#xff08;Wildcard&#xff09;&#xff0c;如&#xff1a;* ? [ ] 具体如下&#xff1a; *…

【Datawhale AI 夏令营第二期】AI 量化模型预测挑战赛

文章目录 赛题分析赛题背景赛事任务赛题数据集评价指标 Baseline实践导入模块EDA特征工程模型训练与验证结果输出 改进 赛题分析 赛题背景 量化金融在国外已经有数十年的历程&#xff0c;而在国内兴起还不到十年。这是一个极具挑战的领域。量化金融结合了数理统计、金融理论、…

DataWhale 机器学习夏令营第二期——AI量化模型预测挑战赛 学习记录

DataWhale 机器学习夏令营第二期 学习记录一 (2023.08.06)1. 问题建模1.1 赛事数据数据集情况数据中缺失值类别和数值特征的基本分布 1.2 评价指标中间价的计算方式价格移动方向说明 1.3 线下验证 DataWhale 机器学习夏令营第二期 ——AI量化模型预测挑战赛 已跑通baseline&…

排查吞吐量和 SNR 方面的 Wi-Fi 问题

服务交付对于客户在选择品牌时要考虑很重要&#xff0c;组织依靠其网络向全球客户无缝提供服务&#xff0c;强大的网络连接对于更好的最终用户体验至关重要&#xff0c;而高质量访问的关键是两个关键指标&#xff1a; 吞吐量信噪比 &#xff08;SNR&#xff09; 为了获得更好…

解决word打字卡顿问题的方法

❤ 2023.8.5 ❤ 最近整理论文&#xff0c;本来我是wps死忠粉&#xff0c;奈何wps不支持latex公式。。。 无奈用起了word&#xff0c;但是谁想字数稍微多了一点&#xff0c;word就卡得欲仙欲死&#xff0c;打个字过去2s才显示出来&#xff0c;删除的时候都不知道自己删了几个字…

基于STM32CUBEMX驱动低压步进器电机驱动器STSPIN220(1)----套件概述

基于STM32CUBEMX驱动低压步进器电机驱动器STSPIN220----1.套件概述 套件概述样品申请特征系统控制和生态系统访问功能示意图系统框图跳线设置开发板原理图 套件概述 STM32C011F4Px_STSPIN220 是一款基于 STM32C011F4Px 的低压步进电机驱动套件。其中&#xff0c;STSPIN220 是一…

离散化的两种实现方式【sort或者map】

离散化 定义 把无限空间中有限的个体映射到有限的空间中去&#xff0c;以此提高算法的时空效率。通俗的说&#xff0c;离散化是在不改变数据相对大小的条件下&#xff0c;对数据进行相应的缩小。 适用范围&#xff1a;数组中元素值域很大&#xff0c;但个数不是很多。 比如将…

Navicat远程连接Linux的MySQL

打开Linux终端&#xff0c;进入root权限&#xff0c;用vim打开MySQL的配置文件 vim /etc/mysql/mysql.conf.d/mysqld.cnf将bind-address的值改为0.0.0.0 进入MySQL mysql -u root -p 将root用户改为允许远程登录 update user set host % where user root; 创建用户 CRE…

码出高效_第二章 | 面向对象_上

目录 一. OOP理念1. 概念辨析2. 四大特性1. 抽象2. 封装3. 继承4. 多态 二. 初识Java1. JDKJDK 5-11的重要类、特性及重大改变 2. JRE关于JVM 三. 类1. 概述2. 接口和抽象类1. 概念及相同点2. 不同点3. 总结 3. 内部类4. 访问权限控制1. 由来2. public/private/无/private3. 推…

无涯教程-Perl - endgrent函数

描述 此功能告诉系统您不再希望使用getgrent从groups文件中读取条目。 语法 以下是此函数的简单语法- endgrent返回值 此函数不返回任何值。 Perl 中的 endgrent函数 - 无涯教程网无涯教程网提供描述此功能告诉系统您不再希望使用getgrent从groups文件中读取条目。 语法以…

开源项目-私人牙医管理系统

哈喽,大家好,今天给大家带来一个开源项目-私人牙医管理系统,项目使用springboot+mysql技术实现 私人牙医管理系统的主要功能包括客户管理,医生管理,药品管理,文章管理模块 登录 客户管理 客户管理主要有客户数据,客户列表,添加客户功能 客户数据 客户列表 添加…

VIOOVI的精益生产探析:深入了解精益生产的本质

精益生产它是利用杜绝浪费和稳定、连续生产的作业流程&#xff0c;是通过系统性的结构管理、生产人员组织以及市场端的供求现状等方面的因素做对应的调整、变革。具备有一定战斗力的生产管理体系&#xff0c;可以很快的根据市场端需求做出对应的调整&#xff0c;而且实现生产过…

黑马大数据学习笔记5-案例

目录 需求分析背景介绍目标需求数据内容DBeaver连接到Hive建库建表加载数据 ETL数据清洗数据问题需求实现查看结果扩展 指标计算需求需求指标统计 可视化展示BIFineBI的介绍及安装FineBI配置数据源及数据准备 可视化展示 P73~77 https://www.bilibili.com/video/BV1WY4y197g7?…

如何使用win10专业版系统自带远程桌面公司内网电脑,从而实现居家办公?

使用win10专业版自带远程桌面公司内网电脑 文章目录 使用win10专业版自带远程桌面公司内网电脑 在现代社会中&#xff0c;各类电子硬件已经遍布我们身边&#xff0c;除了应用在个人娱乐场景的消费类电子产品外&#xff0c;各项工作也离不开电脑的帮助&#xff0c;特别是涉及到数…

router和route的区别

简单理解为&#xff0c;route是用来获取路由信息的&#xff0c;router是用来操作路由的。 一、router router是VueRouter的实例&#xff0c;通过Vue.use(VueRouter)和VueRouter构造函数得到一个router的实例对象&#xff0c;这个对象中是一个全局的对象&#xff0c;他包含了所…

vue结合three.js加载3D模型报404错误

使用vue结合three.js加载3D模型时报404的错误&#xff0c;加载字体库也会报404错误&#xff0c;同样的方法。 vue项目虽然使用npm install three安装了three&#xff0c;但是有些静态资源时读取不到的&#xff0c;当出现异常的404错误时&#xff0c;比如加载3D模型资源时&…

第5章 运算符、表达式和语句

本章介绍以下内容&#xff1a; 关键字&#xff1a;while、typedef 运算符&#xff1a;、-、*、/、%、、--、(类型名) C语言的各种运算符&#xff0c;包括用于普通数学运算的运算符 运算符优先级以及语句、表达式的含义 while循环 复合语句、自动类型转换和强制类型转换 如何编写…

虚拟机不能使用 console 的问题

原理&#xff1a;arm 系统默认走ttyAMA0&#xff0c;x86 默认走ttyS0&#xff0c;而tty0 是走的GPU 串行端口终端(/dev/ttySn) 串行端口终端(Serial Port Terminal)是使用计算机串行端口连接的终端设备。 计算机把每个串行端口都看作是一个字符设备。有段时间这些串行端口设备…

6.6.tensorRT高级(1)-mmdetection框架下yolox模型导出并推理

目录 前言1. yolox导出2. yolox推理3. 补充知识3.1 知识点3.2 mmdetection 总结 前言 杜老师推出的 tensorRT从零起步高性能部署 课程&#xff0c;之前有看过一遍&#xff0c;但是没有做笔记&#xff0c;很多东西也忘了。这次重新撸一遍&#xff0c;顺便记记笔记。 本次课程学习…

Spring Boot介绍--快速入门--约定优于配置

文章目录 SpringBoot 基本介绍官方文档Spring Boot 是什么?SpringBoot 快速入门需求/图解说明完成步骤快速入门小结 Spring SpringMVC SpringBoot 的关系总结梳理关系如何理解-约定优于配置 SpringBoot 基本介绍 官方文档 官网: https://spring.io/projects/spring-boot 学习…