barriers / 阅读 / 详情

车架号LVSHBFAF2AF102621

2023-07-20 07:43:47
TAG: bf fa f1 lv
共1条回复
可可

  车架号犹如人的指纹,如果车架号的钢板损坏,车主千万不可自行切割带车架号的钢板。必须保存车辆的受损模样,直接把车开到车管科进行认证,证明带车架号的钢板确实损坏了,然后,车管科会根据实际情况来处理。

  为什么不能让车主自行切割带车架号的那块钢板呢?如果允许车主自行这么做,就会有一个漏洞,盗车团伙有可能把事故车的车架号钢板切割下来,安装到赃车上,以往的路检中,经常碰到类似的案例,有人借口因为车架号钢板受损,所以自行切割下来贴在车身上,但最后这些车中有90%以上证明是赃车。

  车架号的含义

  1~3位(WMI):制造厂、品牌和类型; 世界制造厂识别代号( WMI)

  第一个字符:是标明一个地理区域的字母数字,如非洲、亚洲、欧洲、大洋洲、北美洲和南美洲。

  第二个字符:是标明一个特定地区内的一个国家的字母或数字。在美国,汽车工程师协会(SAE)负责分配国家代码。

  第三个字符:是标明某个特定的制造厂的字母或数字,由各国的授权机构负责分配。当制造厂的年产量少于500辆的时候,世界制造厂识别代码的 第三个字符就是9。

  美国的WMI前两位区段为1A-10,4A-40,5A-50:中国的WMI前两位区段为LA-LO,它规定了所有在中国境内生产的汽车产品的WMI编号必须在该区段内。

  以下就是国内常见汽车制造厂家的WMI编号:

  LSV上海大众LFV一汽大众LDC神龙富康

  LEN北京吉普LHG广州本田LHB北汽福田

  LKD哈飞汽车LS5长安汽车LSG上海通用4.4 VIN校验位

  ★ 2)4~8位:车辆特征;

  轿车:种类、系列、车身类型、发动机类型及约束系统类型;

  MPV:种类、系列、车身类型、发动机类型及车辆额定总重;

  载货车:型号或种类、系列、底盘、驾驶室类型、发动机类型、制动系统及车辆额定总重;

  客车:型号或种类、系列、车身类型、发动机类型及制动系统。

  ★ 3)第9位:校验位,按标准通过加权计算得到。

  ★ 4)第10位:车型年份(一般标识为车辆的出厂年份,是识别车辆的重要标识)

  ★ 5)第11位:车辆装配厂;

  ★ 6)12~17位:顺序号。

  VIN是英文Vehicle Identification Number(车辆识别码)的缩写。因为ASE标准规定:VIN码由17位字符组成,所以俗称十七位码。它包含了车辆的生产厂家、年代、车型、车身型式及代码、发动机代码及组装地点等信息。正确解读VIN码,对于我们正确地识别车型,以致进行正确地诊断和维修都是十分重要的。

  注意:为了避免和1、0相混淆,VIN中不会包含 I、O、Q 三个英文字母

  二、VIN码各位说明

  1、1~3位(WMI):制造厂、品牌和类型;

  第1位:生产国家代码

  1 美国 J 日本 S 英国

  2 加拿大 K 韩国 T 瑞士

  3 墨西哥 L 中国 V 法国

  4 美国 R 台湾 W 德国

  6 澳大利亚 Y 瑞典

  9 巴西 Z 意大利

  第2位:汽车制造商代码

  1-Chevrolet B-BMW M-Hyundai

  2-Pontiac B-Dodge M-Mitsubishi

  3-Oldsmobile C-Chrysler M-Mercury

  4-Buick D-Mercedes N-Infiniti

  5-Pontiac E-Eagle N-Nissan

  6-Cadillac F-Ford P-Plymouth

  7-GM Canada G-General M S-Subaru

  8-Saturn G Suzuki T-Lexus

  8-Isuzu H-Acura T-Toyota

  A-Alfa Romeo H-Honda V-Volkswagen

  A-Audi J-Jeep V-Volvo

  A-Jaguar L-Daewoo Y-Mazda

  L-Lincoln Z Ford

  Z-Mazda

  G=所有属于通用汽车的品牌:Buick, Cadillac, Chevrolet, Oldsmobile, Pontiac, Saturn

  第3位:汽车类型代码

  (不同的厂商有不同的解释)

  有些厂商可能使用前3位组合代码表示特定的品牌:

  TRU/WAU Audi 1YV/JM1 Mazda

  4US/WBA/WBS BMW WDB Mercedes Benz

  2HM/KMH Hyundai VF3 Peugeot

  SAJ Jaguar WP0 Porsche

  SAL Land Rover YK1/YS3 Saab

  YV1 Volvo

  2、4~8位(VDS):车辆特征:此类数据每个厂商给的数据都不一样,要找厂商具体查询,下面只写一些大概的数据类型。

  轿车:种类、系列、车身类型、发动机类型及约束系统类型;

  MPV:种类、系列、车身类型、发动机类型及车辆额定总重;

  载货车:型号或种类、系列、底盘、驾驶室类型、发动机类型、制动系统及车辆额定总重;

  客车:型号或种类、系列、车身类型、发动机类型及制动系统。

  3、第9位:校验位,按标准加权计算(参见《世界汽车识别代号(VIN)资料手册》P21~23)。

  4、第10位:车型年款

  B 1981 K 1989 V 1997 5 2005

  C 1982 L 1990 W 1998 6 2006

  D 1983 M 1991 X 1999 7 2007

  E 1984 N 1992 Y 2000 8 2008

  F 1985 P 1993 1 2001 9 2009

  G 1986 R 1994 2 2002

  H 1987 S 1995 3 2003

  J 1988 T 1996 4 2004

  5、第11位:装配厂,也就是第几分厂生产装配的;

  6、12~17位:顺序号,代表此车是该年该分厂生产的第几辆该型号的车。

相关推荐

ilvs wfn auko q ep wq 用五笔怎么翻译

wfnaukoqepwq伟燕我爱你追问:前面那个呢回答:ilvs这样打不出字,我一直是用五笔的。
2023-07-19 22:49:171

外泌体是做什么的?

外泌体(Exosomes)是一种双磷脂膜囊泡,含有蛋白、脂质及核酸等多种成分,是细胞外囊泡的一种。外泌体体积小,直径在40~200 nm,在透射电镜下具有典型的杯状结构。几乎所有的细胞都分泌外泌体,外泌体在细胞间的连接中发挥重要作用。01、外泌体的形成细胞发生内吞后,内陷的细胞膜形成数个小囊泡,小囊泡相互融合形成了早期内体(early endosome),逐渐成熟的早期内体膜多处凹陷并向内出芽形成含管腔状囊泡(intraluminal vesicle,ILVs)的晚期内体(late endosome);富含ILVs的内体称为多囊体(multivesicular body,MVBs)。MVBs有两个去向:一部分MVBs与溶酶体融合,以降解其内容物;另一部分MVBs与细胞膜融合,释放ILVs到细胞外,这些分泌的ILVs即为外泌体。02、外泌体的功能外泌体是一种细胞连接物,能够输送蛋白、脂质及核酸到靶细胞,可以在血管形成、抗原呈递、炎症反应和细胞增殖及分化等各种生物过程中发挥功能。外泌体可以通过两种途径影响受体细胞,其一,外泌体和受体细胞间的配体-受体相互作用,无需将外泌体或其内容物内化到靶细胞。其二,外泌体通过膜融合或内吞作用进入细胞,其成分被摄取后释放到细胞质中,通过调节特定的基因表达和信号通路影响宿主细胞,最终导致细胞功能或表型的改变。
2023-07-19 22:49:251

新手如何学习Linux?

新手linux学习路线
2023-07-19 22:49:3611

关于小米ilvs金属边框

垃圾边框 除了银白色 其他颜色边框都掉色
2023-07-19 22:50:152

LVS(IC设计时的版图验证步骤)详细资料大全

LVS全称为Layout Versus Schematics, 是 Dracula 的验证工具,用来验证版图和逻辑图是否匹配。LVS 在电晶体级比较版图和逻辑图的连线性,而且输出所有不一致的地方。 LVS 验证,LVS 的错误类型, LVS 验证 1 LVS 工作原理和基本流程 LVS全称为Layout Versus Schematics, 是 Dracula 的验证工具,用来验证版图和逻辑图是否匹配。LVS 在电晶体级比较版图和逻辑图的连线性,而且输出所有不一致的地方。Dracula 从图形系统中产生版图数据。Dracula 把 GDS2 格式的 Layout 档案转换为 Layout 网表,LOGLVS,Dracula网路编辑器,将 Schematic 或 CDL 描述的门级和电晶体级的网表转化为 LVS 网表。LVS 能够把每一个网路转化为一个电路模型。从一个电路的输入和输出开始,LVS 跟踪两种电路模型。Dracula 利用启发式每一次搜寻电路的一步。首先,LVS 跟踪、I/O 模型,然后搜寻要求最少回溯的路径。当 LVS 在跟踪的过程中检测到匹配的话,Dracula 就给这个匹配的器件和节点一个匹配的标识。当 LVS 检测到一个不匹配,它就停止在那个搜寻的路径。如果 LVS 指定了所有的器件和给出了一个匹配的标识的话或者在搜寻路径上没有一致的地方的话,LVS 会考虑到这两个模型的连续性。当 Dracula 检测到不一致的地方,它会以输出列表和图表形式表示出来。除了比较两个网路,LVS 也比较器件的衬底类型(在 COMS 电路中 NMOS 和 PMOS)和一些器件参数。 2 LVS 工具包括下列的检查 1) 版图与版图 版图与版图(LVL)是 LVS 的一部分,它是用来比较器件级或门级两个相似版图的 资料库,从而报出在互连关系和器件参数方面不一致的地方。 2) 逻辑与逻辑 逻辑与逻辑(SVS)是 LVS 的一部分,它是来比较两个逻辑图的。 3) 版图与逻辑 版图与逻辑(LVS)是用来确认版图和逻辑图是否一直工作。LVS 比较版图和逻辑图 在电晶体级的连线是否正确,并以报告的形式列出差异之处。 LVS 的错误类型 LVS 的错误类型大体分为两类:不一致的点和失配器件。不一致点可分为节点不一 致和器件不一致。节点不一致是指版图和逻辑图中各有一节点,这两个节点所连器件的 情况相似,但是又不完全相同。器件不一致是指版图和逻辑图各有一器件,这两个器件 相同,所连线的节点情况很相似,但又不完全相同。失配器件是指所有的器件在逻辑图 中有而在版图中没有,或在版图中有而在逻辑图中没有。具体来讲,LVS 的错误类型有 以下十五种: 1) 匹配的节点上没有器件; 2) 匹配的器件上有不匹配的节点; 3) 器件不匹配; 4) 匹配的节点上有多余的版图器件; 5) 匹配的节点上有多余的线路图器件; 6) 匹配的节点上有非匹配的版图和线路图器件; 7) 其他不匹配的版图器件; 8) 其他不匹配的线路图器件; 9) 器件的类型(N 型和 P 型,多晶电阻或扩散电阻)不匹配; 10) 器件得尺寸(W 或 L)不匹配; 11) MOS 可逆性错误; 12) 衬底连线不匹配; 13) 器件的电源连线不匹配(多电源供电的情况); 14) 简化多个 MOS 拼接为单个 MOS 时出错(与 LVSCHK 中命令得 K 选项有关); 15) 过滤多余的器件出错(与 LVSCHK 中命令的 F 选项有关)。 LVS 错误既指单个器件、单个节点,又指组合结构(子电路)。不匹配的子电路(子 电路中有多个器件和节点)往往只是其中的一个和几个节点或器件不匹配,并不是所有 的都不匹配。与一个不匹配点关联的一切器件和节点都作为错误的个数,LVS 报告文 件里分别列出了每一个不匹配点。错误报告与人们通常的理解有出入,例如:两根信号 线调换了位置,按常理来说,只能算一个错误,但 LVS 报告有两个错误。
2023-07-19 22:50:221

linux基础知识有哪些

Linux启动过程启动流程:操作系统->/boot -> init进程 -> 运行级别 -> /etc/rc.d->用户登录->login shell内核的引导:首先是BIOS开机自检,按照BIOS中设置的启动设备(通常是硬盘)来启动,操作系统接管硬件以后,首先读入 /boot 目录下的内核文件运行init进程:init 进程是系统所有进程的起点,没有这个进程,系统中任何进程都不会启动,init程序首先是需要读取配置文件 /etc/inittab,init进程的任务之一是运行开机启动的程序;许多程序需要开机启动。它们在Windows叫做"服务"(service),在Linux就叫做"守护进程"(daemon)Linux关机正确的关机流程为:sync>shutdown>reboot>haltsync:将数据有内存同步到硬盘中shutdown:关机指令;Linux文件属性通过命令 ll或 ls-l可以查看某个目录下所有的文件以及文件类型、权限、属组等更为详细的介绍可以查阅下相关资料,比如《Linux就该这么学》。
2023-07-19 22:50:322

有帮忙解释新福克斯驾驶座挡风玻璃条形码代码ILVSHCFDB2DE209731 8287 代表什么意思不?有代表生产日期?

这是汽车的VIN码LVS---长安福特(全球制造厂识别符号)H-------主动安全带,驾驶员及乘客安全气囊,驾驶员及乘客侧向安全气囊,窗帘或活动顶棚(车辆约束系统形式)C-------福克斯 (车型)F-------4门 (车身类型)D-------POWERSHIFT双离合变速器 (变速箱类型)B-------1.6L (发动机类型)2--------内部校验码D--------2013年(生产日期)E--------生产工厂后面是的是顺序号所以你的车应该是新福 CAF7163A4型 三厢1.6AT风尚版。2013年制造的。你可以自己查一下http://www.chinacar.com.cn/vin_index.html
2023-07-19 22:50:391

基于lvs实现4层负载均衡

章文嵩:研发,原就职alibaba公司,目前就职滴滴; lvs:2部分组成 ipvsadm:用户空间的命令行工具;用于管理集群服务及集群服务上的RS; ipvs:是内核中的框架;工作于内核上的netfilter的INPUT钩子上的程序,可根据用户定义的集群实现请求转发; 注意:在lvs主机上,不允许在INPUT链上添加规则,一般不建议与ipvs一同使用filter规则;更不能使用nat规则,任何链接追踪功能都不能开启,链接会话表就限制了会话能力,否则,并发响应能力将大大受到限制; 支持基于TCP UDP SCTP AH EST AH_EST等协议及端口进行调度; 以下部分内容摘自于: https://www.jianshu.com/p/5184c6564ee2 多目标的DNAT;通过将请求报文中的目标地址和目标端口修改为挑选出的某RS的RIP和PORT实现转发; ipvs工作在INPUT链上,所以只有在INPUT链上才能判断出集群服务,然后才能向后转发,转发时,基于某种调度算法,ipvs自动从后端主机中挑选出一个来响应用户请求,挑选出的主机IP会成为报文目标IP的修改对象; 定义负载均衡集群服务时,要定义集群服务,集群服务的真实主机; 上图为lvs-nat的常见的使用场景,其工作流程如下: 1、客户端的请求发往Director 的VIP。 2、Director发到客户端请求报文后,将报文中的目标Ip修改为集群中的选定的RIP,目标端口80也修改成8080,然后将请求报文发往RS。 3、当RS收到请求报文后,在检查报文的目标IP为自己的RIP后,会接受报文并进行处理响应。响应的源Ip为RIP,目标IP为CIP,端口不变。 4、Director收到RS的响应报文,修改响应报文的源IP为VIP,端口为80,然后转发给客户端。 5、客户端接受响应报文,其源IP为VIP,端口为80,整个过程对于客户端来说是透明无感知的。 通过修改请求报文的MAC地址,重新封装一个MAC首部进行转发;源MAC是DIP所在接口的MAC地址,目标MAC是挑选出的某RS的RIP所在接口的MAC地址;IP首部不会发生变化(依然是CIP<-->VIP) lvs服务主机与后端服务器主机接在同一交换机上,且每个后端主机都配有vip,为了避免地址冲突,把各后端主机配置的vip进行隔离; 隔离的方法有3种 (1)确保前端路由器将目标IP为VIP的请求报文转发往Director; (2)RS的RIP可以使用私有地址,也可以使用公网地址; (3)RS跟Director必须在同一物理网络(基于MAC地址转发);RS的网关必须不能指向DIP; (4)请求报文必须由Directory调度,但响应报文必须不能经由Director; (5)不支持端口映射; (6)RS可以使用大多数的OS;一般都为Linux系统; 上图为lvs-dr的常见的使用场景,其工作流程如下: 1、客户端的请求会发往Director,此时,客户端请求报文的源Ip为CIP,目标Ip为Director的VIP。 2、当Director接受到客户端的请求报文后,Director会在请求报文外封装一个MAC首部,其源MAC为Director接口的MAC地址,目标MAC为选定RS的MAC地址; 3、当RS收到Director转发过来的请求报文后,检查发现请求报文的目标Ip为本地环回接口上配置的VIP,因此会接受报文进行响应处理。另外由于对ARP响应规则做了修改,因此RS不会把响应报文响应给director ,而是响应给GW; 4、客户端接收响应报文,完成通信。 请求报文源IP为cip,目标IP为vip,到达lvs服务进入INPUT链上,在整个ip报文外又加了一层ip首部,即IP报文传输IP报文所以叫IP隧道,此时外层源IP为dip,目标IP为某一个被挑选出来远端的rip,远端的服务主机收到报文经过不断拆包后,将响应报文发给客户端,构建响应报文的源IP为rip,目标IP为cip; (1)RIP,DIP,VIP全得是公网地址; (2)RS网关不能指向也不可能指向DIP; (3)请求报文经由Director转发,但响应报文将直接发往CIP; (4)不支持端口映射; (5)RS的OS必须支持隧道功能; (1)VIP是公网地址,RIP和DIP一般是私网地址,且通常不再同一网络中,但需要经由路由器互通; (2)RS收到的请求报文源IP为DIP,因此响应报文将直接响应给DIP; (3)请求和响应报文都经由Director; (4)支持端口映射; (5)RS可以使用大多数的OS; 负载均衡集群中会话保持的方式 (1)原地址哈希; (2)会话集群; (3)会话服务器; 如上图所示: 1.客户端的请求会发往Director,此时,客户端请求报文的源IP为CIP,目标IP为Director的VIP 2.当Director收到客户端的请求报文时,会将源IP修改为本机的DIP,同时将请求报文中的目标IP修改为后端某个RS的RIP,具体为哪个RS的RIP,取决于LVS使用的具体算法 3.当RS收到对应的请求报文时,会发现报文的目标IP就是自己的RIP,于是就会接收报文并处理后进行响应。响应报文的源IP则为RIP,目标IP则为DIP 4.当Director收到对应的响应报文时,Director会将响应报文的源IP修改为VIP,目标IP修改为CIP,于是响应报文被发往客户端。 5.客户端则会收到响应报文,源IP为VIP,端口为80,而LVS相对于客户端而言,转换过程是透明的。 根据其调度时是否考虑后端主机的当前负载,可分为 静态方法 和 动态方法 两类 基于客户端瘦cookie+服务器端的session机制,在负载均衡时,同一用户被调度不同后端服务器时,为了保持会话连接功能不丢失;当第一次用户请求时,通过调度机制给该用户分配了一个负责响应后端服务器,以后来自该用户的请求就由这个服务器负责响应了,而不再调度,这就叫 源地址哈希 ; 在调度器上有会话追踪表,在这个会话追踪模板中,把用户的IP地址和挑选的后端服务器对应的记录下来,而且定义一个超时时长,在定义的时间内该条目不会删除;所以,用户请求到来时,先检查这个表,把原IP当做k查找,因为哈希就是k/v数据,对应的v就是后端的真实服务器;如果检查有用户的IP对应的记录,则直接将请求报文发给记录中对应的后端真实服务器,而不通过调度; 缺陷 :当记录的真实服务器挂了时,就没有会话保持记录了;当内网用户同过同一IP地址访问外网时,可能会把内网用户的所有请求都发往会话记录表上的真实服务器,这样负载均衡能力是受到损害的; 解决办法 内网用户请求的目标地址,在调度器上把目标地址绑定到一个代理缓存服务器上,以后,任何用户访问的是该目标地址就发往绑定的代理服务器,代理服务器收到请求后,再发往后端服务器主机,从而实现正向代理负载均衡的作用; ipvs功能特别强大,一般网站用到的可能性比较小,但面试必会问到; 如果负载不是特别大,使用配置比较麻烦,维护成本较大; ipvs/ipvsadm的关系相当于netfilter/iptables的关系; 真正提供lvs服务的是ipvs; 因为是根据请求的目标ip地址和目标端口(能识别协议)进行转发;一个ipvs(Director)主机就可同时为多个集群提供服务进行调度;这就是四层交换的原因;只不过一个Director很有可能成为负载均衡的瓶颈; 注意:单个Director可同时为多个集群提供调度服务; 在centos 7系统上: 判断内核是否支持ipvs: 判断ipvsadm程序包是否安装 ipvsadm -A|E -t|u|f service-address [-s scheduler] -A:增,添加 -E:修改 ipvsadm -D -t|u|f service-address -D:删除集群服务; service-address:定义集群服务的地址 -t:tcp,把tcp端口定义成集群服务,vip:tcp_port; -u:udp,把udp端口定义成集群服务,vip:udp_port; -f:Firewalls mark防火墙标记,是一个数字; -s scheduler:定义集群服务的调度方法,默认为wlc加权最少连接; ipvsadm -a|e -t|u|f service-address -r server-address [-g|i|m] [-w weight] -a:增,添加RS; -e:改,修改RS; ipvsadm -d -t|u|f service-address -d:删除 -r server-address:向已存在的service-address(集群服务)添加RS的地址; rip[:port] 端口省略时,表示不做端口映射,与请求服务的端口为同一端口;有些集群服务不支持端口映射,如lvs-dr,lvs-tun,只要响应报文不经过Director都不支持; 查看: ipvsadm -L|l [options] -L,--list:列出集群服务; -n, --numeric:数字格式显示,不反解主机名到ip地址,服务到端口号; --exact:精确显示数值,不进行单位换算; -c, --connection:显示当前ipvs连接;可查看后端服务器是否连接; --stats:统计数据; --rate:速率; 清空 :clear ipvsadm -C 保存和重载 保存:输出重定向 ipvsadm -S > /PATH/TO/SOME_RULE_FILE ipvsadm-save > /PATH/TO/SOME_RULE_FILE 重载:输入重定向 ipvsadm -R < /PATH/TO/SOME_RULE_FILE ipvsadm-restore < /PATH/TO/SOME_RULE_FILE 清空计数器: ipvsadm -Z [-t|u|f service-address] 例如: 例如: 添加集群服务,vip为172.18.11.111提供web服务,指明调度方法为rr;不指明为默认wlc; 在集群服务中添加RS地址为192.168.255.2,类型为lvs-nat,权重为1此值无意义,因为前面已经指明使用rr调度算法 再次添加一个RS 再次添加一个集群服务 在另一个集群服务上添加2个RS 修改集群服务的调度方法为wrr 注意:修改只能改属性,不能改IP地址;只有删除集群服务才能从新改IP地址; 修改RS的权重值为10 保存集群服务规则至指定路径 查看保存的内容: 清空集群服务 重载集群服务配置文件 下次开机时会自动载入集群服务规则: 所以,可把规则保存在/etc/sysconfig/ipvsadm文件中; [root@VM_0_2_centos ~]# ipvsadm-save > /etc/sysconfig/ipvsadm 一般手动保存后(确保保存无误),下次开机时,会自动重载此文件; 需要开机自动有效: [root@VM_0_2_centos ~]# systemctl enable ipvsadm.service lvs-nat设计要点: (1)DIP与RIP要在同一IP网络,RIP的网关要指向DIP; (2)支持端口映射; (3)是否用到共享存储,取决于业务需要; 1、配置RS1 2、配置RS2 3、配置Director 打开网卡核心转发功能;永久有效: 查看内核参数是否打开核心转发功能 此时,在Director测试,访问RS1、RS2; 添加ipvs集群: 在另一台虚拟机上测试,调度是否起作用: 测试主机为:172.18.11.111 修改Director上的调度方式为wrr 再到测试主机为:172.18.11.111,测试wrr的调度效果 经过多次请求测试后,有明显wrr调度效果; 其RS服务器响应权重比是1:2,即RS1响应1次后RS响应2次; 数据同步:rsync+inotify 响应报文不用经过Director,每个RS必须配置VIP,为了避免地址冲突,有3种方式: 在各主机(Director,RS)均需要配置VIP,因此,要解决地址的冲突的问题,目标是让各RS上的VIP不可见,仅用接收目标地址为VIP的报文,同时可作为响应报文的源地址; (1)在前端的网关接口上静态绑定(vip+mac); 缺陷:一旦Director挂了,基于高可用转移另外节点上无法实现;而且,要在网关上有权限操作; (2)在各RS上使用arptables;添加规则,拒绝自己的VIP地址向外通告及响应arp解析地址的请求; (3)在各RS上修改内核参数,来限制arp响应和通告; 注意:要将VIP配置在lo的别名上,不能配置在网卡的别名上; 在各RS上设置arp通告级别即修改两个内核参数arp_ignore、arp_announce,因为地址是属于内核的,所以在Linux主机默认的通告方式是所有本机的可用IP地址通告给每个接口; arp_announce要限制通告级别,每一个网卡仅在把自己的网络地址向所在物理网络中通告,即各网卡间地址绝不交叉通告;arp_announce设置为2; arp_ignore是限制响应别人arp请求的级别;默认响应请求是无论从哪个接口接收到arp请求,只要本机有这个地址都会响应;限制arp响应级别后可实现,从哪个网卡接收的arp请求, 必须与该接口属于同一网络时才响应;arp_ignore`设置为1 lvs-dr设计要点: (1)各主机一个接口即可,但需要在同一物理网络中; (2)RIP的网关不能指向DIP,RIP和DIP通常应在同一网络,但此二者未必会与VIP在同一网络; (3)各RS需要先设置内核参数,再设置VIP和路由; 搭建网络环境 1、配置Director 2、配置RS1 3、配置RS2 4、访问测试 在RS2主机运行 在报文进入时,进行打标记,例如目标IP是VIP端口80,把这类报文分拣出来打标,标记一般为十六进制整数,例如标记1;在input链上定义集群服务时,就可判定如果防火墙标记为1,则为集群服务;把本来在input链上完成识别、定义集群服务分成了两步,识别在prerouting做,定义在ipvs(inputing)上实现; 在mangle表上的prerouting链上,目标ip(VIP)为172.18.11.7,目标端口为80,打标记为1; mark标记里包含了IP地址和端口;定义集群服务时使用mark即可; 打标记的方法: iptables -t mangle -A PREROUTING -d $vip -p $protocol --dport $clusterserverport -j MARK --set-mark # #:代表十六进制整数; 打标作用 :提供辅助持久连接功能;在多个端口定义服务时,可把相关作为一个集群来调度; 配置RS1: 配置RS2: 在Director创建CA: 在RS1主机: 在CA服务上签证并传回给RS1: 在各RS主机重启web服务并查看443端口是否监听: 手动测试直接访问RS的IP: 测试请求,OK可以响应页面;-k表示可接受不受信任的页面响应; 单机测试ok,下面绑定80和443服务,打标记:
2023-07-19 22:50:461

Lvs ip-tun(ip隧道)的原理和实现

采用Nat技术时,由于请求和响应报文都必须经过调度器地址重写,当客户请求越来越多时,调度器的处理能力将成为瓶颈。为了解决这个问题,调度器把请求报文通过IP隧道转发至真实服务器,而真实服务器将响应直接返回给客户,所以调度器只处理请求报文。由于一般网络服务器应答比请求报文大许多,采用VS/TUN技术后,集群系统的最大吞吐量可以提高10倍。 实验规划: (1).将物理机上的VMnet1网卡的ip设置为200.168.10.4,子网掩码设置为255.255.255.0 (2).为Lvs服务器配置一块网卡eth0,网络连接设置为VMnet1,设置IP地址:ifconfig eth0 200.168.10.1 (3).为两台真实服务器配置一块网卡,网络连接设置为VMnet1,设置IP地址:ifconfig eth1 200.168.10.2和ifconfig eth1 200.168.10.3 (4).为Lvs服务器和两台真实服务器都配置一个tunl0网卡,配置为单独的网段:ifconfig tunl0 200.168.10.10 netmask 255.255.255.255 up,route add -host 200.168.10.10 dev tunl0 (5).Lvs ip-tun服务器脚本: ipvsadm -C ipvsadm -A -t 200.168.10.10:80 -s rr(-t:采用tcp协议;-s:模式参数;rr:采用轮叫算法) ipvsadm -a -t200.168.10.10:80 -r 200.168.10.2 -i(-r:真实服务器ip;-i:ip-tun模式) ipvsadm -a -t200.168.10.10:80 -r 200.168.10.3 -i (6).真实服务器脚本: echo "1" > /proc/sys/net/ipv4/conf/tunl0/arp_ignore echo "2" > /proc/sys/net/ipv4/conf/tunl0/arp_announce echo "1" > /proc/sys/net/ipv4/conf/all/arp_ignore echo "2" > /proc/sys/net/ipv4/conf/all/arp_announce 注:目前只有Unix/Linux版本的操作系统才具备ip-tun网卡
2023-07-19 22:50:531

钻石LVS1是什么等级?

应该是L色VS1净度的;常见钻石颜色分为DEFGHIJKLMN共十一个等级,H色及以上没有黄色调,以下会有不同程度的黄色调,L色属于偏低颜色等级,肉眼可以看到明显黄色调,预算充足的话,不太推荐;净度等级分为FL,IF,VVS1,VVS2,VS1,VS2,SI1,SI2,I1,I2,I3共十一个等级,VS2及以上理论上肉眼看不到瑕疵,以下会有不同程度的可见包体,VS1算是中等偏上一点,肉眼可以做到100%干净的,净度等级没有问题;等级信息不明确,没有给出的切工等级也非常的重要,钻石效果是所有参数综合的结果,要平衡,不能单方面追逐某个参数;
2023-07-19 22:51:001

linux LVS NAT模式连接不到

可以试一下重启电脑
2023-07-19 22:51:322

茶叶有哪些产地

和i
2023-07-19 22:51:5811

牙齿矫正的年龄是多少岁

牙齿矫正合适的年龄是11-14岁,这个时期儿童刚换完牙,乳牙已经全部脱落,恒牙全部长出了,这时候进行牙齿矫正效果比较好。成年人做牙齿矫正是没有年龄的限制,因为成年人骨骼已经形成了,但是成年人矫正的效果是没有未成年矫正效果好的,恢复时间也没有未成年恢复得快,所以做牙齿矫正是越早越好。
2023-07-19 22:52:277

读《夏洛的网》 你有什么收获?

https://m.baidu.com/from=1001190c/bd_page_type=1/ssid=0/uid=0/baiduid=8CC7560A62444DB2BA8E583ACD35B389/w=0_10_/t=zbios/l=1/tc?ref=www_zbios&pu=sz%401320_480%2Ccuid%400iHK8gO6Ba_pa2tD_uBD80O6SilgiBio08Hha_O_28i-u2t__uv18_a62igua2tDA%2Ccua%40_avLC_aE-i4qywoUfpw1z4aS2N_-h2N5guL5ixLqA%2Ccut%40fJx46qIDv8yDaXiDyuvGCfJDx6qVC%2Cosname%40baiduboxapp%2Cctv%402%2Ccfrom%401014610i%2Ccen%40cuid_cua_cut%2Ccsrc%40app_serchresult_voice%2Cta%40zbios_2_6.0_6_10.3%2Cusm%402%2Cvmgdb%400020100228y&lid=12865621284047033495&w_qd=IlPT2AEptyoA_yk5735bzxevFS2Uf-EowioWlvS&wd=&eqid=b28bde6492541800100000005a7e9aab&order=5&fm=wnor&dict=-1&tj=www_zhidao_normal_5_0_10_l1&tcplug=1&sec=27535&di=a6846d3502689702&bdenc=1&tch=124.72.80.962.0.0&nsrc=IlPT2AEptyoA_yixCFOxCGZb8c3JV3T5AAyNLCpZ0XSwnESzbbrgHtkfEFXeRXqJF5z7uiPQpxwCw8Kh0GQk6so4g43&clk_info=%7B%22srcid%22%3A1529%2C%22tplname%22%3A%22www_zhidao_normal%22%2C%22t%22%3A1518246573422%2C%22xpath%22%3A%22div-div-div-a-div2%22%7D
2023-07-19 22:53:078

js实现数字滚动,就和摇奖一样,数字滚动中,按一下停止按钮,数字就可以停止了,具体怎么实现这个功能啊

我刚好做了一个flash的 摇奖 程序,我吧代码给你吧!如果要全部的就不好发了:这段是注入txt文本就是需要抽奖人的名单列表:UserList.txt ,中奖名单列表:Save.txt第一帧代码:System.useCodepage = true;var UserList:String = "";var AwardUsers:String = "";var nowAwardUser:String = "";var Users:Array;var Users1:Array=new Array();var Users2:Array=new Array();var lv:LoadVars = new LoadVars();var lvs:LoadVars = new LoadVars();lv.onData = function(s) { if (s !== undefined) { UserList = s; Users = UserList.split(" "); for (var i = 0; i<Users.length; i++) { var infos:Array = Users[i].split(" "); if (infos[2].toString() == "2") { Users1.push(infos[0].toString()+" "+infos[1].toString());//能抽所有奖 } Users2.push(infos[0].toString()+" "+infos[1].toString());//不能抽一等奖的人 } }};lv.load("UserList.txt");lvs.onData = function(s) { if (s !== undefined) { AwardUsers = s; }};lvs.load("fscommand/Save.txt");点击停得代码:我只给出一二等奖的三等奖的和着差不多on (release) { var AwardUser:String = ""; //for (var i = 0; i<random(Users.length-1); i++) { var intlength:Number; if (a == "一") { intlength = random(Users1.length-1); AwardUser = Users1[intlength].toString(); for(var i=0;i<Users2.length;i++){ if(Users[i].toString()==Users1[intlength].toString()){ Users2.splice(i,1); } } Users1.splice(intlength,1);//移除已经出现过的人员 } else if (a == "二") { intlength = random(Users2.length-1); AwardUser = Users2[intlength].toString(); for (var i = 0; i<Users1.length; i++) { if (Users1[i].toString() == Users2[intlength].toString()) { Users1.splice(i,1); } } Users2.splice(intlength,1);//移除已经出现过的人员 } //} a1.text = AwardUser; var nowdate:Date = new Date(); var year:Number = nowdate.getFullYear();//年 var month:Number = nowdate.getMonth()+1;//月 var date:Number = nowdate.getDate();//日 var hours:Number = nowdate.getHours();//小时 var minutes:Number = nowdate.getMinutes();//分钟 var seconds:Number = nowdate.getSeconds();//秒 var datetime:String = year+"-"+month+"-"+date+" "+hours+":"+minutes+":"+seconds; var nowif:String = ""; if (a == "一") { nowif = AwardUser+" 一等奖 "+datetime+" "; } else if (a == "二") { nowif = AwardUser+" 二等奖 "+datetime+" "; } nowAwardUser = nowAwardUser+nowif; System.setClipboard(AwardUsers+nowAwardUser); fscommand("exec", "bcwj.exe"); //t2.text = random(9); //t3.text = random(9); //t4.text = random(9); play();}至于你说的那个数字滚动效果没做,我看代码比较麻烦就没写,我滚动用的随机滚动影片剪辑就是自己用姓名分开,做几个影片剪辑有效果,比用代码用的好,而且没那么卡,很实用。希望能帮到你。
2023-07-19 22:53:241

如何搭建亿级并发的系统架构?

分布式+缓存
2023-07-19 22:53:321

如何查看keepalived的日志文件

#不断打印输出最近Keepalived_vrrp日志 tail -f /var/log/messages|grep Keepalived_vrrp或者//查询最近3000行中keepalived日志 tail -3000 /var/log/messages|grep Keepalived_vrrp
2023-07-19 22:53:403

百度百科是不是就是wiki?

你在百度里搜百科
2023-07-19 22:53:4813

如何优化mysql写入速

1. 一条SQL语句插入多条数据。常用的插入语句如:INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`) VALUES ("0", "userid_0", "content_0", 0);INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`) VALUES ("1", "userid_1", "content_1", 1);修改成:INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`) VALUES ("0", "userid_0", "content_0", 0), ("1", "userid_1", "content_1", 1);修改后的插入操作能够提高程序的插入效率。这里第二种SQL执行效率高的主要原因有两个,一是减少SQL语句解析的操作, 只需要解析一次就能进行数据的插入操作,二是SQL语句较短,可以减少网络传输的IO。这里提供一些测试对比数据,分别是进行单条数据的导入与转化成一条SQL语句进行导入,分别测试1百、1千、1万条数据记录。记录数 单条数据插入 多条数据插入1百 0.149s 0.011s1千 1.231s 0.047s1万 11.678s 0.218s2. 在事务中进行插入处理。把插入修改成:START TRANSACTION;INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`) VALUES ("0", "userid_0", "content_0", 0);INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`) VALUES ("1", "userid_1", "content_1", 1);...COMMIT;使用事务可以提高数据的插入效率,这是因为进行一个INSERT操作时,MySQL内部会建立一个事务,在事务内进行真正插入处理。通过使用事务可以减少数据库执行插入语句时多次“创建事务,提交事务”的消耗,所有插入都在执行后才进行提交操作。这里也提供了测试对比,分别是不使用事务与使用事务在记录数为1百、1千、1万的情况。记录数 不使用事务 使用事务1百 0.149s 0.033s1千 1.231s 0.115s1万 11.678s 1.050s性能测试:这里提供了同时使用上面两种方法进行INSERT效率优化的测试。即多条数据合并为同一个SQL,并且在事务中进行插入。记录数 单条数据插入 合并数据+事务插入1万 0m15.977s 0m0.309s10万 1m52.204s 0m2.271s100万 18m31.317s 0m23.332s从测试结果可以看到,insert的效率大概有50倍的提高,这个一个很客观的数字。注意事项:1. SQL语句是有长度限制,在进行数据合并在同一SQL中务必不能超过SQL长度限制,通过max_allowed_packe配置可以修改,默认是1M。2. 事务需要控制大小,事务太大可能会影响执行的效率。MySQL有innodb_log_buffer_size配置项,超过这个值会日志会使用磁盘数据,这时,效率会有所下降。所以比较好的做法是,在事务大小达到配置项数据级前进行事务提交。
2023-07-19 22:54:352

金州去登沙河公交车票价多少啊?

到登沙河汽车站(客运站)乘坐;消脊登沙河汽车站-金州新区此含中心汽车站(坐2站)到金州新区中心汽车站(长途站)转乘;金州新区中心汽车站-站南汽车站(坐4站)到站南汽车站(客运站森桥笑)下,走到大连火车站(长江路)转乘;大连火车站-夏家河子(坐16站)到商务学院站下。约2小时15分《sport.g622.cn/article/510427.html》《sport.51pztc.cn/article/170946.html》《sport.1xfund.cn/article/043518.html》
2023-07-19 22:54:583

JBoss和Tomcat部署方式的区别

在Web2.0的浪潮中,各种页面技术和框架不断涌现,为服务器端的基础架构提出了更高的稳定性和可扩展性的要求。近年来,作为开源中间件的全球领导者,JBoss在J2EE应用服务器领域已成为发展最为迅速的应用服务器。在市场占有率和服务满意度上取得了巨大的成功,丝毫不逊色于其它的非开源竞争对手,如WebSphere、WebLogic、Application Server。JBoss Web的诸多优越性能,正是其广为流行的原因。  基于Tomcat内核,青胜于蓝  Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可。其运行时占用的系统资源小,扩展性好,且支持负载平衡与邮件服务等开发应用系统常用的功能。作为一个小型的轻量级应用服务器,Tomcat在中小型系统和并发访问用户不是很多的场合下被普遍使用,成为目前比较流行的Web 应用服务器。  而JBoss Web采用业界最优的开源Java Web引擎, 将Java社区中下载量最大,用户数最多,标准支持最完备的Tomcat内核作为其Servlet容器引擎,并加以审核和调优。单纯的Tomcat性能有限,在很多地方表现有欠缺,如活动连接支持、静态内容、大文件和HTTPS等。除了性能问题,Tomcat的另一大缺点是它是一个受限的集成平台,仅能运行Java应用程序。企业在使用时Tomcat,往往还需同时部署Apache Web Server以与之整合。此配置较为繁琐,且不能保证性能的优越性。  JBoss在Tomcat的基础上,对其进行本地化,将Tomcat 以内嵌的方式集成到 JBoss 中。JBoss Web通过使用APR和Tomcat本地技术的混合模型来解决Tomcat的诸多不足。混合技术模型从最新的操作系统技术里提供了最好的线程和事件处理。结果,JBoss Web达到了可扩展性,性能参数匹配甚至超越了本地Apache HTTP服务器或者IIS。譬如JBoss Web能够提供数据库连接池服务,不仅支持 JSP 等 Java 技术,同时还支持其他 Web 技术的集成,譬如 PHP、.NET 两大阵营。  标准化是减小技术依赖风险,保护投资最好的方式。JBoss Web率先支持全系列JEE Web标准,从根本上保证了应用“一次开发,到处运行”的特点,使应用成品能方便地在JBoss Web和其他Java Web服务器之间轻易迁移。  集多功能于一身,性能卓越  作为Web 应用服务器中的明星产品,JBoss Web服务器集多种功能于一身。其关键功能包括:完全支持Java EE、高度的扩展性、快速的静态内容处理、群集、OpenSSL、URL重写和综合性。  JBoss Web服务器具有原生特性和强大的可扩展性,可支持多种并非基于Java的服务器内容处理技术,可同时运行JSP, Servlet, Microsoft .NET , PHP 及 CGI,为其提供一个单一的、高性能的企业级部署平台。  与Tomcat 相比,JBoss Web在静态资源访问方面性能优越。JBoss Web支持两种组件模式——纯Java和Native I/O。在Native组件的支持下,动态运行不会受到任何影响,而静态资源的访问利用了操作系统本身提供的0拷贝传送,CPU消耗降低,响应时间缩短,吞吐率大大提高,混合的连接模式支持最大达到10000个并发客户端的同时访问,与Apache Web服务器相当。部署于高性能的操作系统,可利用JBoss Web对纯Java和Native I/O两种模式的支持,使得应用在开发时可随时跨平台敏捷迁移,而部署于高性能的操作系统相关的Native环境。由于JBoss Web较好地解决了静态资源的访问性能问题,可在解决方案中把它直接作为强大的LVS的分发对象,和RHEL负载均衡系统结合,形成理论上无限线性扩展的负载均衡场景。  OpenSSL是业界最为快速和安全的开源传输组件,可借助操作系统和硬件的特性实现高效的安全承载。JBoss Web集成了OpenSSL,可提供高效的安全传输服务,使得安全机制更上台阶。研究表明, JBoss Web中的SSL性能比单纯的Tomcat快四倍。  URL重写功能可缩短URL,隐藏实际路径提高安全性,易于用户记忆和键入,及被搜索引擎收录。Tomcat 不具备URL重写功能,JBoss Web则可提供一个灵活的URL rewriting操作引擎,支持无限个规则数和规则条件。URL可被重写以支持遗留的URL错误处理,或应对服务器不时产生的其他问题。  JBoss Web既可单独运行,也可无缝嵌入JBoss应用服务器,成为JBoss中间件平台的一部分。不仅后台服务调用的性能将得以提升,也可利用以下JBoss平台的特性提升Web应用功能:  基于JGroups的多种集群方案的支持  基于Arjuna技术的JTA和JTS的事务处理支持  优化的线程池和连接池的支持  基于JMX 控制台的基本管理支持和JBoss On的高级管理维护支持  基于JBoss AOP技术的面向方面架构的支持  Hibernate服务组件的支持  专业团队支持  业界大多数开源产品在技术方面富于创新性,但在可持续性,产品生命周期规划,以及质量保证方面缺乏有效保障,为软件集成商和最终用户所诟病。红帽所力行的“专业化开源技术”则完美解决了这一问题。  来自开源社区的JBoss Web,在红帽专业化开源的锤炼下,在性能、扩展性、稳定性、安全性等方面,已成为一个达到企业级,甚至电信级标准的优秀产品。红帽不仅有专职的技术团队投入JBoss Web的开发,而且具备专门的QA团队为产品作质量保证。完善的集成测试和兼容性测试保证了JBoss Web自身的稳定性,并保证了它的后向兼容和其他JBoss产品协作良好的互操作性。  在服务体系保障方面,JBoss 开拓了以产品专家提供的专家级支持服务作为开源软件强大后盾的软件生态模式。公司以及庞大的 JBoss 授权服务合作伙伴网络可为包括JBoss Web在内的整个JEMS 产品套件提供全面的支持服务。与Tomcat相比,JBoss Web 可提供迁移服务与现场专家服务,在迁移服务方面,专家指导应用可从Tomcat向JBoss Web迁移,省时省力。独特的服务订阅模式,全力保障软件生命周期,让企业高枕无忧。
2023-07-19 22:55:061

WARNING: Device for PV XXXX not found or rejected by a filter

vgreduce - Remove physical volume(s) from a volume group --removemissing Removes all missing PVs from the VG, if there are no LVs allocated on them. This resumes normal operation of the VG (new LVs may again be created, changed and so on). If this is not possible because LVs are referencing the missing PVs, this option can be combined with --force to have the command remove any partial LVs. In this case, any LVs and dependent snapshots that were partly on the missing disks are removed completely, including those parts on disks that are still present. If LVs spanned several disks, including ones that are lost, salvaging some data first may be possible by activating LVs in partial mode. 从VG中删除所有丢失的pv(如果没有在这些pv上分配lv)。这将恢复VG的正常操作(可能会再次创建、更改新的lv等等)。如果由于lv引用了丢失的pv而无法执行此操作,则可以将此选项与--force结合使用,以使命令删除任何部分lv。在这种情况下,部分位于缺失磁盘上的所有lv和从属快照都将被完全删除,包括磁盘上仍然存在的那些部分。如果lv跨越多个磁盘,包括丢失的磁盘,则可以通过在部分模式下激活LVs来先恢复一些数据。 vgreduce --removemissing VG
2023-07-19 22:55:131

MFC 中CListCtrl控件的作用

这个推荐你看微软的MSDN里面最详细 其它给一点参考 在 VC中使用控件一直是件让我头痛的事件,从控件的创建到控件的操作管理,都得写一大堆代码,相比于Delphi/VB,实在是麻烦多了。其实在之前学习 SDK的时候,就有想过专门花点儿时间来学习VC中控件的使用,但一直没空。最近准备写一个小工具,要用到ListCtrl控件,所以又不得不好好的恶补 一翻。我是在MFC的对话框模式下使用CListCtrl控件的,其实不管在SDK或文档/视图模式下,VC控件的使用都差不多,下面来好好的写写CListCtrl控件的使用笔记。一、CListCtrl控件的创建由于我是在MFC的对话框模式下使用CListCtrl控件的,所以只需要在控件栏上选择CListCtrl的图形按钮,接着添加到对话框中就行了。二、CListCtrl控件样式的设置第一步:在使用CListCtrl控件之前,首先需要为该控件关联一个变量(只针对于对话框模式):CListCtrl m_BlogAccountList;第二步:由于CListCtrl控件要做一些初始化操作,比如设置控件样式,设置控件的行列并填入一些数据。初始化操作的代码是在对话框的OnInitDialog事件中写入的。默 认情况下,CListCtrl控件的样式是非常简陋的,大多情况下我们都需要对CListCtrl控件的样式进行修改,比如设置为报表样式,可以进行整行 选择等,如有需要还有调整CListCtrl控件的行高。诸如这些设置都需要用到CListCtrl控件的扩展样式,所以首先得了解这些扩展样式。我在MSDN中没有找到CListCtrl控件的扩展样式资料,只好上百度百科找了找。CListCtrl控件的扩展样式LVS_EX_GRIDLINES //绘制表格线LVS_EX_SUBITEMIMAGES//子项目图标列表LVS_EX_CHECKBOXES //带复选框LVS_EX_TRACKSELECT //自动换行LVS_EX_HEADERDRAGDROP//报表头可以拖拽LVS_EX_FULLROWSELECT //选择整行LVS_EX_ONECLICKACTIVATE//单击激活LVS_EX_TWOCLICKACTIVATE//双击激活LVS_EX_FLATSB//扁平滚动条LVS_EX_REGIONALLVS_EX_INFOTIPLVS_EX_UNDERLINEHOTLVS_EX_UNDERLINECOLDLVS_EX_MULTIWORKAREAS//多工作区对话框模式下创建的CListCtrl控件样式只有一个,就是WS_BORDER,而我需要为CListCtrl设置为报表样式,并能选择整行,下面就可以开始写代码了://通过GetWindowLong来获取CListCtrl已有的样式DWORD dwStyle = GetWindowLong(m_BlogAccountList.m_hWnd, GWL_STYLE);//在原有样式的基本上,添加LVS_REPORT扩展样式SetWindowLong(m_BlogAccountList.m_hWnd, GWL_STYLE, dwStyle|LVS_REPORT); //获取已有的扩展样式DWORD dwStyles = m_BlogAccountList.GetExStyle();//取消复选框样式dwStyles &= ~LVS_EX_CHECKBOXES;//添加整行选择和表格线扩展样式m_BlogAccountList.SetExtendedStyle(dwStyles|LVS_EX_FULLROWSELECT|LVS_EX_GRIDLINES);通过以上四句代码,就已经能满足我的需求了。三、为CListCtrl控件添加列列的添加只需要用到LVCOLUMN结构体,所以需要先行了解了解。在MSDN中查到的LVCOLUMN结构体的定义如下:typedef struct _LVCOLUMN { UINT mask; int fmt; int cx; LPTSTR pszText; int cchTextMax; int iSubItem; #if (_WIN32_IE >= 0x0300) int iImage; int iOrder;#endif} LVCOLUMN, FAR *LPLVCOLUMN; 该结构体共有8个成员。mask是用来设置LVCOLUMN结构体中哪些成员有效,其值可以为0。mask可设置的值如下:LVCF_FMT fmt成员有效LVCF_IMAGE iImage成员有效 LVCF_ORDER //以下略LVCF_SUBITEM LVCF_TEXT LVCF_WIDTH fmt成员是对CListCtrl控件列标题进行设置,比如列标题中文字的对齐方式,是否在列标题中显示图标等。cx成员是设置列宽。pszText成员是设置列标题文字cchTextMax成员是设置标题文字的缓冲区大小iSubItem成员是设置列索引iImage成员是设置ImageList中的图像索引。iOrder成员的作用未知。下面进行添加列操作:char *szColUmn[] = {"帐号", "密码"};int nColWidth[] = {100, 100};LVCOLUMN lvc;lvc.mask = LVCF_FMT | LVCF_SUBITEM | LVCF_TEXT | LVCF_WIDTH | LVCF_ORDER;lvc.fmt = LVCFMT_LEFT; //左对齐for (int i = 0; i < 2; i++){ lvc.pszText = szColUmn[i]; lvc.iSubItem = i; lvc.iOrder = i; lvc.cx = nColWidth[i]; m_BlogAccountList.InsertColumn(i, &lvc);}四、为CListCtrl控件添加行添加行的操作需要用到InsertItem和SetItemText属性,这个简单,就不详述了,看代码:m_BlogAccountList.InsertItem(0, "abc"); m_BlogAccountList.SetItemText(0, 1, "abc");m_BlogAccountList.SetItemText(1, 1, "123");
2023-07-19 22:55:211

求大神帮我用C++编写一个如下的一个程序,在列表框中显示两列,一列为采集数据,一列为采集日期。

这么简单都不会。大学白读了
2023-07-19 22:55:282

物联网设备网关技术架构设计TCP Gateway

《开源精选》是我们分享Github、Gitee等开源社区中优质项目的栏目,包括技术、学习、实用与各种有趣的内容。本期推荐的是物联网设备网关技术架构设计(Session 管理、心跳管理、数据上行、数据下行)TCP Gateway。 物联网设备网关技术架构设计(Session 管理、心跳管理、数据上行、数据下行) NioEventLoop 是 Netty 的 Reactor 线程,其角色: 基于Netty构建TCP网关的长连接容器,作为网关接入层提供服务API请求调用。 客户端通过域名+端口访问TCP网关,域名不同的运营商对应不同的VIP,VIP发布在LVS上,LVS将请求转发给后端的HAProxy,再由HAProxy把请求转发给后端的Netty的IP+Port。 LVS转发给后端的HAProxy,请求经过LVS,但是响应是HAProxy直接反馈给客户端的,这也就是LVS的DR模式。 其中步骤一至步骤九是指 Netty 服务端的创建时序,步骤十至步骤十三是 TCP 网关容器创建的时序。 Window 地址 // C:WindowsSystem32driversetchosts 添加 127.0.0.1 iot-open.icloud.com 位置: com.ibyte.iot.test.server.TestTcpServer 位置: com.ibyte.iot.test.client.TcpClient 更多内容:https://gitee.com/ibyte/icloud-tcp-gateway
2023-07-19 22:55:351

MFC列表控件如何做成这种风格?就是需要每一项前面都要有一个打钩的,然后最关键的是我想要复选了这么多项

给复选框设定编号,绘制时保存名字,根据编号查找名称。
2023-07-19 22:55:431

inpkts和 outpkts是什么单位?是lvs中的

That"s a Fact, it"s a thing we can"t deny Like the fact that I will love you till I die
2023-07-19 22:56:532

VC++ listctrl 到底怎么能全选!!!

设置完了有没有用UpdateData(false)啊
2023-07-19 22:57:013

怎样得到LISTVIEW显示的行数

行数 int nItemNum = m_list.GetItemCount();列数 int nHeadNum = m_list.GetHeaderCtrl()->GetItemCount();1、 ListCtrl添加左键单击(NM_CLICK)函数(这个很重要)。2、 ListCtrl风格设置(一般是网格)。一般listctrl默认view风格为report,一般在OnInitDialog函数中:LONG m_lStyle;m_lStyle = GetWindowLong( m_list.m_hWnd , GWL_STYLE);//获取当前窗口stylem_lStyle |= LVS_EX_FULLROWSELECT;//选中某行使整行高亮(只适用与report风格的listctrl)m_lStyle |= LVS_EX_GRIDLINES;//网格线(只适用与report风格的listctrl)//m_lStyle |= LVS_SHOWSELALWAYS;//一直选中itemm_list.SetExtendedStyle( m_lStyle );//设置扩展风格3、 插入数据一般在OnInitDialog函数中://m_list.InsertColumn( 0, "ID", LVCFMT_LEFT, 40 );//插入列m_list.InsertColumn( 1, "NAME", LVCFMT_LEFT, 50 );int nRow = m_list.InsertItem(0, "11");//插入行m_list.InsertItem(1,"12");m_list.SetItemText(nRow, 1, "jacky");//设置数据m_list.SetItemText(nRow+1, 1, "James");4、 得到listctrl中所有行的checkbox的状态在OnNMClickList1函数中:方法一:m_list.SetExtendedStyle(LVS_EX_CHECKBOXES);CString str;for(int i=0; i<m_list.GetItemCount(); i++){if( m_list.GetItemState(i, LVIS_SELECTED) == LVIS_SELECTED || m_list.GetCheck(i)){str.Format(_T("第%d行的checkbox为选中状态"), i+1);AfxMessageBox(str);}}
2023-07-19 22:57:081

VC中的MFC控件control不见了怎么找回来?

View菜单 Toolbox 反正就是Toolbox工具栏 自己找吧
2023-07-19 22:57:164

关于clistctrl怎么选中指定的列,怎么让所有列都不选中

clistctrl怎么选中指定的列,怎么让所有列都不选中?在线等 ------Solutions------怎么取消选中的项? ------Solutions------SetItemState(int nItem,UNIT nState,UNIT nMask); ------Solutions------SetItemState(nItem, 0, LVIS_SELECTED); ------Solutions------选中为:SetItemState(nItem, LVIS_SELECTED, LVIS_SELECTED);全部选中做一个循环就可以了,取消选中用SetItemState(nItem,0, LVIS_SELECTED);------Solutions------// 响应LVN_COLUMNCLICK消息,遍历CListCtrl中所有的Item,然后设置状态// 初始化OnInitDailog函数中:m_list.ModifyStyle(0, LVS_REPORT|LVS_SHOWSELALWAYS);m_list.SetExtendedStyle(/*LVS_EX_FULLROWSELECT |*/ LVS_EX_GRIDLINES);m_list.InsertColumn(0, _T("AAA"), LVCFMT_LEFT, 100);m_list.InsertColumn(1, _T("BBB"), LVCFMT_LEFT, 100);m_list.InsertColumn(2, _T("CCC"), LVCFMT_LEFT, 100);CString strText(_T(""));for(int i=0;i<10; i++){strText.Format(_T("Index: %d"), i);m_list.InsertItem(i, _T(""));m_list.SetItemText(i, 0, strText);m_list.SetItemText(i, 1, strText);m_list.SetItemText(i, 2, strText);}// LVN_COLUMNCLICK消息响应函数void CXXDlg::OnColumnclickList1(NMHDR* pNMHDR, LRESULT* pResult) {NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;// TODO: Add your control notification handler code hereint nCount = m_list.GetItemCount();int nSubItem = pNMListView->iSubItem;for(int i=0; i<nCount; i++){m_list.SetItem(i, nSubItem, LVIF_STATE, NULL, 0, LVIS_SELECTED, LVIS_SELECTED, 0);}*pResult = 0;}------Solutions------SetItemState是设置某一行的状态,当然他也可以设置列,但是只能是第一列
2023-07-19 22:57:381

MFC,想要用listcontrol显示表中数据

CListCtr的用法:-------------------------------------------------------------------------------1. CListCtrl 风格LVS_ICON: 为每个item显示大图标LVS_SMALLICON: 为每个item显示小图标LVS_LIST: 显示一列带有小图标的itemLVS_REPORT: 显示item详细资料直观的理解:windows资源管理器,"查看"标签下的"大图标,小图标,列表,详细资料--------------------------------------------------------------------------------2. 设置listctrl 风格及扩展风格LONG lStyle;lStyle = GetWindowLong(m_list.m_hWnd, GWL_STYLE);//获取当前窗口stylelStyle &= ~LVS_TYPEMASK; //清除显示方式位lStyle |= LVS_REPORT; //设置styleSetWindowLong(m_list.m_hWnd, GWL_STYLE, lStyle);//设置styleDWORD dwStyle = m_list.GetExtendedStyle();dwStyle |= LVS_EX_FULLROWSELECT;//选中某行使整行高亮(只适用与report风格的listctrl)dwStyle |= LVS_EX_GRIDLINES;//网格线(只适用与report风格的listctrl)dwStyle |= LVS_EX_CHECKBOXES;//item前生成checkbox控件m_list.SetExtendedStyle(dwStyle); //设置扩展风格--------------------------------------------------------------------------------3. 插入数据m_list.InsertColumn( 0, "ID", LVCFMT_LEFT, 40 );//插入列m_list.InsertColumn( 1, "NAME", LVCFMT_LEFT, 50 );//新插入的在上面int nRow = m_list.InsertItem(0, "11");// 插入行m_list.SetItemText(nRow, 1, "jacky");//设置其它列数据//新插入的数据在下面int nIndex = m_list.GetItemCount();LV_ITEM lvItem;lvItem.mask = LVIF_TEXT ;lvItem.iItem = nIndex; //行数lvItem.iSubItem = 0;lvItem.pszText = (char*)(LPCTSTR)strCount; //第一列//在最后一行插入记录值.m_list.InsertItem(&lvItem);//插入其它列m_list.SetItemText(nIndex,1,strLat);--------------------------------------------------------------------------------
2023-07-19 22:58:121

MFC中 ListCtrl的用法

tWindowLong(m_ListCtrl.m_hWnd, GWL_STYLE); //获取当前窗口style lStyle &= ~LVS_TYPEMASK; //清除显示方式位 lStyle |= LVS_REPORT; //设置style lStyle |= LVS_SHOWSELALWAYS; SetWindowLong(m_ListCtrl.m_hWnd, GWL_STYLE, lStyle); //设置style DWORD dwStyle = m_ListCtrl.GetExtendedStyle(); //获取当前扩展样式 dwStyle |= LVS_EX_FULLROWSELECT; //选中某行使整行高亮(report风格时) dwStyle |= LVS_EX_GRIDLINES; //网格线(report风格时) dwStyle |= LVS_EX_MULTIWORKAREAS; // dwStyle |= LVS_EX_CHECKBOXES; //item前生成checkbox控件 //dwStyle |= LVS_EX_FLATSB; //扁平拖动 m_ListCtrl.SetExtendedStyle(dwStyle); //设置扩展风格 char *szColUmn[] = ; int nColWidth[] = ; LVCOLUMN lvc; lvc.mask = LVCF_FMT | LVCF_SUBITEM | LVCF_TEXT | LVCF_WIDTH | LVCF_ORDER; lvc.fmt = LVCFMT_LEFT; //左对齐 for (int i = 0; i < 2; i++) { lvc.pszText = szColUmn[i]; lvc.iSubItem = i; lvc.iOrder = i; lvc.cx = nColWidth[i]; m_ListCtrl.InsertColumn(i, &lvc); }这个是我以前写过的。呵呵,按着我这个模仿一下吧。
2023-07-19 22:58:191

请问在VC中CListCtrl的LVN_GETDISPINFO消息怎么发送?

两种方法:一,已知具体的插入项目m_pList->InsertItem (iIndex, LPSTR_TEXTCALLBACK); 二,只知道项目总数,iCount为列表项目总数SetItemCountEx (iCount, LVSICF_NOINVALIDATEALL);或者SendMessage(LVM_SETITEMCOUNT, (WPARAM)iCount, (LPARAM)LVSICF_NOINVALIDATEALL);
2023-07-19 22:58:271

找遍网络,也没有一个能用win32 sdk 自绘listview控件的示例,都是mfc的 ,哎。有大神能给一个吗?

msdn 有给例子 的 PALLETIZED.CPP 自己找谷歌去PALLETIZED.CPP/*++Copyright (c) 1998 Microsoft CorporationAll rights reserved.Module Name:Palletized--*/// Palettized List View// By MarkFi, April 1998// Requires at least COMCTL32 4.70 (IE3)// Included files#include <windows.h>#include <commctrl.h>#include "resource.h"// Global variablesHWND hLV = NULL;HPALETTE hLVPalette = NULL;// Create palette from DIB SectionHPALETTE CreateDIBSectionPalette(HBITMAP hBitmap){ BITMAP bm; HPALETTE hPalette; // Get the color depth of the DIBSection GetObject(hBitmap,sizeof(BITMAP),&bm); // If the DIBSection is 256 color or less, it has a color table if((bm.bmBitsPixel*bm.bmPlanes) <= 8) { HDC hMemDC; HBITMAP hOldBitmap; RGBQUAD rgb[256]; LPLOGPALETTE pLogPal; WORD i; int nColors; // Find out how many colors are in the color table nColors = 1 << (bm.bmBitsPixel*bm.bmPlanes); // Create a memory DC and select the DIBSection into it hMemDC = CreateCompatibleDC(NULL); hOldBitmap = SelectObject(hMemDC,hBitmap); // Get the DIBSection"s color table GetDIBColorTable(hMemDC,0,nColors,rgb); // Create a palette from the color table pLogPal = malloc(sizeof(LOGPALETTE)+(nColors*sizeof(PALETTEENTRY))); pLogPal->palVersion = 0x300; pLogPal->palNumEntries = nColors; for(i=0;i<nColors;i++) { pLogPal->palPalEntry[i].peRed = rgb[i].rgbRed; pLogPal->palPalEntry[i].peGreen = rgb[i].rgbGreen; pLogPal->palPalEntry[i].peBlue = rgb[i].rgbBlue; pLogPal->palPalEntry[i].peFlags = 0; } hPalette = CreatePalette(pLogPal); // Clean up free(pLogPal); SelectObject(hMemDC,hOldBitmap); DeleteDC(hMemDC); } else // It has no color table return NULL; return hPalette;}// Main window procedureLRESULT CALLBACK WndProc(HWND hwnd,UINT iMsg,WPARAM wParam,LPARAM lParam){ switch(iMsg) { case WM_NOTIFY: { // Handle custom draw notifications LPNMHDR pNM = (LPNMHDR)lParam; if(pNM->hwndFrom == hLV && pNM->code == NM_CUSTOMDRAW) { // Custom draw from List View LPNMLVCUSTOMDRAW pCD = (LPNMLVCUSTOMDRAW)lParam; if(pCD->nmcd.dwDrawStage == CDDS_PREPAINT) return CDRF_NOTIFYITEMDRAW; else if(pCD->nmcd.dwDrawStage == CDDS_ITEMPREPAINT) { // Select and realize palette SelectPalette(pCD->nmcd.hdc,hLVPalette,FALSE); RealizePalette(pCD->nmcd.hdc); return CDRF_DODEFAULT; } } } break; case WM_QUERYNEWPALETTE: case WM_PALETTECHANGED: // Invalidate List View to refresh palette InvalidateRect(hLV,NULL,FALSE); break; case WM_COMMAND: // Check for menu selection if(!HIWORD(wParam)) { BOOL bHandled = TRUE; LONG dNotView = ~(LVS_ICON|LVS_SMALLICON|LVS_LIST|LVS_REPORT); // Menu selection switch(LOWORD(wParam)) { case IDM_ICON: SetWindowLong(hLV,GWL_STYLE,GetWindowLong(hLV,GWL_STYLE)&dNotView|LVS_ICON); break; case IDM_SMALLICON: SetWindowLong(hLV,GWL_STYLE,GetWindowLong(hLV,GWL_STYLE)&dNotView|LVS_SMALLICON); break; case IDM_LIST: SetWindowLong(hLV,GWL_STYLE,GetWindowLong(hLV,GWL_STYLE)&dNotView|LVS_LIST); break; case IDM_REPORT: SetWindowLong(hLV,GWL_STYLE,GetWindowLong(hLV,GWL_STYLE)&dNotView|LVS_REPORT); break; case IDM_ALIGNLEFT: ListView_Arrange(hLV,LVA_ALIGNLEFT); break; case IDM_ALIGNTOP: ListView_Arrange(hLV,LVA_ALIGNTOP); break; case IDM_DEFAULT: ListView_Arrange(hLV,LVA_DEFAULT); break; case IDM_SNAPTOGRID: ListView_Arrange(hLV,LVA_SNAPTOGRID); break; default: bHandled = FALSE; break; } if(bHandled) return 0; } break; case WM_SIZE: { RECT rectClient; GetClientRect(hwnd,&rectClient); SetWindowPos(hLV,NULL,0,0,rectClient.right-rectClient.left,rectClient.bottom-rectClient.top,SWP_NOZORDER|SWP_NOACTIVATE|SWP_NOMOVE); } break; case WM_DESTROY: PostQuitMessage(0); return 0; } return DefWindowProc(hwnd,iMsg,wParam,lParam);}int WINAPI WinMain(HINSTANCE hInstance,HINSTANCE hPrevInstance,PSTR szCmdLine,int iCmdShow){ static char szAppName[] = "SimpleLV"; HWND hwnd; MSG msg; RECT rectClient; WNDCLASSEX wndclass; // Initialize common controls InitCommonControls(); // Setup window class wndclass.cbSize = sizeof(wndclass); wndclass.style = CS_HREDRAW|CS_VREDRAW; wndclass.lpfnWndProc = WndProc; wndclass.cbClsExtra = 0; wndclass.cbWndExtra = 0; wndclass.hInstance = hInstance; wndclass.hIcon = LoadIcon(NULL,IDI_APPLICATION); wndclass.hCursor = LoadCursor(NULL,IDC_ARROW); wndclass.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH); wndclass.lpszMenuName = NULL; wndclass.lpszClassName = szAppName; wndclass.hIconSm = LoadIcon(NULL,IDI_APPLICATION); RegisterClassEx(&wndclass); // Create main window hwnd = CreateWindowEx(0,szAppName,"Palettized List View",WS_OVERLAPPEDWINDOW,275,200,400,300,NULL,NULL,hInstance,NULL); SetMenu(hwnd,LoadMenu(hInstance,MAKEINTRESOURCE(IDR_MENU))); GetClientRect(hwnd,&rectClient); // Create and fill list view hLV = CreateWindowEx(0,WC_LISTVIEW,NULL,WS_CHILD|WS_VISIBLE,0,0,rectClient.right-rectClient.left, rectClient.bottom-rectClient.top,hwnd,NULL,hInstance,NULL); { LPSTR pLabel[] = { "Mercury","Venus","Earth","Mars","Jupiter","Saturn","Uranus","Neptune","Pluto" }; CHAR szLabel[81]; HIMAGELIST hILLarge; HIMAGELIST hILSmall; HBITMAP hBitmap; LVITEM lvItem; LVCOLUMN lvColumn; INT dIndex; INT x; INT y; // Create image lists as DIB Section 24-bit color // Large image list hILLarge = ImageList_Create(32,32,ILC_COLOR24|ILC_MASK,9,1); hBitmap = LoadImage(hInstance,MAKEINTRESOURCE(IDB_PLANETS),IMAGE_BITMAP,0,0,LR_CREATEDIBSECTION); // Get palette of large bitmap and use as List View"s palette hLVPalette = CreateDIBSectionPalette(hBitmap); ImageList_AddMasked(hILLarge,hBitmap,RGB(0,255,255)); DeleteObject(hBitmap); // Small image list hILSmall = ImageList_Create(16,16,ILC_COLOR24|ILC_MASK,9,1); hBitmap = LoadImage(hInstance,MAKEINTRESOURCE(IDB_PLANETSSMALL),IMAGE_BITMAP,0,0,LR_CREATEDIBSECTION); ImageList_AddMasked(hILSmall,hBitmap,RGB(0,255,255)); DeleteObject(hBitmap); // Assign image lists to control ListView_SetImageList(hLV,hILLarge,LVSIL_NORMAL); ListView_SetImageList(hLV,hILSmall,LVSIL_SMALL); // Add columns lvColumn.mask = LVCF_TEXT|LVCF_WIDTH; lvColumn.cx = 125; lvColumn.pszText = szLabel; // Column 0 strcpy(szLabel,"Column 2"); ListView_InsertColumn(hLV,0,&lvColumn); // Column 1 strcpy(szLabel,"Column 1"); ListView_InsertColumn(hLV,0,&lvColumn); // Column 2 strcpy(szLabel,"Column 0"); ListView_InsertColumn(hLV,0,&lvColumn); // Add items ZeroMemory(&lvItem,sizeof(LVITEM)); for(x=8;x>=0;x--) { lvItem.mask = LVIF_TEXT|LVIF_IMAGE; lvItem.iItem = 0; lvItem.iSubItem = 0; lvItem.pszText = pLabel[x]; lvItem.iImage = x; dIndex = ListView_InsertItem(hLV,&lvItem); // Add subitems for(y=1;y<3;y++) { lvItem.mask = TVIF_TEXT; lvItem.iItem = dIndex; lvItem.iSubItem = y; lvItem.pszText = szLabel; wsprintf(szLabel,"Sub Item %d,%d",x,y-1); ListView_SetItem(hLV,&lvItem); } } } // Show main window ShowWindow(hwnd,iCmdShow); UpdateWindow(hwnd); // Message loop while(GetMessage(&msg,NULL,0,0)) { TranslateMessage(&msg); DispatchMessage(&msg); } return msg.wParam;}Built on: Wednesday, October 20, 1999
2023-07-19 22:58:341

VC++ List Control 的具体用法实例。

你复制粘贴下面的内容吧:分赶快给我1. ListCtrl 风格 LVS_ICON: 为每个item显示大图标 LVS_SMALLICON: 为每个item显示小图标 LVS_LIST: 显示一列带有小图标的item LVS_REPORT: 显示item详细资料 直观的理解:windows资源管理器,“查看”标签下的“大图标,小图标,列表,详细资料”--------------------------------------------------------------------------------2. 设置listctrl 风格及扩展风格 LONG lStyle; lStyle = GetWindowLong(m_list.m_hWnd, GWL_STYLE);//获取当前窗口style lStyle &= ~LVS_TYPEMASK; //清除显示方式位 lStyle |= LVS_REPORT; //设置style SetWindowLong(m_list.m_hWnd, GWL_STYLE, lStyle);//设置style DWORD dwStyle = m_list.GetExtendedStyle(); dwStyle |= LVS_EX_FULLROWSELECT;//选中某行使整行高亮(只适用与report风格的listctrl) dwStyle |= LVS_EX_GRIDLINES;//网格线(只适用与report风格的listctrl) dwStyle |= LVS_EX_CHECKBOXES;//item前生成checkbox控件 m_list.SetExtendedStyle(dwStyle); //设置扩展风格--------------------------------------------------------------------------------3. 插入数据 m_list.InsertColumn( 0, "ID", LVCFMT_LEFT, 40 );//插入列 m_list.InsertColumn( 1, "NAME", LVCFMT_LEFT, 50 ); int nRow = m_list.InsertItem(0, “11”);//插入行 m_list.SetItemText(nRow, 1, “jacky”);//设置数据--------------------------------------------------------------------------------4. 一直选中item 选中style中的Show selection always,或者在上面第2点中设置LVS_SHOWSELALWAYS--------------------------------------------------------------------------------5. 选中和取消选中一行 int nIndex = 0; //选中 m_list.SetItemState(nIndex, LVIS_SELECTED|LVIS_FOCUSED, LVIS_SELECTED|LVIS_FOCUSED); //取消选中 m_list.SetItemState(nIndex, 0, LVIS_SELECTED|LVIS_FOCUSED); --------------------------------------------------------------------------------6. 得到listctrl中所有行的checkbox的状态 m_list.SetExtendedStyle(LVS_EX_CHECKBOXES); CString str; for(int i=0; i<m_list.GetItemCount(); i ) { if( m_list.GetItemState(i, LVIS_SELECTED) == LVIS_SELECTED || m_list.GetCheck(i)) { str.Format(_T("第%d行的checkbox为选中状态"), i); AfxMessageBox(str); } }CString strIns;strIns="delete from tmpStatByGround";m_pRs.CreateInstance(__uuidof(Recordset));m_pRs->CursorLocation = adUseClient;m_pRs->Open((LPCTSTR)strIns, vDispatch, adOpenKeyset,adLockOptimistic, adCmdUnknown);--------------------------------------------------------------------------------7. 得到listctrl中所有选中行的序号 方法一: CString str; for(int i=0; i<m_list.GetItemCount(); i ) { if( m_list.GetItemState(i, LVIS_SELECTED) == LVIS_SELECTED ) { str.Format(_T("选中了第%d行"), i); AfxMessageBox(str); } } 方法二: POSITION pos = m_list.GetFirstSelectedItemPosition(); if (pos == NULL) TRACE0("No items were selected! "); else { while (pos) { int nItem = m_list.GetNextSelectedItem(pos); TRACE1("Item %d was selected! ", nItem); // you could do your own processing on nItem here } }--------------------------------------------------------------------------------8. 得到item的信息 TCHAR szBuf[1024]; LVITEM lvi; lvi.iItem = nItemIndex; lvi.iSubItem = 0; lvi.mask = LVIF_TEXT; lvi.pszText = szBuf; lvi.cchTextMax = 1024; m_list.GetItem(&lvi);--------------------------------------------------------------------------------9. 得到listctrl的所有列的header字符串内容 LVCOLUMN lvcol; char str[256]; int nColNum; CString strColumnName[4];//假如有4列 nColNum = 0; lvcol.mask = LVCF_TEXT; lvcol.pszText = str; lvcol.cchTextMax = 256; while(m_list.GetColumn(nColNum, &lvcol)) { strColumnName[nColNum] = lvcol.pszText; nColNum ; }--------------------------------------------------------------------------------10. 使listctrl中一项可见,即滚动滚动条 m_list.EnsureVisible(i, FALSE);--------------------------------------------------------------------------------11. 得到listctrl列数 int nHeadNum = m_list.GetHeaderCtrl()->GetItemCount();--------------------------------------------------------------------------------12. 删除所有列 方法一: while ( m_list.DeleteColumn (0)) 因为你删除了第一列后,后面的列会依次向上移动。 方法二: int nColumns = 4; for (int i=nColumns-1; i>=0; i--) m_list.DeleteColumn (i);--------------------------------------------------------------------------------13. 得到单击的listctrl的行列号 添加listctrl控件的NM_CLICK消息相应函数 void CTest6Dlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult) { // 方法一: /* DWORD dwPos = GetMessagePos(); CPoint point( LOWORD(dwPos), HIWORD(dwPos) ); m_list.ScreenToClient(&point); LVHITTESTINFO lvinfo; lvinfo.pt = point; lvinfo.flags = LVHT_ABOVE; int nItem = m_list.SubItemHitTest(&lvinfo); if(nItem != -1) { CString strtemp; strtemp.Format("单击的是第%d行第%d列", lvinfo.iItem, lvinfo.iSubItem); AfxMessageBox(strtemp); } */ // 方法二: /* NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR; if(pNMListView->iItem != -1) { CString strtemp; strtemp.Format("单击的是第%d行第%d列", pNMListView->iItem, pNMListView->iSubItem); AfxMessageBox(strtemp); } */ *pResult = 0; }--------------------------------------------------------------------------------14. 判断是否点击在listctrl的checkbox上 添加listctrl控件的NM_CLICK消息相应函数 void CTest6Dlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult) { DWORD dwPos = GetMessagePos(); CPoint point( LOWORD(dwPos), HIWORD(dwPos) ); m_list.ScreenToClient(&point); LVHITTESTINFO lvinfo; lvinfo.pt = point; lvinfo.flags = LVHT_ABOVE; UINT nFlag; int nItem = m_list.HitTest(point, &nFlag); //判断是否点在checkbox上 if(nFlag == LVHT_ONITEMSTATEICON) { AfxMessageBox("点在listctrl的checkbox上"); } *pResult = 0; }--------------------------------------------------------------------------------15. 右键点击listctrl的item弹出菜单 添加listctrl控件的NM_RCLICK消息相应函数 void CTest6Dlg::OnRclickList1(NMHDR* pNMHDR, LRESULT* pResult) { NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR; if(pNMListView->iItem != -1) { DWORD dwPos = GetMessagePos(); CPoint point( LOWORD(dwPos), HIWORD(dwPos) ); CMenu menu; VERIFY( menu.LoadMenu( IDR_MENU1 ) ); CMenu* popup = menu.GetSubMenu(0); ASSERT( popup != NULL ); popup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON, point.x, point.y, this ); } *pResult = 0; }--------------------------------------------------------------------------------16. item切换焦点时(包括用键盘和鼠标切换item时),状态的一些变化顺序 添加listctrl控件的LVN_ITEMCHANGED消息相应函数 void CTest6Dlg::OnItemchangedList1(NMHDR* pNMHDR, LRESULT* pResult) { NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR; // TODO: Add your control notification handler code here CString sTemp; if((pNMListView->uOldState & LVIS_FOCUSED) == LVIS_FOCUSED && (pNMListView->uNewState & LVIS_FOCUSED) == 0) { sTemp.Format("%d losted focus",pNMListView->iItem); } else if((pNMListView->uOldState & LVIS_FOCUSED) == 0 && (pNMListView->uNewState & LVIS_FOCUSED) == LVIS_FOCUSED) { sTemp.Format("%d got focus",pNMListView->iItem); } if((pNMListView->uOldState & LVIS_SELECTED) == LVIS_SELECTED && (pNMListView->uNewState & LVIS_SELECTED) == 0) { sTemp.Format("%d losted selected",pNMListView->iItem); } else if((pNMListView->uOldState & LVIS_SELECTED) == 0 && (pNMListView->uNewState & LVIS_SELECTED) == LVIS_SELECTED) { sTemp.Format("%d got selected",pNMListView->iItem); } *pResult = 0; }--------------------------------------------------------------------------------17. listctrl的 subitem 添加图标 注意: 首先要用 InsertItem() 插入一行的第一列, 然后才能用 SetItem 设置其他项 m_list.SetExtendedStyle(LVS_EX_SUBITEMIMAGES); m_userlist.SetItem(..);--------------------------------------------------------------------------------18. 在CListCtrl显示文件,并根据文件类型来显示图标 网上找到的代码,自己试用并改正过, share 步骤1: 设置 list 的图像列表为 系统图像列表 BOOL SetSystemImageList( CListCtrl & list ){ HIMAGELIST himlSmall; HIMAGELIST himlLarge; SHFILEINFO sfi; char cSysDir[MAX_PATH]; CString strBuf; memset(cSysDir, 0, MAX_PATH); GetWindowsDirectory(cSysDir, MAX_PATH); strBuf = cSysDir ; // SHGetFileInfo: // If uFlags contains SHGFI_SYSICONINDEX, the return value is a handle to // an image list that contains the large icon images. // If SHGFI_SMALLICON is included with SHGFI_SYSICONINDEX, the return value // is the handle to an image list that contains the small icon images. // himlSmall = (HIMAGELIST)SHGetFileInfo ( (LPCSTR)cSysDir, 0, &sfi, sizeof(SHFILEINFO), SHGFI_SYSICONINDEX | SHGFI_SMALLICON ); himlLarge = (HIMAGELIST)SHGetFileInfo((LPCSTR)cSysDir, 0, &sfi, sizeof(SHFILEINFO), SHGFI_SYSICONINDEX | SHGFI_LARGEICON); if (himlSmall && himlLarge) { ::SendMessage(list.m_hWnd, LVM_SETIMAGELIST, (WPARAM)LVSIL_SMALL, (LPARAM)himlSmall); ::SendMessage(list.m_hWnd, LVM_SETIMAGELIST, (WPARAM)LVSIL_NORMAL, (LPARAM)himlLarge); } return TRUE;}步骤2: 给列表添加指定的文件, 同时获得该文件的的图标索引, 给 list 添加图标int GetIconIndex(LPCTSTR lpszPath, BOOL bIsDir, BOOL bSelected) ; // 向前声明void AddFiles(CListCtrl & list, LPCTSTR lpszFileName, BOOL bAddToDocument){ int nIcon = GetIconIndex(lpszFileName, FALSE, TRUE); CString strSize; CFileFind filefind; // get file size if ( filefind.FindFile(lpszFileName)) { filefind.FindNextFile(); strSize.Format("%d", filefind.GetLength()); } else strSize = "0"; // split path and filename CString strFileName = lpszFileName; CString strPath; int nPos = strFileName.ReverseFind("\"); if (nPos != -1) { strPath = strFileName.Left(nPos); strFileName = strFileName.Mid(nPos 1); } // insert to list int nItem = list.GetItemCount();//list.InsertItem(nItem, strFileName, nIcon); //list.SetItemText(nItem, 1, strSize); // // 此处可以根据实际需要修改代码 //} --------------------------------------------------------------------------------19. listctrl内容进行大数据量更新时,避免闪烁 m_list.SetRedraw(FALSE); //更新内容 m_list.SetRedraw(TRUE); m_list.Invalidate(); m_list.UpdateWindow();20. 清除 ListCtrl 以重新初始化: // 删除所有行 m_ctrllist.DeleteAllItems() ; // 删除所有列 int iColCount = m_ctrllist.GetHeaderCtrl()->GetItemCount() ; // 方法 1 // 原理: 删除第一列后, 其他列向前移动 while( m_ctrllist.DeleteColumn(0) ) ; // 方法 2 for (int i=0; i < iColCount ; i ) { m_ctrllist.DeleteColumn(0); } // 方法 3 for (int i=iColCount-1; i >= 0; i-- ) { m_ctrllist.DeleteColumn( i ); }
2023-07-19 22:58:411

WPF怎么设置ListView中CheckBox的值

for (int i = 0; i < ds.Tables[0].Rows.Count; i++) { CheckBox cb1 = new CheckBox(); lvsqz.Items.Add(cb1); }//代码添加 不用写XAML for (int i = 0; i < lvsqz.Items.Count; i++) { CheckBox cb = new CheckBox(); cb = (CheckBox)lvsqz.Items[i]; cb.IsChecked = true; }// 遍历 赋值其实和上面的回答差不多
2023-07-19 22:58:491

有一个由N匝导线绕成的平面正三角形线圈,边长为a,通有电流I,置于均匀外磁场中,当线圈平面的法向与

线框在进入磁场时,产生的感应电动势E=nBLv回路中的电流I=ER=nBLvRnBLvρ4nLS=BvS4ρ,I与n无关.故B错误.则通过线圈截面的电量Q=It=nBLvR?Lv=nBL2R,可见Q与v无关.故A错误.C、电功率P=E2R=(nBLv)2ρ4nLS=nB2LvS4ρ,P与L成正比.故C正确.D、拉力做的功W等于线圈的发热,则W=Pt=nB2LvS4ρ?Lv=nB2L2S4ρ,则W与L的平方成正比.还请采纳求大神指导
2023-07-19 22:59:001

求hp 教授受文

亲,sh的要不
2023-07-19 22:59:204

由N匝细导线绕成的平面正三角形线圈,边长为a,通有电流I,置于均匀外磁场B中

A、B线框在进入磁场时,产生的感应电动势E=nBLv回路中的电流I=ER=nBLvRnBLvρ4nLS=BvS4ρ,I与n无关.故B错误.则通过线圈截面的电量Q=It=nBLvR?Lv=nBL2R,可见Q与v无关.故A错误.C、电功率P=E2R=(nBLv)2ρ4nLS=nB2LvS4ρ,P与L成正比.故C正确.D、拉力做的功W等于线圈的发热,则W=Pt=nB2LvS4ρ?Lv=nB2L2S4ρ,则W与L的平方成正比.故D正确.故选:D
2023-07-19 22:59:351

有一N匝细导线绕成的平面正三角形线圈,边长为a,通有电流I,至于均匀外磁场B中,当线圈平面的法向与

a、b线框在进入磁场时,产生的感应电动势e=nblv回路中的电流i=er=nblvrnblvρ4nls=bvs4ρ,i与n无关.故b错误.则通过线圈截面的电量q=it=nblvr?lv=nbl2r,可见q与v无关.故a错误.c、电功率p=e2r=(nblv)2ρ4nls=nb2lvs4ρ,p与l成正比.故c正确.d、拉力做的功w等于线圈的发热,则w=pt=nb2lvs4ρ?lv=nb2l2s4ρ,则w与l的平方成正比.故d正确.故选:d
2023-07-19 22:59:441

MFC,ListBox使用 InsertColumn添加列,在列表框中却无论如何都不显示,很是郁闷,求解,正解追加高分。

控件属性-》外观-》view 默认是icon 改成report就可以了。。望采纳
2023-07-19 23:00:033

vc++ 怎么查看listctrl有多少行,以及多少列??

行数 int nItemNum = m_list.GetItemCount();列数 int nHeadNum = m_list.GetHeaderCtrl()->GetItemCount();
2023-07-19 23:00:112

vc怎么实现列表控件各项的图标拖动

拖动图标通过实现OnBeginDrag等消息函数完成: void CMyListCtrl::OnBeginDrag(LPNMHDR pnmhdr, LRESULT *pResult) { CPoint ptItem, ptAction, ptImage; NM_LISTVIEW *pnmListView = (NM_LISTVIEW *)pnmhdr; ASSERT(!m_bDragging); m_bDragging = TRUE; m_iItemDrag = pnmListView->iItem; ptAction = pnmListView->ptAction; GetItemPosition(m_iItemDrag, &ptItem); // ptItem is relative to (0,0) and not the view origin GetOrigin(&m_ptOrigin); ASSERT(m_pimageListDrag == NULL); m_pimageListDrag = CreateDragImage(m_iItemDrag, &ptImage); m_sizeDelta = ptAction - ptImage; // difference between cursor pos and image pos m_ptHotSpot = ptAction - ptItem + m_ptOrigin; // calculate hotspot for the cursor m_pimageListDrag->DragShowNolock(TRUE); // lock updates and show drag image m_pimageListDrag->SetDragCursorImage(0, m_ptHotSpot); // define the hot spot for the new cursor image m_pimageListDrag->BeginDrag(0, CPoint(0, 0)); ptAction -= m_sizeDelta; m_pimageListDrag->DragEnter(this, ptAction); m_pimageListDrag->DragMove(ptAction); // move image to overlap original icon SetCapture(); } void CMyListCtrl::OnMouseMove(UINT nFlags, CPoint point) { long lStyle; int iItem; LV_ITEM lvitem; lStyle = GetWindowLong(m_hWnd, GWL_STYLE); lStyle &= LVS_TYPEMASK; // drag will do different things in list and report mode if (m_bDragging) { ASSERT(m_pimageListDrag != NULL); m_pimageListDrag->DragMove(point - m_sizeDelta); // move the image if ((iItem = HitTest(point)) != -1) { m_iItemDrop = iItem; m_pimageListDrag->DragLeave(this); // unlock the window and hide drag image if (lStyle == LVS_REPORT || lStyle == LVS_LIST) { lvitem.iItem = iItem; lvitem.iSubItem = 0; lvitem.mask = LVIF_STATE; lvitem.stateMask = LVIS_DROPHILITED; // highlight the drop target SetItem(&lvitem); } point -= m_sizeDelta; m_pimageListDrag->DragEnter(this, point); // lock updates and show drag image } } CListCtrl::OnMouseMove(nFlags, point); } void CMyListCtrl::OnButtonUp(CPoint point) { if (m_bDragging) // end of the drag operation { long lStyle; CString cstr; lStyle = GetWindowLong(m_hWnd, GWL_STYLE) & LVS_TYPEMASK; m_bDragging = FALSE; ASSERT(m_pimageListDrag != NULL); m_pimageListDrag->DragLeave(this); m_pimageListDrag->EndDrag(); delete m_pimageListDrag; m_pimageListDrag = NULL; // The drop target"s sub-item text is replaced by the dragged item"s // main text if (lStyle == LVS_REPORT && m_iItemDrop != m_iItemDrag) { cstr = GetItemText(m_iItemDrag, 0); SetItemText(m_iItemDrop, 1, cstr); } //the character string "**" is added to the end of the drop target"s main text if (lStyle == LVS_LIST && m_iItemDrop != m_iItemDrag) { cstr = GetItemText(m_iItemDrop, 0); cstr += _T("**"); SetItemText(m_iItemDrop, 0, cstr); } // move the icon if (lStyle == LVS_ICON || lStyle == LVS_SMALLICON) { point -= m_ptHotSpot; // the icon should be drawn exactly where the image is point += m_ptOrigin; SetItemPosition(m_iItemDrag, point); // just move the dragged item } ::ReleaseCapture(); } } void CMyListCtrl::OnLButtonUp(UINT nFlags, CPoint point) { OnButtonUp(point); CListCtrl::OnLButtonUp(nFlags, point); } 在图标间划线可以确定图标的位置然后用Pen自画。 右键菜单相应OnRclick函数 void CMyListView::OnRclick(NMHDR* pNMHDR, LRESULT* pResult) { // TODO: Add your control notification handler code here CListCtrl &theCtrl = GetListCtrl(); CPoint pt; ::GetCursorPos(&pt); theCtrl.ScreenToClient(&pt); LVHITTESTINFO lvinfo; lvinfo.pt = pt; lvinfo.flags = LVHT_ABOVE; m_nItem = theCtrl.SubItemHitTest(&lvinfo); if(m_nItem != -1) { CMenu menu ,* pSubMenu; menu.LoadMenu(IDR_MENU1); pSubMenu = menu.GetSubMenu(0); theCtrl.ClientToScreen(&pt); if(pSubMenu) pSubMenu->TrackPopupMenu (TPM_LEFTALIGN, pt.x, pt.y, this); } *pResult = 0; }
2023-07-19 23:00:251

《什么是数学对思想和方法的基本研究》epub下载在线阅读,求百度网盘云资源

《什么是数学》([美] R·柯朗 H·罗宾 著)电子书网盘下载免费在线阅读资源链接:链接: https://pan.baidu.com/s/1v4iEFZORQXEJ3MTbRXQzWg 提取码: rwva书名:什么是数学作者:[美] R·柯朗 H·罗宾 著译者:左平豆瓣评分:9.1出版社:复旦大学出版社出版年份:2005-5页数:584内容简介:《什么是数学》既是为初学者也是为专家,既是为学生也是为教师,既是为哲学家也是为工程师而写的。它是一本世界著名的数学科普读物。书中搜集了许多经典的数学珍品,给出了数学世界的一组有趣的、深入浅出的图画,对整个数学领域中的基本概念与方法,做了精深而生动的阐述。I·斯图尔特增写了新的一章,以新的观点阐述了数学的最新进展,叙述了四色定理和费马大定理的证明等。这些问题是在柯朗与罗宾写书的年代尚未解决,但现在已被解决了的。作者简介:R·柯朗(Richard Courant)是20世纪杰出的数学家,哥廷根学派重要成员。他生前是纽约大学数学系和数学科学研究院的主任,该研究院后被重命名为柯朗数学科学研究院。他写的书《数学物理方程》为每一个物理学家所熟知;而他的《微积分学》已被认为是近代写得最好的该学科的代表作。H·罗宾(Herbert Robbins)是新泽西拉特杰斯大学的数理统计教授。I·斯图尔特(Ian Stewart)是沃里克大学的数学教授,并且是《自然界中的数和上帝玩色子游戏吗》一书的作者;他还在《科学美国人》杂志上主编《数学娱乐》专栏;他因使科学为大众理解的杰出贡献而在1995年获得了皇家协会的米凯勒法拉第奖章。
2023-07-19 23:00:323

Selvsving的《Kitch》 歌词

歌曲名:Kitch歌手:Selvsving专辑:Selvsving IgensvingLemonheads"Kitchen"歌词Thrilled to be in the same post code as you.I tell you things i know you"d like to knowTreat you to cake every nightSuddenly talk and it"ll make you frightSmile at me, i"ll hold you really tightFollow you into bed, run around till mornin"We"ll stay awake all night.We"ll repeat the same storiesBut of course never in front of friendsHow it all started in the kitchenHey!Remember the time when you said we should wait awhile?You"d let me know when you changed your mind.Yeah, i was sad for some time.But 12 hours watching me at the wheelMade me realize what you really feelWon"t have to hurt anymorerun around till mornin",We"ll stay awake all nightWe"ll repeat the same storiesBut of course never in front of friendsHow it all started in the kitchenOoohhh......Walking you home along mt. vernon street,You told me secrets i was shocked to knowPretend it was me every night.I"m thrilled to be in the same postcode as youI"ll come and visit, maybe never goFollow you into bedRun around till mornin" and we"ll stay awake all night.We repeat the same storiesBut of course never in front of friendsHow it all started in the kitchen.Run around till mornin" and we"ll stay awake every night.We repeat the same stories,But of course never in front of friends.How it all started in the kitchen.http://music.baidu.com/song/2952612
2023-07-19 23:01:061

从澳门科技馆到威尼斯人酒店怎麼坐车

一朵雪拥抱着另一朵他见过诗人的雪。犹太人的雪。他见过雪的镇压。他看见了红色的雪。见过雪的珠穆朗玛和雪的卡瓦格博
2023-07-19 23:01:445

关于VC++的BOXCHECK控件的使用

1.让List Control有Check Box 用SetExtendedStyle方法可以设置,看代码:(CListCtrl m_ListCtrl;)DWORD dwStyle = m_ListCtrl.GetStyle();dwStyle |= LVS_EX_CHECKBOXES;m_ListCtrl.SetExtendedStyle(dwStyle);2.让List Box有Check Box 首先,声明Control变量的时候用CCheckListBox代替CListBox。然后,将List Box的Has Strings属性改为True;把Ower Draw属性改为Fixed。
2023-07-19 23:02:071

CListCtrl新增行问题

你的storeList有自动排序功能?
2023-07-19 23:02:154

怎样设置ListCtrl控件中行的高度

1、 ListCtrl添加左键单击(NM_CLICK)函数(这个很重要)。2、 ListCtrl风格设置(一般是网格)。一般listctrl默认view风格为report,一般在OnInitDialog函数中:LONG m_lStyle;m_lStyle = GetWindowLong( m_list.m_hWnd , GWL_STYLE);//获取当前窗口stylem_lStyle |= LVS_EX_FULLROWSELECT;//选中某行使整行高亮(只适用与report风格的listctrl)m_lStyle |= LVS_EX_GRIDLINES;//网格线(只适用与report风格的listctrl)//m_lStyle |= LVS_SHOWSELALWAYS;//一直选中itemm_list.SetExtendedStyle( m_lStyle );//设置扩展风格3、 插入数据一般在OnInitDialog函数中://m_list.InsertColumn( 0, "ID", LVCFMT_LEFT, 40 );//插入列m_list.InsertColumn( 1, "NAME", LVCFMT_LEFT, 50 );int nRow = m_list.InsertItem(0, "11");//插入行m_list.InsertItem(1,"12");m_list.SetItemText(nRow, 1, "jacky");//设置数据m_list.SetItemText(nRow+1, 1, "James");4、 得到listctrl中所有行的checkbox的状态在OnNMClickList1函数中:方法一:m_list.SetExtendedStyle(LVS_EX_CHECKBOXES);CString str;for(int i=0; i<m_list.GetItemCount(); i++){if( m_list.GetItemState(i, LVIS_SELECTED) == LVIS_SELECTED || m_list.GetCheck(i)){str.Format(_T("第%d行的checkbox为选中状态"), i+1);AfxMessageBox(str);}}方法二:POSITION pos = m_list.GetFirstSelectedItemPosition();CString str;if (pos == NULL)TRACE0("No items were selected!/n");else{while (pos){int nItem = m_list.GetNextSelectedItem(pos);str.Format(_T("选中了第%d行"), nItem+1);AfxMessageBox(str);}}5、 删除所有列(即清空)while ( m_list.DeleteColumn (0));6、 得到单击的listctrl的行列号// 方法一:DWORD dwPos = GetMessagePos(); //返回表示屏幕坐标下光标位置的长整数值CPoint point( LOWORD(dwPos), HIWORD(dwPos) );m_list.ScreenToClient(&point); //把屏幕上指定点的屏幕坐标转换成用户坐标LVHITTESTINFO lvinfo;lvinfo.pt = point;lvinfo.flags = LVHT_ABOVE;int nItem = m_list.SubItemHitTest(&lvinfo);if(nItem != -1){CString strtemp;strtemp.Format("单击的是第%d行第%d列", lvinfo.iItem, lvinfo.iSubItem);AfxMessageBox(strtemp);}// 方法二:NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;if(pNMListView->iItem != -1){CString strtemp;strtemp.Format("单击的是第%d行第%d列", pNMListView->iItem, pNMListView->iSubItem);AfxMessageBox(strtemp);}7、 右键点击listctrl的item弹出菜单在资源里画菜单添加listctrl控件的NM_RCLICK消息相应函数//右键单击的函数void CListCtrlDlg::OnNMRclickList1(NMHDR *pNMHDR, LRESULT *pResult){NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;if(pNMListView->iItem != -1){DWORD dwPos = GetMessagePos(); //返回表示屏幕坐标下光标位置的长整数值CPoint point( LOWORD(dwPos), HIWORD(dwPos) );CMenu menu;VERIFY( menu.LoadMenu( IDR_MENU1 ) );CMenu* popup = menu.GetSubMenu(0); //取得被指定菜单激活的下拉式菜单或子菜单的句柄ASSERT( popup != NULL );popup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON,point.x, point.y, this ); //在指定位置显示快捷菜单,并跟踪菜单项的选择}*pResult = 0;}著的性质是能使荧光物质发光,另外还可以灭菌 。
2023-07-19 23:02:421