CListCtrl::SortItems Sorts list view items using an application-defined comparison function.BOOL SortItems( PFNLVCOMPARE pfnCompare, DWORD_PTR dwData );
Parameters pfnCompare Address of the application-defined comparison function. The comparison function is called during the sort operation each time the relative order of two list items needs to be compared. The comparison function must be either a static member of a class or a stand-alone function that is not a member of any class.dwData Application-defined value that is passed to the comparison function.Return Value Nonzero if successful; otherwise zero.Res The index of each item changes to reflect the new sequence.The comparison function has the following form:int CALLBACK CompareFunc(LPARAM lParam1, LPARAM lParam2, LPARAM lParamSort);
The comparison function must return a negative value if the first item should precede the second, a positive value if the first item should follow the second, or zero if the two items are equivalent.The lParam1 parameter is the 32-bit value associated with the first item being compared, and the lParam2 parameter is the value associated with the second item. These are the values that were specified in the lParam member of the items' LVITEM structure when they were inserted into the list. The lParamSort parameter is the same as the dwData value.ExampleMyCompareProc(LPARAM lParam1, LPARAM lParam2, LPARAM lParamSort) { return lParam1 < lParam2; }
PFNLVCOMPARE pfnCompare,
DWORD_PTR dwData
);
Parameters
pfnCompare
Address of the application-defined comparison function. The comparison function is called during the sort operation each time the relative order of two list items needs to be compared. The comparison function must be either a static member of a class or a stand-alone function that is not a member of any class.dwData
Application-defined value that is passed to the comparison function.Return Value
Nonzero if successful; otherwise zero.Res
The index of each item changes to reflect the new sequence.The comparison function has the following form:int CALLBACK CompareFunc(LPARAM lParam1, LPARAM lParam2,
LPARAM lParamSort);
The comparison function must return a negative value if the first item should precede the second, a positive value if the first item should follow the second, or zero if the two items are equivalent.The lParam1 parameter is the 32-bit value associated with the first item being compared, and the lParam2 parameter is the value associated with the second item. These are the values that were specified in the lParam member of the items' LVITEM structure when they were inserted into the list. The lParamSort parameter is the same as the dwData value.ExampleMyCompareProc(LPARAM lParam1, LPARAM lParam2, LPARAM lParamSort)
{
return lParam1 < lParam2;
}
传过一个比较函数.
就可以自动排序了.