「玩一玩」用TabControl实现新浪微博客户端面板
好难得晚上没酒局。。休息下。。既想弄点东西出来,又懒得废脑筋。。矛盾。。弄个小东西,然后看日剧。。顺便求推荐韩剧。。
果然还是山寨顺手又省脑啊。。
-----------
注意:关于TabControl的自定义制作方法,请看这篇文章。
本文源代码下载(VisualStudio 2005,.NET Fx 2.0):点击下载
现在而今眼目下,人类已经无法阻止新浪微博了。于是新浪趁机推出了自己的桌面版微博客户端,就是这个:
看起来似乎挺不错,那么我们试着用一下呢?(动画)
woo……这部分面板切换好像挺有意思的。
发挥我们的山寨精神,开始分析。
分析
很显然,这是一个类似TabControl的控件。当然,具体是什么我也不知道。Who cares?我们只需要做个样子就行了。现在开始解剖。
抛开渐变背景这些次要内容,可以看到,这个和《一步》一文中仿制Safari的标签几乎一样,所以很多代码可以直接借鉴过来。
而在上篇文章中没有实现的面板缩放,虽然简陋,但这次总算是完成了。使用下面的简单代码。
int count = 1; while (Height > ImageList.ImageSize.Height + 10 * count) { Height -= 5 * count; count++; } Height = ImageList.ImageSize.Height;
protected override void OnMouseMove(MouseEventArgs e) { if (DesignMode) return; if (!HotTrack) return; hoverIndex = getTabIndexAtPoint(e.Location); Rectangle rect = Rectangle.Empty; if (hoverIndex > -1) rect = GetTabRect(hoverIndex); if (rect != Rectangle.Empty) Invalidate(rect); else Refresh(); base.OnMouseMove(e); }
int len = 10; PointF a = new PointF(rect.X + (float)(rect.Width - len) / 2.0f, rect.Bottom); PointF b = new PointF(a.X + len, a.Y); PointF c = new PointF(a.X + len / 2.0f, a.Y - (float)Math.Sqrt(3) * (len / 2.0f) / 2.0f); PointF[] points = new PointF[] { a, b, c }; g.FillPolygon( Brushes.White, points );
[解决办法]
小王子碉堡了 谢谢分享
[解决办法]
碉堡了,你的很多东西我还没动手练习呢。
现在晚上回去开始看你发的那个人脸识别的东西了,想根据你的东西做个小工具
[解决办法]
不会向我要版权保护吧
http://img.my.csdn.net/uploads/201201/4/4880885_13256495295z7W.gif
[解决办法]
- -!韩剧啊……王世子看完了,还行...
最近在追《幽灵》……李沇熹美啊……yebi你会喜欢的……
[解决办法]
野比是谁?
[解决办法]
[解决办法]
[解决办法]
山寨小功能蛮有意思的
之前我试着山寨win7的桌角标签功能,没成功
[解决办法]
楼主你玩你画我猜厉害不
[解决办法]
幽灵 我已经忍不住看了,结果看得欲罢不能,很支持yebi你等它出完了再看
[解决办法]
为啥不用wpf?
[解决办法]