Sorting list based on integers in any column



Here is an extremely simple implementation for sorting, which is probably
sufficient for most needs.  The code determines which column in the
report was clicked, converts the text data for that column into item
data, then lets the list control perform its standard sorting.  The code
below sorts columns of integers; sorting text is even simpler.

1) Use Class Wizard to map the message LVN_COLUMNCLICK to the
ListView handler function OnColumnclick.  This will insert the line
ON_NOTIFY_REFLECT(LVN_COLUMNCLICK, OnColumnclick) into your derived
ListView message map.  Fill in the OnColumnclick function with the code
below. 

2) Add a comparison function to your derived ListView class.  The
function prototype should read: static int CALLBACK CompareFunc(LPARAM,
LPARAM, LPARAM).  The ListView framework calls this function to compare
ListView items (the first two function parameters).  Fill in the
function with the code below.  

void CMyListView::OnColumnclick(NMHDR* pNMHDR, LRESULT* pResult) 
{
    // Keep track of sort order and column used for sorting.

    static int nSortColumn = -1;
    static BOOL bSortAscending = TRUE;

    // Get the index of the column header that was clicked.

    NM_LISTVIEW* pNMListView = (NM_LISTVIEW*) pNMHDR;
    int iColumn = pNMListView -> iSubItem;

    // Reverse sort order if column was just previously clicked.

    if (iColumn == nSortColumn) { bSortAscending = !bSortAscending; }
    else                                    { bSortAscending = TRUE; }
    nSortColumn = iColumn;

    // Set item data for each row to column value,
    // since sort routine gets passed item data only.

    CListCtrl& ListCtrl = GetListCtrl();
    int nItems = ListCtrl.GetItemCount();

    for (int item=0; item<nItems item++)
    {
        CString text = ListCtrl.GetItemText(item, iColumn);

        int value = atoi(text);  // numeric sort
        if (!bSortAscending) { value = -value; }

        ListCtrl.SetItemData(item, value);
    }

    LPARAM lParamSort = 0;
    ListCtrl.SortItems(CompareFunc, lParamSort);
}

int CALLBACK CMyListView::CompareFunc(LPARAM lParam1, LPARAM lParam2,
LPARAM lParamSort)
{
    // First two parameters are item data to be compared.
    // Third parameter is passed from SortItems, not used here.

    if (lParam1 < lParam2) { return -1; }
    if (lParam1 > lParam2) { return  1; }
    return  0;
}



Comments

  • A problem...if the "itemdata" is already utilized to save some other information then...??

    Posted by aniketd on 04/26/2005 01:25am

    Yes, this is an helpful example but what if the listview control's "itemdata" needs to store some other information (e.g. Item Text Formatting information) in that case we cannot use the for loop to set the itemdata to item number... 
    
    for (int item=0; item

    Reply
  • How to sort text columns?

    Posted by Legacy on 02/22/1999 12:00am

    Originally posted by: varsh

    Sorting of integer columns works fine.I want to sort text columns when clicked on the column header using the
    SetItemData() and SortItems() method. How can i do?
    

    Reply
  • You must have javascript enabled in order to post comments.

Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • Complex hybrid environments can make it difficult to track interdependencies, increasing the risk of disrupting critical business services. In this white paper by EMA, you'll learn how application discovery and dependency mapping can help you: Meet granular targets for availability, cost, and time-to-revenue for cloud services. Accelerate mean time to repair (MTTR) while communicating better with stakeholders. Manage even the most complex hybrid environments more efficiently and effectively Understand the …

  • Rocket Mobile® for IBM i is an enterprise mobile application development and deployment platform for customers who rely on the IBM i system. Rocket Mobile for IBM i enables customers to leave proven applications in-place and rapidly repurpose them into new managed and secure mobile applications. Fast, easy creation of mobile, web, and hybrid mobile applications that deploy to any iOS, Android, or Windows mobile phone or tablet Built-in integration for seamless repurposing of existing IBM i applications …

Most Popular Programming Stories

More for Developers

RSS Feeds

Thanks for your registration, follow us on our social networks to keep up-to-date