MFC CListBox 类 公共方法:CListBox::FindStringExact
CListBox::FindStringExact 是 MFC(Microsoft Foundation Classes)中 CListBox 类的一个公共方法,用于在列表框中查找与指定字符串完全匹配的项,并返回该项的索引。以下是 CListBox::FindStringExact 的函数原型:int FindStringExact(int nIndexStart, LPCTSTR lpszFind) const; nIndexStart 参数表示开始查找的位置,如果为 -1,则从列表框的开头开始查找。 lpszFind 参数是要查找的字符串。该方法返回找到的项的索引。如果没有找到完全匹配的项,则返回 LB_ERR。以下是一个简单的示例代码,演示如何使用 CListBox::FindStringExact 方法:// 假设 m_listBox 是你的 CListBox 对象的一个成员变量CString searchString = _T("ItemToFind");int nIndex = m_listBox.FindStringExact(-1, searchSt...
MFC CListBox 类 公共方法:CListBox::FindString
CListBox::FindString 是 MFC(Microsoft Foundation Classes)中 CListBox 类的一个公共方法,用于在列表框中查找包含指定字符串的项,并返回该项的索引。以下是 CListBox::FindString 的函数原型:int FindString(int nStartAfter, LPCTSTR lpszString) const; nStartAfter 参数表示开始查找的位置,如果为 -1,则从列表框的开头开始查找。 lpszString 参数是要查找的字符串。该方法返回找到的项的索引。如果没有找到匹配项,则返回 LB_ERR。以下是一个简单的示例代码,演示如何使用 CListBox::FindString 方法:// 假设 m_listBox 是你的 CListBox 对象的一个成员变量CString searchString = _T("ItemToFind");int nIndex = m_listBox.FindString(-1, searchString);if (nIndex != LB_ERR)...
MFC CListBox 类 公共方法:CListBox::DrawItem
CListBox::DrawItem 是一个用于在列表框中绘制项的虚拟函数,它属于 CListBox 类的一部分。该函数通常被用于自定义绘制列表框中的每一项。以下是 CListBox::DrawItem 的函数签名:void DrawItem(LPDRAWITEMSTRUCT lpDrawItemStruct);DrawItem 方法通过 lpDrawItemStruct 参数提供了有关要绘制项的详细信息,包括项的矩形区域、状态等。通常,你需要在派生的类中覆盖 DrawItem 方法来实现自定义绘制。下面是一个简单的例子,演示如何使用 DrawItem 自定义绘制列表框中的项:void CMyListBox::DrawItem(LPDRAWITEMSTRUCT lpDrawItemStruct){ CDC dc; dc.Attach(lpDrawItemStruct->hDC); // 检查项是否被选中 BOOL bSelected = lpDrawItemStruct->itemState & ODS_SELECTED; // 绘制背...
MFC CListBox 类 公共方法:CListBox::Dir
在 MFC(Microsoft Foundation Classes)的 CListBox 类中,没有直接的 CListBox::Dir 方法。可能是有误解或混淆了方法名。如果你想在列表框中显示文件或目录的列表,通常可以使用 CListBox 的 AddString 方法逐一添加项,或者使用 CListBox 的 InsertString 方法插入项。然后,你可以使用 Windows API 或 MFC 提供的功能来获取文件和目录的列表,将它们逐一添加到列表框中。以下是一个简单的示例,演示如何使用 CListBox 显示指定目录中的文件列表:// 假设 m_listBox 是你的 CListBox 对象的一个成员变量// 获取指定目录下的文件列表CString directoryPath = _T("C:\\YourDirectoryPath");CFileFind finder;BOOL bWorking = finder.FindFile(directoryPath + _T("\\*.*"));while (bWorking) { b...
MFC CListBox 类 公共方法:CListBox::DeleteString
CListBox::DeleteString 是 MFC(Microsoft Foundation Classes)中 CListBox 类的另一个公共方法,用于删除列表框(ListBox)中指定索引的项。该方法与前面提到的 CListBox::DeleteItem 方法类似,但更方便,因为它不需要索引,而是通过字符串值来指定要删除的项。函数原型如下:int DeleteString(UINT nIndex);参数 nIndex 表示要删除的项的位置,从零开始计数。成功删除返回值为 LB_OKAY,如果删除失败则返回 LB_ERR。以下是一个简单的示例代码,演示如何使用 CListBox::DeleteString 方法:// 假设 m_listBox 是你的 CListBox 对象的一个成员变量// 删除列表框中包含字符串 "ItemToDelete" 的项CString strItemToDelete = _T("ItemToDelete");int nIndexToDelete = m_listBox.FindStringExact(-1,...
MFC CListBox 类 公共方法:CListBox::DeleteItem
CListBox::DeleteItem 是 MFC(Microsoft Foundation Classes)中 CListBox 类的一个公共方法,用于删除列表框(ListBox)中指定索引的项。函数原型如下:int DeleteItem(int nIndex);参数 nIndex 表示要删除的项的索引,从零开始计数。成功删除返回值为 LB_OKAY,如果删除失败则返回 LB_ERR。以下是一个简单的示例代码,演示如何使用 CListBox::DeleteItem 方法:// 假设 m_listBox 是你的 CListBox 对象的一个成员变量// 删除列表框中索引为 2 的项int nIndexToDelete = 2;m_listBox.DeleteItem(nIndexToDelete);请确保在调用 DeleteItem 方法之前,你已经向列表框中添加了足够的项,以确保索引值 nIndex 是有效的。
MFC CListBox 类 公共方法:CListBox::Create
CListBox::Create 是 MFC 中 CListBox 类的一个公共方法,用于在运行时动态创建列表框控件。这个方法通常用于非对话框类窗口(如 CView)中创建列表框。以下是一个简单的示例,演示如何使用 Create 方法:// 在你的 CView 派生类中的某个方法中CListBox myListBox;// 在窗口创建时动态创建列表框if (myListBox.Create(WS_CHILD | WS_VISIBLE | LBS_STANDARD, CRect(10, 10, 200, 200), this, IDC_MYLISTBOX) != 0) { // 列表框创建成功 // 可以使用 myListBox 对象进行操作} else { // 列表框创建失败}在上述示例中,我们首先创建了一个 CListBox 对象 myListBox,然后使用 Create 方法动态创建了一个列表框控件。WS_CHILD | WS_VISIBLE | LBS_STANDARD 是列表框的样式,CRect(10, 10, 200, 200) 是列表框的位置和大小,t...
MFC CListBox 类 公共方法:CListBox::CompareItem
在 MFC 的 CListBox 类中,有一个名为 CompareItem 的公共方法,用于处理列表框的 LBN_COMPAREITEM 消息。LBN_COMPAREITEM 消息在用户试图选择或取消选择列表框中的项时发送。当列表框的 LBS_SORT 样式启用时,该消息用于确定在列表框中插入新项的位置。下面是一个简单的示例,演示如何使用 CompareItem 方法:// 假设你有一个 CListBox 对象 myListBoxCListBox myListBox;// 在你的消息映射函数中处理 LBN_COMPAREITEM 消息void CYourDialog::OnCompareItem(LPCOMPAREITEMSTRUCT lpCompareItemStruct){ if (lpCompareItemStruct->CtlType == ODT_LISTBOX) { CListBox* pListBox = (CListBox*)CWnd::FromHandle(lpCompareItemStruct->hwndItem); i...
MFC CListBox 类 公共方法:CListBox::AddString
在 MFC 中,CListBox::AddString 是 CListBox 类的一个公共方法,用于向列表框中添加一个字符串。以下是一个简单的示例,演示如何使用 AddString 方法:// 假设你有一个 CListBox 对象 myListBoxCListBox myListBox;// 假设你有一个 CWnd 对象 pParentWnd,表示父窗口pParentWnd = this;// 在列表框中添加字符串myListBox.AddString(_T("Item 1"));myListBox.AddString(_T("Item 2"));myListBox.AddString(_T("Item 3"));在上述示例中,我们首先创建了一个 CListBox 对象 myListBox,然后使用 AddString 方法向列表框中添加了三个字符串。请注意,在实际应用中,你可能需要确保在调用 AddString 方法之前,列表框已经被创建并且有效。通常,你会在 OnInitDialog 或类似的初始化方法中调用此方法,以确保...
MFC CListBox 类 公共构造函数:CListBox::CListBox
在 MFC 中,CListBox 类的构造函数 CListBox::CListBox 通常是用于创建 CListBox 对象的。以下是一个基本的构造函数示例:CListBox myListBox;这将创建一个名为 myListBox 的 CListBox 对象。这个构造函数没有参数,所以创建的 CListBox 对象将具有默认的样式和属性。如果你希望在创建时设置特定的样式或属性,可以使用其他重载的构造函数或在构造函数后使用相应的设置方法。例如:CListBox myListBox;myListBox.Create(WS_CHILD | WS_VISIBLE | LBS_STANDARD, CRect(10, 10, 200, 200), pParentWnd, IDC_MYLISTBOX);在上述示例中,Create 方法用于在运行时创建列表框,并设置了一些基本的样式和位置。pParentWnd 是指向父窗口的指针,IDC_MYLISTBOX 是列表框的标识符。请注意,这里的代码只是简单的示例,实际使用中需要根据你的需求进行适当的设置和调整。
MFC CList 类 公共方法:CList::SetAt
在 MFC 中,CList::SetAt 是 CList 类的一个公共方法,用于设置链表中指定位置的元素的值。该方法接受一个表示位置的迭代器参数和要设置的新值。以下是一个简单的示例,演示如何使用 SetAt 方法:// 假设你有一个 CList 对象 myListCList<int, int&> myList;// 添加一些元素到链表中myList.AddTail(10);myList.AddTail(20);myList.AddTail(30);// 使用 GetHeadPosition 获取链表头部的迭代器位置POSITION pos = myList.GetHeadPosition();// 设置第一个元素的新值为 15if (pos != NULL) { myList.SetAt(pos, 15);}// 循环遍历链表中的元素for (POSITION iter = myList.GetHeadPosition(); iter != NULL; myList.GetNext(iter)) { int nItem = myList.GetAt(it...
MFC CList 类 公共方法:CList::RemoveTail
在 MFC 中,CList::RemoveTail 是 CList 类的一个公共方法,用于移除链表尾部的元素。以下是一个简单的示例,演示如何使用 RemoveTail 方法:// 假设你有一个 CList 对象 myListCList<int, int&> myList;// 添加一些元素到链表中myList.AddTail(10);myList.AddTail(20);myList.AddTail(30);// 移除链表尾部的元素myList.RemoveTail();// 循环遍历链表中的元素for (POSITION iter = myList.GetHeadPosition(); iter != NULL; myList.GetNext(iter)) { int nItem = myList.GetAt(iter); // 在这里你可以进行你的操作,nItem 包含链表中的元素值}在上述示例中,我们首先使用 AddTail 方法向链表中添加了三个元素,然后使用 RemoveTail 方法移除链表尾部的元素。最后,通过循环遍历链表中的元素,输出它们...
MFC CList 类 公共方法:CList::RemoveHead
在 MFC 中,CList::RemoveHead 是 CList 类的一个公共方法,用于移除链表头部的元素。以下是一个简单的示例,演示如何使用 RemoveHead 方法:// 假设你有一个 CList 对象 myListCList<int, int&> myList;// 添加一些元素到链表中myList.AddTail(10);myList.AddTail(20);myList.AddTail(30);// 移除链表头部的元素myList.RemoveHead();// 循环遍历链表中的元素for (POSITION iter = myList.GetHeadPosition(); iter != NULL; myList.GetNext(iter)) { int nItem = myList.GetAt(iter); // 在这里你可以进行你的操作,nItem 包含链表中的元素值}在上述示例中,我们首先使用 AddTail 方法向链表中添加了三个元素,然后使用 RemoveHead 方法移除链表头部的元素。最后,通过循环遍历链表中的元素,输出它们...
MFC CList 类 公共方法:CList::RemoveAt
在 MFC 中,CList::RemoveAt 是 CList 类的一个公共方法,用于移除链表中指定位置的元素。该方法接受一个表示位置的迭代器参数,并在该位置上移除元素。以下是一个简单的示例,演示如何使用 RemoveAt 方法:// 假设你有一个 CList 对象 myListCList<int, int&> myList;// 添加一些元素到链表中myList.AddTail(10);myList.AddTail(20);myList.AddTail(30);// 使用 GetHeadPosition 获取链表头部的迭代器位置POSITION pos = myList.GetHeadPosition();// 移除第一个元素if (pos != NULL) { myList.RemoveAt(pos);}// 循环遍历链表中的元素for (POSITION iter = myList.GetHeadPosition(); iter != NULL; myList.GetNext(iter)) { int nItem = myList.GetAt(it...
MFC CList 类 公共方法:CList::RemoveAll
CList::RemoveAll 是 MFC 中 CList 类的一个公共方法,用于移除链表中的所有元素,使链表变为空链表。以下是一个简单的示例,演示如何使用 RemoveAll 方法:// 假设你有一个 CList 对象 myListCList<int, int&> myList;// 添加一些元素到链表中myList.AddTail(10);myList.AddTail(20);myList.AddTail(30);// 使用 RemoveAll 移除链表中的所有元素myList.RemoveAll();// 再次判断链表是否为空if (myList.IsEmpty()) { TRACE("链表为空\n");} else { TRACE("链表不为空\n");}在上述示例中,我们首先使用 AddTail 方法向链表中添加了三个元素,然后使用 RemoveAll 方法移除链表中的所有元素。最后,通过 IsEmpty 方法判断链表是否为空,并通过 TRACE 函数输出结果。请注意,模板参数 <int, int...
MFC CList 类 公共方法:CList::IsEmpty
CList::IsEmpty 是 MFC 中 CList 类的一个公共方法,用于检查链表是否为空。如果链表为空,该方法返回 TRUE;否则,返回 FALSE。以下是一个简单的示例,演示如何使用 IsEmpty 方法:// 假设你有一个 CList 对象 myListCList<int, int&> myList;// 判断链表是否为空if (myList.IsEmpty()) { TRACE("链表为空\n");} else { TRACE("链表不为空\n");}// 添加一些元素到链表中myList.AddTail(10);myList.AddTail(20);// 再次判断链表是否为空if (myList.IsEmpty()) { TRACE("链表为空\n");} else { TRACE("链表不为空\n");}在上述示例中,我们首先使用 IsEmpty 方法检查链表是否为空,并通过 TRACE 函数输出结果。然后,我们向链表中添加了两个元素,并再次使用...
MFC CList 类 公共方法:CList::InsertBefore
在 MFC 中,CList::InsertBefore 是 CList 类的一个公共方法,用于在指定位置之前插入一个元素。此方法接受两个参数,第一个参数是表示链表中某个位置的迭代器,第二个参数是要插入的元素的值。以下是一个简单的示例,演示如何使用 InsertBefore 方法:// 假设你有一个 CList 对象 myListCList<int, int&> myList;// 添加一些元素到链表中myList.AddTail(10);myList.AddTail(20);// 使用 GetHeadPosition 获取链表头部的迭代器位置POSITION pos = myList.GetHeadPosition();// 在第一个元素之前插入一个新元素if (pos != NULL) { myList.InsertBefore(pos, 15);}// 循环遍历链表中的元素for (POSITION iter = myList.GetHeadPosition(); iter != NULL; myList.GetNext(iter)) { int n...
MFC CList 类 公共方法:CList::InsertAfter
在 MFC 中,CList::InsertAfter 是 CList 类的一个公共方法,用于在指定位置之后插入一个元素。此方法接受两个参数,第一个参数是表示链表中某个位置的迭代器,第二个参数是要插入的元素的值。以下是一个简单的示例,演示如何使用 InsertAfter 方法:// 假设你有一个 CList 对象 myListCList<int, int&> myList;// 添加一些元素到链表中myList.AddTail(10);myList.AddTail(20);// 使用 GetHeadPosition 获取链表头部的迭代器位置POSITION pos = myList.GetHeadPosition();// 在第一个元素之后插入一个新元素if (pos != NULL) { myList.InsertAfter(pos, 15);}// 循环遍历链表中的元素for (POSITION iter = myList.GetHeadPosition(); iter != NULL; myList.GetNext(iter)) { int nIte...
MFC CList 类 公共方法:CList::GetTailPosition
CList::GetTailPosition 是 MFC 中 CList 类的一个公共方法,用于获取链表的尾部位置的迭代器。它返回链表中最后一个元素的位置,可以通过这个位置迭代访问链表的所有元素。以下是一个简单的示例,演示如何使用 GetTailPosition 方法:// 假设你有一个 CList 对象 myListCList<int, int&> myList;// 添加一些元素到链表中myList.AddTail(10);myList.AddTail(20);myList.AddTail(30);// 使用 GetTailPosition 获取链表尾部的迭代器位置POSITION pos = myList.GetTailPosition();// 循环遍历链表中的元素while (pos != NULL) { // 使用 GetPrev 获取当前位置的元素,并将位置移动到前一个元素 int nItem = myList.GetPrev(pos); // 在这里你可以进行你的操作,nItem 包含链表中的元素值}在上述示例中,我们首先使用 Ge...
MFC CList 类 公共方法:CList::GetTail
CList::GetTail 是 MFC 中 CList 类的一个公共方法,用于获取链表的尾部元素。它返回链表中的最后一个元素的引用。以下是一个简单的示例,演示如何使用 GetTail 方法:// 假设你有一个 CList 对象 myListCList<int, int&> myList;// 添加一些元素到链表中myList.AddTail(10);myList.AddTail(20);myList.AddTail(30);// 使用 GetTail 获取链表尾部元素int nTail = myList.GetTail();// 在这里你可以使用 nTail,它包含链表中的最后一个元素的值在上述示例中,我们创建了一个 CList 对象 myList,并添加了三个整数元素到链表中。然后,我们使用 GetTail 获取链表中的尾部元素,并将其值存储在变量 nTail 中。请注意,模板参数 <int, int&> 指定了链表存储的元素类型和引用类型。在实际使用中,你需要根据你的需求修改这些类型。