TortoiseSVN文件夹及文件图标不显示问题解决方法(兼容xp、window7与64位)

所属分类: 电脑基础 / 故障排除 阅读数: 118
收藏 0 赞 0 分享

最近遇到TortoiseSVN图标(如上图:增加文件图标、文件同步完成图标等)不显示问题,网上找到的解决方法试了很多都无法真正解决,最后总结了一下,找到了终极解决方案,当然此方案也有弊端,接下来我们就研究、分析、解决这个问题。
 
打开资源管理器,怎么都看不到已经同步的文件夹显示已同步图标。到SVN的设置面板,也找不到任何相关的解决办法。

不过有一天,使用DW浏览文件,定位到文件,这时候发现了已同步图标。这就更让人疑惑了,但是最起码证明,图标文件没有丢失,只是因为某种原因,没办法显示出来,那就有可能是软件冲突了。
可是近期七七八八装了不少东西,到底是哪个的原因呢?

不明原因,所以,百度google之,发现还是挺多人遇到这情况的,现摘录如下:

“开始以为是TortoiseSVN坏了,于是重装,但结果还是一样。于是找了好多资料,终于发现症结所在--原来是Windows对覆盖图标类型的数据 限制的原因。Windows最多只允许15个覆盖图标,它自己又用了几个,结果给用户用的就11个左右了(这个限制一直都Windows 7都没有放宽,真不知微软是怎么想的)。TortoiseSVN标准会使用7个(普通图标、已修改图标、冲突指示图标、已删除图标、新增文件图标、忽略图 标、未版本化图标等),这样剩下可用的就少之又少了。如果再安装了网盘软件(如:快盘,Dropbox等),那就更惨了,它们各自又会使用3个左右的覆盖 图标,这样,覆盖图标当然远远不够用了。
那么,覆盖图标的设置保存在Windows的哪个地方呢?如果有超过11个的覆盖图标,Windows如何选择显示哪些屏蔽哪些呢?下面继续…
所有应用程序的覆盖图标都需要在注册表“HKEY_LOCAL_MACHINESOFTWAREMicrosoftWindows CurrentVersionExplorerShellIconOverlayIdentifiers”下面增加一个项目,当需要显示覆盖图标 时,Windows会按照项目名称的字母顺利依次查询在这些项目里所指示的接口,以检测是否有覆盖图标,当检测到11个有效的接口后,Windows就会 自动停止继续向下检测,这样,后来的覆盖图标就不会显示了。
知道原理了,解决问题就好办了。我们可以分析一下在这个注册表项下的所有项目,看哪些覆盖图标是需要的,哪些是不需要的,把不需要的项目的名称改一下,前 面加个“z”,这样,这个表项按字母排序就自动排到最后面了。哪些是不需要的呢?比如:网盘的“正在同步图标”就没什么用,可以去掉。其它的,可以自己看 着办了。
 
如果你进行调整后,把TortoiseSVN的所有覆盖图标全部提前,但TortoiseSVN仍然不会显示忽略图标、未版本化图标。为什么呢?研 究了TortoiseSVN的源代码才发现,原来TortoiseSVN会自己分析在ShellIconOverlayIdentifiers中注册的覆 盖图标数,如果注册了太多,TortoiseSVN会自动屏蔽一些无关紧要的图标,目的是让别人软件的覆盖图标尽可能有机会显示。也就是说,如果你希望, 显示TortoiseSVN的这些它自己认为“无关紧要”的覆盖图标,你需要删除一些别的程序的图标,把覆盖图标的总数减小到13个以下,这 时,TortoiseSVN才会正常显示忽略图标、未版本化图标等无关紧要的图标。”

----------------------- 分割线 -------------------------------------------------------

对于我自己机器, 看了下注册表,ShellIconOverlayIdentifiers的目录树如下:

    !!!BoxFlashSyncExt1
    !!!BoxFlashSyncExt2
    !!!BoxFlashSyncExt3
    !!!BoxFlashSyncExt4
!IconOverlay_Conflict
!IconOverlay_ForbidSync
!IconOverlay_LargeFile
!IconOverlay_Synced
!IconOverlay_Syncing
.KLive_OverlayIcon_ForbidSync
.KLive_OverlayIcon_Synced
.KLive_OverlayIcon_Syncing
1TortoiseNormal
2TortoiseModified
360UDiskGuard Icon Overlay
3TortoiseConflict
4TortoiseLocked
5TortoiseReadOnly

...

...

怪不显示不出SVN的图标呢,在SVN要overlay icon前面有好多个野蛮的icon,酷盘、115 、快盘三个网盘也是想尽了千方百计让自己的overlay icon能够被显示出来。居然连感叹号,空格都用上了。

酷盘对应的overlayicon为:

    !!!BoxFlashSyncExt1
    !!!BoxFlashSyncExt2
    !!!BoxFlashSyncExt3
    !!!BoxFlashSyncExt4

115 对应的overlayicon为:

!IconOverlay_Conflict
!IconOverlay_ForbidSync
!IconOverlay_LargeFile
!IconOverlay_Synced
!IconOverlay_Syncing

快盘对应的overlayicon为:

.KLive_OverlayIcon_ForbidSync
.KLive_OverlayIcon_Synced
.KLive_OverlayIcon_Syncing

既然知道原理了,那就挨个把网盘干掉吧。

其中:115网盘属于半绿色安装,因为只有Sync115Ext.dll (在C:Users用户名AppDataRoaming115Box) 被注册,它正在shell overlay icon对应的dll,因此,只需要将它反注册一下就可以了:regsvr32 /u Sync115Ext.dll。

经过卸载,ShellIconOverlayIdentifiers的目录树终于干净了,目录树如下:

1TortoiseNormal
2TortoiseModified
360UDiskGuard Icon Overlay
3TortoiseConflict
4TortoiseLocked
5TortoiseReadOnly

...

...

最后,重启一下,或注销一下,SVN图标终于重建天日。

最后终极解决方案:

在网上有部分解决方案是更改SVN图标名称,让其排序靠前来解决此问题,但是在window xp下我通过此方法无法解决此问题,猜测应该是即使SVN图标排序靠前,但是SVN仍然会将自己的图标优先权让给其他软件,所以最有效的解决方案是删除所有其他软件的图标,只留下SVN的图标,但是此方法的弊端是360云盘、百度云盘等其他软件无法显示图标,所以具体如何解决此方案,还是大家自己权衡吧!

1、 到C:Windows文件夹下,打开regedit.exe
2、 Ctrl+F,搜索“ShellIconOverlayIdentifiers”
3、 把ShellIconOverlayIdentifiers下面的节点非SVN的全部删除即可。
最终效果如下图

3、删除完其他软件的节点后,可以重启电脑或者在任务管理器中结束explorer.exe进程(如下图),

然后在任务管理器中重新开启explorer.exe进程,如下图,单击任务管理器->文件->新建任务(运行...

然后进入下图窗口,

在打开中输入:C:WINDOWSexplorer.exe 单击确定即可!
完成上述操作,再次打开SVN客户端目录,刷新就可以看到图标了,祝你好运!

Win7 64位下TortoiseSVN的文件夹及文件SVN图标不显示正确解决方法

最近为了代码版本管理,安装了SVN服务端与客户端,安装TortoiseSVN之后,功能正常,但是就是文件夹或文件夹的左下角就是不显示SVN图标,之前在XP上是正常显示的。通过网络查找,发现以下方法可以解决问题。

Windows Explorer Shell 支持的 Overlay Icon 最多 15 个,Windows 自身使用了 4 个,只剩 11 个可扩展使用,可能这 11 个位置部分可能被其他的软件占用了,导致 TortoiseSVN的某些重要的图标不显示了。不过,可以重新命名以调整 Tortoise 图标名称的字母顺序,让SVN的排在前面,Windows 内部就是按图标名称的字母顺序来优先显示的。

第一:

输入:win+R,(开始->运行)输入regedit.exe,调出注册表管理器

(1)按下Ctrl+F,在注册表里搜索 ShellIconOverlayIdentifiers
(2)或是查找: HKEY_LOCAL_MACHINE -> SOFTWARE -> Microsoft -> Windows -> CurrentVersion -> Explorer -> ShellIconOverlayIdentifiers

第二:将TortoiseAdded、TortoiseConflict……TortoiseUnversioned 右键->重命名,如命名为:0TortoiseAdded、1TortoiseConflict……8TortoiseUnversioned。如下图:

第三: 重启或是注销电脑之后,最后文件夹连接服务器后有了图标

更多精彩内容其他人还在看

打印机端口改不了怎么办详细解决方案

驱动程序安装完整后,将打印机重新连到服务器端。在客户端电脑上配置打印机端口。客户端安装打印机后,创建的本地端口是 “USB001” 。需要把打印机端口改成网络端口,下面与大家分享下具体的修改方法
收藏 0 赞 0 分享

64位系统不能玩英雄联盟的解决方法

因为很多人玩的游戏是针对32位系统的,所以游戏内的DirectX9插件安装不正确,所以才会提示出错,比如提示:缺少d3dx9_43.dll
收藏 0 赞 0 分享

电脑开机出现Invalid partition table错误解决方法

Invalid Partition Table 就是无效分区表,一般是由于电脑中毒或硬盘分区表有问题造成的,一般通过重写硬盘分区表
收藏 0 赞 0 分享

因动态磁盘引起的系统无法引导解决方法

因为VMVare本身的虚拟技术和Windows Phone模拟器相冲突,从而使得在Visual Sutodio Express For Windows Phone 中的调试时,连接模拟器出错,找到解决资料后与大家分享
收藏 0 赞 0 分享

Mac下SSH登录不上提示错误的解决方法

登录虚拟机的的linux时,提示未知错误: REMOTE HOST IDENTIFICATION HAS CHANGED,经搜索找到了解决方法,有类似问题的朋友可以参考下哈
收藏 0 赞 0 分享

host 不起作用问题的解决方法

由于某种需要,需要将域名指向指定的ip地址,平时挺好用,今天发现不能用了,注册表,host文件也修改了都不能用,经过排查,原来是host中的文件顺写反了
收藏 0 赞 0 分享

为什么电脑空闲时(隔一段时间)ADSL就自动频繁断线

只要我一直玩《英雄联盟》 《穿越火线》或者不停地上网一切正常,但只要不碰电脑,隔一段时间后ADSL就会自动断线,下面与大家分享下造成此原因的具体解决方法
收藏 0 赞 0 分享

USB设备运行不正常怎么回事具体判断方法

面对越来越多的USB设备,电脑总会给大家出点小难题,比如说USB设备运行不正常了,下面与大家分享下具体的判断方法,感兴趣的朋友可以了解下哈
收藏 0 赞 0 分享

电脑语言栏不见了(输入法)丢失怎么办(多种找回方法)

语言栏(输入法)丢失问题可能是你自己误删除,也可能是广告木马,输入法图标不见了的现象。必须进行修复才能解决这个问题,具体的修复方法如下,有类似问题的朋友可以参考下哈
收藏 0 赞 0 分享

ThinkPad X100e不显示问题通过焊北桥解决

一个ThinkPad X100e,故障就是什么也不显示,经过一番折腾,根据之前学过的知识,焊北桥,开机以后居然正常显示了,特与大家分享
收藏 0 赞 0 分享
查看更多