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 ...
随机推荐
- NeHe OpenGL教程 第二十五课:变形
转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...
- NeHe OpenGL教程 第十二课:显示列表
转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...
- Mongodb(1)如何存储以及简介
在学习一个数据库之前应该了解这个数据库是如何存储的,是不是适合你所需要的存储方式. 如果上来就说命令,理解起来似乎有点麻烦. 不管学习什么数据库都应该学习其中的基础概念,在mongodb中基本的概念是 ...
- jmeter测试某个QPS下的响应时间-设置QPS限制
本次性能测试的需求中提到测试的目的是“了解博客的首页在负载达到20 QPS时的响应时间”,因此需要控制向博客首页发送请求的负载为20QPS. 一种可行的方法是逐步调整测试计划中的线程计算的数量以及为取 ...
- 20145305 《Java程序设计》第3周学习总结
教材学习内容总结 1."一类一文件" 2.参考名称与对象数据成员同名时,可以在数据成员前使用this区别 3.不能用==直接比较浮点数运算结果 4.=是用在指定参考名称参考某个对象 ...
- 学习MVC框架的步骤
1.搭建环境 2.了解控制层和视图层的映射 3.控制层和视图层的传值 交互 4.异常处理 5.页面标签 6.文件上传 7.框架源代码
- Html5中的跨页面消息传输
1.如果要接受从其他的窗口那里发过来的消息,就必须对窗口对象的message事件进行监控. window.addEventListener("message",function() ...
- 使用go tool pprof分析内存泄漏、CPU消耗
go中提供了pprof包来做代码的性能监控,在两个地方有包: net/http/pprof runtime/pprof 其实net/http/pprof中只是使用runtime/pprof包来进行封装 ...
- POJ 1286 【POLYA】
题意: 给你三种颜色的珠子,每次给你N,问在旋转,翻转之后视作相同的情况下,能组成多少种不同的项链. 思路: 让我们借这道题拯救一下我对POLYA定理的理解... sigma(m^(gcd(i,n)) ...
- Contains DuplicateII
超时版: /*Contains Duplicate II Given an array of integers and an integer k, find out whether there the ...