c++ builder TListView控件按字符串排序(根据网上代码亲测ok)
//---------------------------------------------------------------------------
/*
首先将一个列表框控件安放在Form上,并将其名称设为ListView1。
然后在其中添加若干项目作为试验对象。方法为:用鼠标右键单击控件,
在弹出的对话框中选择Columns Editor用来添加列和子列;
再选Items Editor用来添加项目(包含子列和主列上的内容)。
为了显示出子项目内容,需要在Object Inspector中修改ListView属性值,
将ViewStyle设置为vsReport。另外,还必须将SortType设置为None,
以使我们的排序程序起作用。这样,程序的外观已经符合需要,
下面应该增加排序功能的代码了。为此需要添加类的方法到源代码中。
*/
void __fastcall TFormVBS::listViewColumnClick(TObject *Sender, TListColumn *Column)
{
int i,m,n,j;
static bool od=true; /* od代表用户点击的次数,奇数时为true,偶数时为false。
注意此处od的存储类型设定为static,可以保证其数值的连续性。
用n记录用户点击的列号,m记录列表框中的总项目数。*/
od=!od; n=Column->Index;
m=listView->Items->Count; /* 在列表框中临时添加一个项目作为排序中交换用的临时空间 */
listView->Items->Add(); /* 当用户点击第一列列标头时,
排序按listView->Items->Item[i]->Caption进行,
与其它列不同,所以要单独进行排序。 */ if (n==)
{
for(i=;i < m-;i++)
{
for(j=i+;j< m;j++)
{
if(od)
{
if(listView->Items->Item[i]->Caption >
listView->Items->Item[j]->Caption)
{
listView->Items->Item[m]= listView->Items->Item[i];
listView->Items->Item[i]= listView->Items->Item[j];
listView->Items->Item[j]= listView->Items->Item[m];
}
}
else
{
if(listView->Items->Item[i]->Caption < listView->Items->Item[j]->Caption)
{
listView->Items->Item[m]= listView->Items->Item[i];
listView->Items->Item[i]= listView->Items->Item[j];
listView->Items->Item[j]= listView->Items->Item[m];
}
}
}
}
} listView->Items->Delete(m);
return;
/* 编译运行程序后,即会看到我们预期的结果。
另外,本程序是按照字符串方式进行排序的,如果需要按照数字或其它方式排序,
只需进行相应的类型转换即可。
理解本程序后,读者即掌握了对ListView控件编程的一条基本思路,
对今后使用BCB以及对Windows编程起到良好作用。 */
}
//---------------------------------------------------------------------------
c++ builder TListView控件按字符串排序(根据网上代码亲测ok)的更多相关文章
- Delphi的TListView控件拖放选定行操作
http://www.tansoo.cn/?p=401 Delphi的TListView控件拖放选定行操作的例子,效果图如下:TListView控件拖动选定行到指定位置 具体实现步骤: 一.新建一个D ...
- Victor 串口 VCL 控件 - 简单实用, 功能强大的 C++ Builder 串口控件!
源:Victor 串口 VCL 控件 - 简单实用, 功能强大的 C++ Builder 串口控件! 2014年02月06日发布控件的重要更新版本: Victor 串口控件 1.5.0.2 版本 (包 ...
- C# WinForm中 让控件全屏显示的实现代码
夏荣全 ( lyout(at)163.com )原文 C#中让控件全屏显示的实现代码(WinForm) 有时候需要让窗口中某一块的内容全屏显示,比如视频播放.地图等等.经过摸索,暂时发现两种可行方法, ...
- 圆环,扇形控件基本算法一种实现 - 代码库 - CocoaChina_让移动开发更简单
圆环,扇形控件基本算法一种实现 - 代码库 - CocoaChina_让移动开发更简单 //// CircleCore.h// Quartz//// Created by 仙人掌 on 12 ...
- Duilib的控件拖拽排序,支持跨容器拖拽(网易云信版本)
完整代码见:https://github.com/netease-im/NIM_Duilib_Framework/pull/151 核心代码(思路): appitem.h #pragma once # ...
- 最佳实践扩展Windows窗体DataGridView控件 .net 4.5 附示例代码
Windows窗体DataGridView控件的性能调优.net 4.5 在处理大量数据时, DataGridView 控制可以消耗大量的内存开销,除非你仔细地使用它. 在客户有限的内存,你可以避 ...
- .net 用户控件ascx.cs注册js脚本代码无效果
在.net web项目中碰到一个比较奇怪的问题,网上没找到解决方案,先自己mark一下 问题描述: 添加一个用户控件ascx,在后端.cs添加js注册脚本,执行后没有弹出框 注册脚本为: this.P ...
- [iOS基础控件 - 6.7.1] 微博展示 代码
Controller: // // ViewController.m // Weibo // // Created by hellovoidworld on 14/12/4. // Copyrig ...
- [iOS基础控件 - 6.7] 微博展示 使用代码自定义TableCell(动态尺寸)
A.需求 1.类似于微博内容的展示 2.头像 3.名字 4.会员标志 5.内容 6.分割线 7.配图(可选,可有可无) code source: https://github.com/hellov ...
随机推荐
- HDU 2087 剪花布条(KMP,不可重叠重复子串)
给KMP传的数组一定要从0开始!! 显然,我们要先把模式串放到前面,之后主串放后面,中间隔开,这样就可以根据前缀数组的性质来求了. 这题和我上一篇博客类似,只不过不可重叠,我看了数据范围不大,所以就开 ...
- poj_2421_mst
D - Constructing Roads Time Limit:2000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I ...
- poj 1011 Sticks
Sticks Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 126238 Accepted: 29477 Descrip ...
- ylbtech-LanguageSamples-Threading(线程处理)
ylbtech-Microsoft-CSharpSamples:ylbtech-LanguageSamples-Threading(线程处理) 1.A,示例(Sample) 返回顶部 “线程处理”示例 ...
- linux 挂载(转载)
From:http://forum.ubuntu.org.cn/viewtopic.php?t=257333 用linux,就一定要用linux的方式去思维.嗯,说的容易做起来难.我的D盘哪去了?恐怕 ...
- netty中LengthFieldBasedFrameDecoder的使用
在org.jboss.netty.handler.codec.frame包中,有LengthFieldBasedFrameDecoder类用来解析带有长度属性的包,只要我们在传输协议中加入包的总长度就 ...
- SQL SERVER 中的 object_id()函数
在SQLServer数据库中,如果查询数据库中是否存在指定名称的索引或者外键约束等,经常会用到object_id('name','type')方法,做笔记如下: ? 语法:object_id('obj ...
- 20145305 《Java程序设计》第5周学习总结
教材学习内容总结 1.设计错误对象都继承自java.lang.Throwable类 2.Throwable有两个子类:java.lang.Error与java.lang.Exception 3.Err ...
- [Java] Steam文件输入流
package test.stream; import java.io.FileInputStream; import java.io.FileNotFoundException; import ja ...
- POJ - 2533 Longest Ordered Subsequence(最长上升子序列)
d.最长上升子序列 s.注意是严格递增 c.O(nlogn) #include<iostream> #include<stdio.h> using namespace std; ...