2010年6月30日星期三

笑话 1-50

1.早上上班坐地铁,人多特别挤! 旁边有一个女孩子长得非常卡哇伊正在发短信,我无意看了一眼发现她写道“今天车上人很多,很挤” 一会儿我想起个事自己笑了几声。一会儿无意回头一看,看到这个女孩继续写道“旁边还站着一个SB”



2.早上公车上,一个人从包里掏手机看时间,然后说了句”我CAO”,还以为他时间来不及了,再仔细一看,我Cao他手里拿着一个空调遥控器



3.跟一姐姐聊天 她说:

前天我老板,一个男的,和真懂似的,在我的电脑后面看半天,说“小柯,你也种菜啊?这可是上班时间!”

我收了收瓜子皮,,,瞅瞅他

说“张总,这是我的桌面,你见哪块菜地上站着超级玛利呢?”



4.说个高中时的
记得是周末,有几个人在教室自修,我看到班上一尖子生(男)诺有所思的看着《青年文摘》的封面(封面上是一个女的穿着一件很薄的白衣服站在田野上),就走过去问他:这封面有什么好看的?
答曰:这女的好像没穿内裤 ...



5.昨晚和女友开房了,用的剩下的TT早上退房时顺手装在了裤兜里,去超市里买完东西结账掏钱时就把TT给掏出来了,哎!好长的一条啊 收银员和后面排队的人估计都看见了 真想地上找个缝。。。



6.和女友异地,QQ视频聊天,她去洗澡,我在这边上H网暗爽,可耻的Y了,用手在下面慢慢的弄,突然感觉要s了,站起来很爽的解决了,一时忘记了开着摄像头。关了网页,发现女友不知道什么时候回来了,正惊讶的看着我...



7.一次我在街上溜达,突然尿急,就随便找了一个小巷子方便。刚掏出JJ,左边来了一个4.50岁的女人。我往右转,一抬头,4.5个16岁左右的女孩惊奇看着我,估计JJ被她们看的一清二楚。我提上裤就跑。妈呀 真想找个老鼠洞钻进去...



8.一次和几个朋友约在我家集合,然后出去玩.就差一个哥们,人就全了.无聊,就在电脑上看电影,法国片《你丫闭嘴》,还是东北话版的,很搞笑.

这哥们姗姗来迟,见我们看的很有兴致,问:“什么电影啊?”

我说:《你丫闭嘴》

这哥们说:我问你电影什么名字?

我说:不是告诉你了么,《你丫闭嘴》啊!!

这哥们似乎明白了,点头说:噢

……

隔了几天又聚,这哥们突然拉住我,问:你告诉我,上回你们看的电影到底叫什么?

我无语……

9.高中时候有次,全宿舍去喝酒,全都挂了,迷迷糊糊回宿舍后就都睡了.我们宿舍的床是那种上下床铺的,每间宿舍2张床.隔天一早醒过来,我隔壁床的下铺正对着上铺狂骂,一问才知道,昨晚他上铺睡到半夜,想吐,特清醒的下床对着下铺一阵狂吐…吐完还小了个便…又心满意足的回去睡觉了…他下铺早上起来才发现…那个囧啊……



10.以前想学《成长的烦恼》里的迈克作弊,把考试内容写在鞋底上,为此特意买了双平底鞋,万事具备,没想到那天下雨…



11.一个同学,他的电脑每天早上会自动开机(估计是因为宿舍里早上来电的时候一瞬间冲开的)。

结果他老人家拿了一个符贴在了电脑上……



12.在一所幼儿园的一个很大的班级里,老师让小孩们问问题,
大家一个问完接下一个,有个小孩一直把手举在空中,
不过当轮到他问时,他却把手放下了。
老师问他「怎么了你等了这么久,为什么轮到你讲,你却把手放下了? 」
小孩回答说: 「来不及了,已经湿了。」





13.前段时间QQ离开的自动回复非常简洁——“不在!”
于是出现了这样的聊天记录:
——在吗?
——不在!
——真不在?
——不在!
——问你件事情哦,你的初吻还在吗?
——不在!
——啊?那你的初夜还在吧?
——不在!
——你的贞操还在吗?
——不在!
——喂,你太过分了,你的廉耻心还在吗?
——不在!
……………………
mm遂改自动回复…





14.走在拥挤的街上背后忽然响起急促霸道的鸣笛声,还没反应过来,一辆别克商用车就撞上了我的肩膀;我没发火,只是轻轻的拿出钥匙,在它前进的过程中从头到尾的划了道优美的曲线~



15.在一地摊上买袜子,一块一双,便宜,本来想买三十双,结果只剩下同一黑色款式的了,卖袜子的忽悠我说,一种颜色好,丢了一只拿其它的顶上谁也看不出来...一想也对,于是买了三十双....

就这样两天一换的...

结果过了快两个月,我同桌实在看不下去了,说:懒死你了,怎么两个月你连袜子也不说换一双

我:....





15.一时兴起、拿自己照片当电脑桌面…然后我的电脑就中毒了…



16.今天和一个非常要好的异性朋友约好逛街,半路口渴就买了瓶鲜的每日C,她一口我一口的喝着,喝完了找个地方坐下,不知什么时候话题聊到大家今天早上做了什么事,结果她说今天早上和她男朋友KJ了,我顿时感觉胃向上翻~



17.裤兜里装着瓜子,女同事(漂亮MM)要我不给,她下手向兜里硬掏,我向后一转身,她就抓着我的JJ了~~

郁闷,喊疼也不是,不吭气也不行。





18.昨天和同事出去遛弯,在道上看见只鸡,就用叫狗的方法叫了一下,同事用特别鄙视的眼光看了我一下说“真没学问,叫鸡是这么叫的吗,应该是这样叫。”看他憋住了气,酝酿一下,大喊了一声“多少钱”。…………





19.某日,体育课中途,洗手间解决个人问题。结果着急误进男厕。看到一男生正在小便池嘘嘘,俺当时就蒙了,一秒过后正准备悄悄撤退,结果被发现,晕死。只见那男生大叫一声“流氓,非礼”然后双手捂胸。后来,后来俺说了一句自己都觉得不可思议的话“同学,你捂错地方了……”





20.停车等人,路边田坎上两狗交尾,车上众人注视良久。
未几,驾驶员回头说话:“我硬了”





21.我在学校门口买了一个工艺品:“夜光葡萄”(摊贩宣传说的) 回去发现它根本不夜光,把它一颗颗扎破,把紫色的水放掉,再把缠着的绳子解开,发现它根本就是一个安全套…





22.学A出车祸,脚骨折,住院

我们几个玩得好的同学去看他

一进住院部就遇见了他爸妈

我连忙上前去询问A的病情

结果一开口就变成了

“叔叔阿姨,A是怎么死得啊~~。。。”

他爸妈脸都绿了。。





23.初中的时候,有一次和堂姐玩,她问我:你吃糖吗?我裤裆里有(想说裤兜的)。 我:。。。。不吃!





24.来发个我们楼里的事吧……我们楼里老外基本脑残,有一个家伙说要做葡萄干给我们吃,结果就真的吧葡萄放进微波炉了,我没见过这样做法,以为他经常做,也就不去管他了,谁知道,火警了,悲剧了,消防队都出动了,还被我们tutor骂了一顿……@——!结果后来我问他,他说也是第一次做!OMG!创新精神可嘉!





25.问:怎么形容暴发户.?


答:昨天还在卖.淫 今天就去嫖.娼





26.某好学生,本学期第一次犯错,比较严重,被老师批。
老师把她拉到办公室,批评了一会,说了几条惩罚措施。
此生希望老师能原谅她的这次错误,小声地说:老师…不要…人家是第一次……

后面所有人表情严肃,憋得脸都青了。等学生走了,办公室里的笑声,那个叫放肆啊……



27.昨晚躺床上给女朋友发信息:“宝贝,洗过PP了吗?我在彩虹被子里面哦!”等了一会,我亲爱的计算机老师发信息过来:“我洗过了……”彻底对自己无语,这样的信息都能发错,真是郁闷……





28.有次,我和女友正在ML,G潮时,我老爸突然不知为什么就进来了,三人一时很尴尬。我脑袋短路的来句:“老爸,要不,你也来一次?”老爸忙说:“不了,不了,我房间里有,房间里有。”然后出去了,我女友气的直想打我





29.我掏口袋的 时候,一把钥匙掉了,当时没有发现,后来回去找!
在路边有对小情侣在那里,男的 突然激动的说:是 谁的?到底是 谁的?
我当时以为是 钥匙连忙说:我 的,我的!是我 的
后来才知道,原来那女的怀孕了。。。。
可怜我 的脸啊 。。。疼了几天





30.昨天晚上,和BF去超市新买了一盒安全套,晚上睡觉时,BF脱下裤子,叫我用手安抚下他的小弟弟,待我把他的小弟弟安抚得“昂首挺胸”后,他拿出一个TT,并未拆开,只是拿着在弟弟上比划了下说:恩,大小刚好。然后对我说,把TT收好,睡觉了。。。





31.A:这是上天的警告吗?
在苏州,现在外面下大雨,刚刚一道闪电在离我不远的地方击中地面(在阳台抽烟时),是不是老天在对我警告呀,因为我正在下几部日本电影。求解!!!

B:他在提示你,用迅雷





32.上大学那会,学校通报批评了一个夜不归宿去网吧整夜上网的童鞋(通报是贴在木质展板上的)。第二天展板上空空如野,学校也没直接证据就是该同学撕的。无奈,只好再帖,第二天又没有了,如此反复。学校有点毛了,用特大字又写了一边,下边还标注:再撕者开除学籍!第二天——展板没了!





33.早上洗头,手机放旁边搁板上。洗完一抬头,发现手机沾了点泡沫,非常自然地拿到水龙头下面冲了20秒。冲完很干净,很满意,顺手又用毛巾把手机表面擦干。看着焕然一新的手机觉得今天实在是太美好了。2分钟后傻了,关机、开后盖、卸电池,看着水珠从手机内部淌出来…





34.老婆的一个同事注册结婚了,大家去贺喜,这位仁兄姓“卞”,于是大家一起说“恭喜你,小便**你终于结婚了”,接着有人就对着她夫人说“恭喜您,荣升为变态”,另一位则说“将来,小便**将来要有了秘书,我们都要称之为便秘”,最后一位幽幽地说“这将来有了孩子,可是要称为变种了”。





35.大学期间,一天下晚自习,我闲的蛋疼,就在校园乱逛,恰好看到一对恋人在吵架,女的不断的骂那个男生,男的一直在忍,最后估计把那个男的骂急,那个男的回了一句非常雷人的话,至今都不敢忘记,男的狠狠的说:再吵,再吵我就把你白带吸出来。女的瞬间无语。





36.小明上完厕所回到教室跟老师说:“厕所有好多蚂蚁 老师忽然想到蚂蚁的英文ant这个单词,于是测试小明:“蚂蚁怎么说?”
小明一脸茫然……说:“蚂蚁他……什么也没说……”





37.小时候年幼无知,只看过我妈穿胸罩,便以为胸罩是我妈专属的东西。于是有一段时间,我每天抱着撑衣竿子去院子里把所有的胸罩都收回家。邻居女人们日日来我家索要胸罩,我每天执着的守护着家门口,朝她们大喊,全是我妈的!~





38.一个年轻的猎人来向老猎人请教如何猎熊。老猎人说,通常我都是先找到一个山洞,然后向洞里扔一块石头,如果听到有“呜呜……”的声音,那里面一定有熊。你就跳到洞口,向里面开枪,一定能打到熊的。
过了几天,老猎人在医院里看全身缠满绷带的年轻猎人,很惊讶。
年轻猎人说:我去猎熊,先找到一个山洞,然后我向里面扔了一块石头,听到里面有‘呜呜……’的声音,我就跳到洞口……可是,我还没来得及开枪,从山洞里开出一列火车……





39.一个人买了一个只会说俩字谁呀的鹦鹉,有一天主人不在家,有个换煤气的来敲门。
鹦鹉:谁呀。
答:换煤气的
鹦鹉:谁呀。
答:换煤气的
……
主人回家门口躺个人,主人纳闷,这是谁呀
门内:换煤气的





40.一个国王要替公主征婚,把一个苹果放在公主头上,谁要把它射中就有机会迎娶公主。
第一个男士把苹果射中,他说:“I’m 罗宾。”
第二个男士也把苹果射中,他说:“I'm 后羿。”
第三个男士不小心把公主射死了,他说:“ I'm sorry..."





41.今年五一假期的时候,我和妈妈一起去商场,我们逛了很久。后来走到一个卖运动鞋的专柜,我妈要我试一双鞋,当时我累的不行了,甚至我觉得自己神志都不是很清楚。~~~~可能是之前试裤子试的太多了吧,我竟然二话不说,就开始解腰带,接着又很自然的要拉裤门,天啊,我妈,叫到,喂,你干什么!!??

我这才反过味来!那个卖鞋的售货员看着我都呆了。我当时真是……哎!脸和烧猪一样烫呀!太丢人了!

42.我弟弟去某小学打篮球,听到一低年级女生问一个低年级男生:“你到底爱不爱我???”那男生无奈道:“我妈一天给我3元钱,其中两块五都让你拿去买零食了,你说我爱不爱你..



43.听朋友说的,他一个同事的亲戚来厦门,亲戚给了一张厦门e卡通,上公车,此人给司机看了一下e卡通,就想去找位置了,司机叫住他,说:"读卡啊",他就拿起e卡通,大声念到:"厦门e卡通~~",司机说:"到那边读",这人居然直接走到司机指的地方,用尽全力念道:"厦门e卡通",……车子当场失控



44.我们数学老师总喜欢故作幽默的说些个没人笑的笑话

我们全班就商量恶搞他一把,等他上课说第一句话的时候,我们就全体齐声大笑


那天他进来,沉默了一下 说他爸去世了

我立刻放声大笑,其他人鸦雀无声。





45.逛超市呢

看到一收款员在很认真数一堆硬币

一小孩跑过,边跑边唱:门前大桥下游过一群鸭,快来快来数一数,二四六七八。。。。

然后收款员很郁闷的把数了一半的硬币倒回去重数....





46.高中的时候住校,有同学回家让他帮我捎点东西,便发短信:给我烧点衣服和钱。





47和女友约会,看到前面有个和我女友很像的了,就上去拍了下她屁股。
她一转头就给了我一巴掌。
这时有人拍我肩膀…
我一转头女友就给了我一巴掌。





48.那天突然接一个电话:“猜猜我是谁?猜中有礼物哦!”
我把可能的人都猜了一遍,还不对。后来我怒了,问“你TM到底是谁?不说我挂电话了!”
结果那人说:“我是送快递的,你有一个包裹……”
当时我就吐血了。





49.天晚上和LP带儿子去旁边的旋转餐厅吃自助,人多拥挤,和一对小情侣坐在一起。
也许是我穿的有够土,胡子也没有刮。旁边小情侣当我是土老冒来着,于是两个人用英语开始交谈。真是什么话都敢说啊,从昨天晚上ML的感受,到最近的电影。....当我们听不懂(其实我和我LP是大学同学,那点日常对话随便听听)
后来他们实在没有话说了,居然把话题扯到我头上。说我LP很漂亮,说我穿着不怎么样。说看我不象有钱人为什么可以找到漂亮的LP...
我那个晕啊!我LP在旁边笑到岔气
后来我们吃好了,准备回家。
我用英语对那男的说:其实你女朋友对你昨天晚上还是很满意的,如果你不强迫她给你KJ那就更完美了



50.小学五六年级时,一天晚上在表弟家看电视。

看 CCTV-6。到床戏时,姑姑拿着遥控器就要换频道,说:小孩子不能看这个。

弟弟一把抢过遥控器,喊:中央台不会脱的,你看。

结果,果然没脱





51.小时候和隔壁大姐姐玩(我五岁她十七),她叫我舔她那,舔十分钟就折个纸星星给我,不许我和别人讲,不然以后都不给我折。
现在,我还常常看着我书柜上满满的一罐纸星星发呆,YY着隔壁的人妻...

2010年6月28日星期一

笑话 转自6Park

1.昨晚座公交,快到终点了特别空,一年轻女子投入地讲电话,先是很小声,边讲还边抽泣,突然嗓门放大来了句颤音:“你到底要做我丈夫还是姐夫!” 稀稀拉拉几个人瞬时安静侧目,陷入无限联想中……

2.某天自己下楼逛超市回来,刚一开门,娇声娇气的朝屋里问了句:先生,要服务吗?结果老公没应声,狗狗喜颠颠跑过来奶声奶气的:“汪、汪!” 老公笑倒~

3.大一由于校区没建好,学生太多,大一在陆军学院上学,那里有军队,一次学校组织看电影,得2块钱买票,我和我哥们阿磊没买票不想去,吃完饭我们又想去,我俩就结伴寻思能偷着进去看个免费的,我们俩来到大礼堂,手刚伸到门把手,身后一片亮光,我以为是探照灯,我对磊说,我草,果然是军校,然后我俩把手举起来了,结果一辆汽车转弯而去……

4.话说高中的时候,手机还是非常昂贵的。某同学攒钱N久终于买了一部M牌的带电线,那叫做一个爱不释手啊。因为怕磨损,去手机店贴膜。当天也是巧了,正好手机膜卖光了。这同学灵机一动,去药店买了一个安全套,直接套在手机上了,颗粒正好在键盘上,按起来手感还不错。最搞笑的:前边的储jing囊。正好放天线,后来每次打电话,引来目光无数……

5.上厕所撒尿,看到池子里有只小飞虫在飞,很小的,于是我就瞄准它尿…它飞哪我尿哪…

完事之后回头,背后一哥们傻傻的看着我…估计是没见过大学生尿尿乱甩JJ的…唉…

真想告诉他我在除害虫

6.(某游戏中)猎人叫“你的老婆和我”,他的宝宝叫“发生了关系”,pvp时战斗显示:
你的老婆和我的宠物发生了关系对你造成了致命一击!

7.昨天在家和弟弟玩,他9岁 模仿武侠剧里的情节,两个人手并在一起,发功,然后互相推。他力气没有我大,节节败退 接着,他说,我要使绝招了 “鸡鸡复鸡鸡” 然后就迅速的到我下面抓了一下……他狂笑“厉害吧” 我呆掉,我是24的女生啊.

8.话说我一个哥们第一次坐飞机,登机时站到飞机门口 看着机身一脸的神往...空姐就很诧异的看着他,这哥们上去对着机身啪啪啪就是几巴掌,边打边感慨:"终于打到真正的飞机了。"

9.我是儿童牙医,有次一小女孩来补牙,五六岁吧,怕疼,一上来就恳求我说:叔叔,叔叔你轻一点阿。小姑娘又长得特可爱特水灵的那种,故意逗她:什么叔叔,把我叫老了,应该叫哥哥!于是可爱水灵的小姑娘改口了,整个治疗过程都边啜泣边抽泣边哽咽着大喊:哥哥,哥哥…你轻一点啊,呜呜……呜呜……然后整个治疗室全听见了… 乐得她妈跟我们那边护士半天直不起腰来…

10.在某论坛上看到一巨有才的哥们儿征女友。其贴子透着一股蛋疼劲儿,最亮的几句话是这么说的:本人处男,性功能健全,满血满蓝20分钟以上! 于是底下跟帖的有人问,既然是处男,怎么知道是20分钟以上? LZ回复:手测!跟帖众人绝倒一片……

11.和BF在一起两年多了,平常和BF睡觉在一起都睡惯了,第一次带BF带回家,结果被安排BF和我爸睡,我和我妈睡!到了晚上我楞要往老妈身上翻,老妈把我一掌给掴下来了,接着我又把老妈两腿间摸了个遍。最后,老妈忍无可忍从床上跳起来,啪,啪两巴掌把我给打醒了说:“你个小死妮子,要死啊!”而后,我彻夜未眠……

12.宿舍有一自命不凡的帅哥,女友如云!丫的口号:没有追不到的女孩。当场我生气了,打赌50块,让丫的去追我们的班长(不同班)。丫的就是牛,当场答应了。第二天他回来“草,你班长是男的。”第三天我输了50。

13.和老公在外面KF,两人一起看《非诚勿扰》正看到起劲的,上面房间一男一女正战况起劲~那女的不停的很大声的呻吟……一开始我们两个还打算忽略。后来她越发起劲的喊。影响看电视情绪了。老公贼笑的看着我问:怎么办?于是,我深吸一口气,大声的喊了句:“ 啊~老爸,你好厉害哦~啊~”楼上顿时鸦雀无声。老公雷倒……

14.上周五社会心理学让写一篇关于富士康九连跳的分析,TMD还没交就十二连跳了,题目都改了三四遍,为了学术的严谨性持续观望中……

15.有个姐姐,娘家夫家都很有钱那种,去生小孩,包了很丰厚的红包打点医生护士。 结果生的时候超顺利,医护人员们觉得这么简单太对不起人家给的红包,就顺手把处女膜给修复了。

16.骑电动车,路很颠,没肩带,到家以后,胸罩变肚兜……

17.四月1号美国《国家地理》杂志说,三峡坝区的储水重量将让地球的自转轴偏移近一英寸(2.54 厘米)——终于让世界知道了中国的份量。

18.大一的时候有一次放假回家,本人为了省钱所以坐火车回去。到达目的地时已经快午夜了。没办法,得坐出租车回家了,遂拦下一辆出租车。然后问价,司机说要十元,我说只给八元,最后达成一致就八元。在上车之前,弱弱得问了句“你是坏人吗?”那司机看了我一眼淡定得回了句“你才是坏人…这么晚打的就给我八块钱…”

19.朋友公司来了个小伙子,很nice,勤劳从没牢骚。经常说人能活着就很不容易,眼前的生活都是老天给的,要珍惜。朋友感叹,这小屁孩太淡定了。后得知:丫是新疆克拉玛依人,克拉玛依大火的时候他们学校去的大巴坏了没到,后来考入云南大学,马加爵就住在对门宿舍……叹道,小伙儿淡定是有理由的。

20.高中时有次上网看见一个据说是老外的隐晦签名:8==D,百思不得其解遂拿到学校问班上同学,问遍全班竟无一人知道其意,最后让一MM看,突然脸红,骂我流氓,我莫名其妙,求她说是什么意思,她只是脸红最后也没告诉我…

21.妹妹今年12岁,今天放学回家回到卧室关上门 ,我以为她干嘛呢,就开门边问她干嘛呢?妹怒吼“别进来!” 晚上看电视,妈妈跟我说,姑娘来月经了,妹妹才12岁呀,真早熟!正晕着呢,爸爸来了句:“又多了一项开销呀!”

22.一死党学成要回国了,把带不走的东西都送人了,什么书啊家具啊。去机场送他时,进安检前把我拉到一边,很不好意思的说:也没什么好送你的,只剩下一些非物质文化遗产了。说完提笔在纸上写下近十个色情网站的地址和帐号密码……

6Park

一天小粥在家看电视, 三哥来找他去游泳

这时电视里正好在讲解游泳的注意事项, 其中一则说带伤口者不宜游泳,以免感染....

小粥犯懒了说到: 还是改天吧我刚修完脚指甲, 没看电视里说的, 不宜游泳吗

当时只见三哥面带,箭步走到小粥面前piapia给了两巴掌, 说道: "呵呵, 你丫的走不走,偶还刚剃完鼻毛呢"..........

麽麽一天约他心仪已久的杨杨去看电影

当全场暗下的瞬间,麽麽悄悄的靠过去,迅速地亲了杨杨的脸颊

杨杨先是一惊,但马上就反应过来,她并不生气但又不甘愿白被吃豆腐就娇滴的骂了一句: "你...讨厌... 哼,偶就当作被猪咬了一口".

麽麽知道表白成功了,欣喜若狂,但又不想立刻表露出来, 装傻说道:"没有啊, 偶哪有咬...."
原创3: 话说芒果小时候十分向往学校,终于到了上学的年龄,他兴冲冲的上学去了~

在课上,小芒果十分积极地发言,可他每次都忘记举手,虽然老师每次提醒他,当他屡教不改,最后老师有点烦了,严厉地批评他的行为,说: "@#$%&(省略三分钟的口水不计).... 下次发言给我...举!手!"~

小芒果没想到如此被人泼冷水,气愤的回到: "俺不举, 不举, 不举, 不举, 就不举, 俺从前从没举过, 凭什么要我现在举. 告诉你, 俺今后也不举,永远不举~~~~~"
原创4: 话说小粥小时候很淘气, 一天到二楼阳台上玩,正好见到他家小猫趴在围栏边晒太阳~~ 他想起在课本上看到猫能够从很高的地方跳下去就想试试~~

小粥将他的咸猪手放到小猫PP上,慢慢将小猫推出去~~~

小猫害怕地极力反抗, 但于事无补, 眼看就要掉下去了, 最后关头只见小猫使出一个神猫摆尾 加 惯性飘移, 瞬间迂回至小粥手背, 麻利地咬上一口,扬长而去~~~

"哇~~~~" 小粥疼得一PP瘫做在上哭了起来~~ 小粥他妈妈听到哭声过来看看~~

"妈妈~~ 小芒果咬我..我只不过想...." 小粥委屈地讲了刚刚发生的事, 妈妈听了,没有安慰小粥而是教育他不对的行为 (3000字省略)...

最后小粥不情愿地承认了错误~~~
妈妈: "那你以后到阳台玩,要留心点知道吗~~
小粥: "嗯, 我会格外留心的, 如果小芒果想推我, 我也咬他~~~~
.........

啥人整天释放大量二氧化碳还从不节俭用水,却一直被人们歌颂 --------------------- 消防局D

啥人整天理所当然地乌鸦嘴,没能力乌鸦的却被人们唾骂 --------------------------- 地震局D

啥人在一人之下万人之上,却每天端茶倒水气功哈腰,为生活忙得不可开交 ------------- 一文字菊D

6Park

1.一老农赶著毛驴进城,驴闯红灯,罚10元。老农喝驴子:“你以为你是军车啊!红灯也敢闯。”没走几步,驴又碰翻一水果摊,赔人200元。老农更气:“你以为你是工商城管么,想掀谁的摊儿就掀谁的摊。”老农牵驴回家,路过一片青草地,驴啃青草,又被罚30元。老农气极,骂道:“你以为你是检查团下乡么,走到哪儿吃到哪儿!” 老农骂完牵驴去河边喝水,可驴子却发起倔脾气,扬颈不饮。老农火了:“你以为你是大款啊,没小姐陪就不喝。”驴子掉头就跑,岸边晒一张渔网,驴上而破之,渔翁索赔500元。老农热泪盈眶道“你以为这是中国电信么,上网要花这么多钱。”驴子转身踢了老农一脚,老农忍痛骂道:“你以为你是群主么,想踢谁就踢谁。”驴子气得不再理老农,变的很沉默。老农说:“你以为这是在QQ群里啊,可以整天不说话!
2.一个乞丐敲敲车窗说:给我点钱.
先生看了下,说:给你抽支烟吧.
乞丐说:我不抽烟,给我点钱.
先生说:我车上有啤酒,给你喝瓶酒吧.
乞丐说:我不喝酒,给我点钱.
先生说:那这样,我带你到麻将馆,我出钱,你来赌,赢了是你的.
乞丐说:我不赌钱,给我点钱.
先生说:我带你去桑拿房享受“一条龙服务”,费用我全包。
乞丐说:我不嫖妓,给我点钱.
先生说:那你上车吧,我带你回去,让我老婆看看:一个不抽烟、不喝酒、不赌钱、不嫖妓的好男人能混成啥样!

3.从警校毕业的张先生结婚两年,总感觉妻子有些异样,怀疑妻子有外遇。一日,张先生总是发现妻子的手机上有一则陌生人的短信,而且每次短信的内容都是一样的:“赵兄托你帮我办点事。”!
  晚上十一点,张先生一举将出轨的妻子和那个正在苟合的男人擒拿。
张先生大骂:太小看我了,你以为那短信我不懂?倒过来读就 是“十点半我帮你脱胸罩
4.端午节乌龟想吃粽子,让蜗牛去买粽子。过了2个小时,蜗牛还没回来,乌龟急了骂道:他妈的再不回来老子就饿死了!这时门外传来了蜗牛的声音:你他妈再说老子不去了!
5.关于需求
0-5岁:女→妈妈 / 男→妈妈。
  6-10岁:女→不是讨厌的男孩子就可以了 / 男→可以陪我欺负女孩子的男孩
  11-15岁:女→十五六七八岁的大哥哥 / 男→足球,篮球,网球,乒乓球……
  16-20岁:女→十七八岁大家都称赞的“大帅哥” / 男→女人,女人就可以了!
  21-25岁:女→25-29岁的男人,有事业、品位、才华…… / 男→20~24岁漂亮又有身材的女人
  26-30岁:女→仍是坚持要比自己年纪大的男人 / 男→20~24岁漂亮又有身材的女人
  30-40岁:女→心灵契合的好男人 / 男→20~24岁漂亮又有身材的女人
  40-50岁:女→男人 / 男→20~24岁漂亮又有身材的女人
  50-60岁:女→可与她终老的男人 / 男→20~24岁漂亮又有身材的女人
  70-80岁:女→五六十岁时找到的那个,不需要自己照顾 / 男→20~24岁漂亮又有身材的女人
  80-90岁:女→比自己迟死的男人 / 男→虽然我已经老花眼,看不清楚……但是我还是希望是20~24岁……
  总结:男人打从20岁后,对女人的需求就十分专一!

6.赵本山骑驴进城巧遇范伟!
范伟问:“吃饭了吗?”
赵本山说:“吃了!”
范伟得意的说:“我问驴呢,你插什么话!”
赵本山转身抽了驴两耳光,骂道:“城里有亲戚也不说一声。”
7
一美女下夜班,被一色男子尾随跟踪,美女很害怕,正路过一片坟地, 色男子正要下手, 美女走到一座坟墓前说:“爸爸,开门吧,我回来了”。吓的色男子狂奔而去。 美女为自己的聪明得意地笑了起来,哪知笑声未落,从坟墓里传出一个阴森森的声音说:“闺女,你咋又忘记带钥匙了呢?”吓得美女尖叫著跑了。 这时,一个盗墓者从坟墓里爬了出来,说:“影响我工作,吓死你”。突然发现墓碑前有一老者,手拿凿子在刻墓碑,就奇地问:“你在干吗”?老者生气地说:“这些不肖子孙把我的墓碑都刻错了,只自己来改啦”。盗墓者一听,吓得撒腿就跑了。 看著盗墓者的背影,老者冷笑道:“跟老子抢生意,吓死你”。一不小心,凿子掉地上了,老者正要弯腰去拾,却看见从草丛中伸出一只手,同时还有个冷冰冰声音:“ 啊,敢乱改我家的门牌号”。吓得老者连滚带爬地跑了。 一个拾荒者从草丛中爬出来,捡起地上的凿子,感叹道:“这年头,捡块烂铁还得费这么大神。”

6Park

【知道你过得不好,我也就安心了。】

  【这位帅哥,你好像我下一任男友】

  【伯母你好,我是你儿子的男朋友】

  【不要叫我宅女,请叫我居里夫人】

  【真羡慕你这么年轻就认识我了。】

  【最近总是失眠,16小时就醒一次。】

  【大叔,帮我在配偶栏签个名呗?

  【人人都说我丑,其实我只是美得不明显。】

  【你有什么不开心的事?说出来让大家开心一下。 】

【有人撒你一身油,对你说:别担心,有奥妙全自动,你咋办?——打到他肾亏,对他说“别担心,有六味地黄丸,治肾亏,不含糖。”】

  【别到处嚷嚷世界抛弃了你,世界原本就不是属于你】

  【我们要向前看,不错过些歪瓜劣枣怎么知道什么是好

  【你到底喜欢我什么,我改还不成吗?】

  【我喜欢低调 我喜欢慢慢的渗透 我喜欢一点一点的征服 一步一步的策反 我要你一天一天的记取我的名字 我是糖衣炮弹】

  【他死,我记得。他生,我心动到惶然。】

  【我若为王,你必为后】

  【我要你作个旷古绝今的圣明天子,我要保住你的江山不容任何人染指,我要助你开承平盛世。

  我要—— 我要你看见天下,就想起谢长留!】

  【说你懂得生之微末,我便做了这壮大与你看,

  你说再热闹也终需离散,我便做了这一辈子与你看,

  你说冷暖自知,我便做了这冬花夏雪与你看,

  你说恋恋旧日好时光,我便做了这描金绣凤的浮世绘与你看。

  你说应愁高处不胜寒,我便拱手河山,讨你欢。 】

  【如果我真的好,你为什么不要。】

  【我多想一个不小心就和你白头偕老】

  【我曾经爱过的男孩,有着世界上最英俊的侧脸。 】

  【别轻易对别人说爱,别固执的将别人心门打开,又玩笑着离开。】

  【如有来生,请别用情至深】

  【爱情是一杯酒 我小心翼翼捧给心爱的人 他不小心碰撒了 于是我兑上了水】


  【有人向你索取东西,微笑着望向他:你要用什么来和我换? 】

  【生活不是林黛玉,不会因为忧伤而风情万种。 】

  【 新世纪女性:上得了厅堂,下得了厨房,写得了代码,查得出异常,杀得了木马, 翻得了围墙,开得起好车,买得起新房,斗得过二奶,打得过流氓... 】

  【 已经将整个青春都用来检讨青春,还要把整个生命都用来怀疑生命? 】

  【如果玫瑰很香,我会喜欢玫瑰。这玫瑰真的很香,那好,我喜欢这束玫瑰,但请把上面的脏手拿开。】

  【请转告王子,老娘还在披荆斩棘的路上,还有雪山未翻、大河未过、巨龙未杀、帅哥未泡……叫他继续死睡吧! 】

  【当初惊艳,完完全全,只为世面见得少。】

  【 对你微笑,纯属礼貌 】

  【有事找我,没事找事找我】

  【人和猪的区别就是:猪一直是猪,而人有时却不是人】

  【我爱你时,你说什么就是什么。 我不爱你时,你说你是什么。 】

  【总有一天你的名字会出现在我家的户口本上 】

  添加:

  【明骚易躲,暗贱难防。】

  【我终于能笑着回忆你】

  【你喜欢我这件事,我允许了。】

  【入党?姐我不稀罕!】

  【毁人不倦】

  【你说...你喜欢我?其实...我一开始...其实我也...唉跟你说了吧,其实我也挺喜欢我自己的. 】

  【无论我此时是如何的彷徨迷茫,最终,我都要过上自己想要的生活。】

  【要不是打不过你,我早跟你翻脸了。】

  【生命这么长,等你几年算什么】

  【来世记得早点来娶我。】

  【“我,已经是埃及的法老,我可以给你想要的一切。如果是合理的,那么你要一,我给你二。即使是不合理的,我一样可以做一个不明事理的君主,满足你。”

  -------埃及帝王谷法老拉美西斯二世给他的爱妃纳菲尔塔里的誓言 】

  【有本事.你就爱我一辈子! 】

  【我在这里,你就不会没有家】

  【此生,你不来,我不老】

  【你的岸是岸,我的岸便是海吗?】

  【你说你以后可能会和不喜欢的人结婚,没关系,我愿意做那个你不喜欢的人。】

让我流泪的人,我一定会让你流血。

2010年6月24日星期四

腐蚀,膨胀,细化算法

6 腐蚀,膨胀,细化算法

这一章的内容我认为是最有趣的。还记得前言中那个抽取骨架的例子吗?现在我们就来看看它是如何实现的。

今天所讲的内容属于一门新兴的学科:数学形态学(Mathematical Morphology)。说起来很有意思,它是法国和德国的科学家在研究岩石结构时建立的一门学科。形态学的用途主要是获取物体拓扑和结构信息,它通过物体和结构元素相互作用的某些运算,得到物体更本质的形态。在图象处理中的应用主要是:(1)利用形态学的基本运算,对图象进行观察和处理,从而达到改善图象质量的目的;(2)描述和定义图象的各种几何参数和特征,如面积、周长、连通度、颗粒度、骨架和方向性等。

限于篇幅,我们只介绍二值图象的形态学运算,对于灰度图象的形态学运算,有兴趣的读者可以阅读有关的参考书。在程序中,为了处理的方便,还是采用256级灰度图,不过只用到了调色板中的0255两项。

先来定义一些基本符号和关系。

1. 元素

设有一幅图象X,若点aX的区域以内,则称aX的元素,记作aX,如图6.1所示。

2. B包含于X

设有两幅图象BX。对于B中所有的元素ai,都有aiX,则称B包含于(included in)X,记作B X,如图6.2所示。

3. B击中X

设有两幅图象BX。若存在这样一个点,它即是B的元素,又是X的元素,则称B击中(hit)X,记作BX,如图6.3所示。

4. B不击中X

设有两幅图象BX。若不存在任何一个点,它即是B的元素,又是X的元素,即BX的交集是空,则称B不击中(miss)X,记作BX=Ф;其中∩是集合运算相交的符号,Ф表示空集。如图6.4所示。

6.1 元素

6.2 包含

6.3 击中

6.4 不击中

5. 补集

设有一幅图象X,所有X区域以外的点构成的集合称为X的补集,记作Xc,如图6.5所示。显然,如果BX=Ф,则BX的补集内,即B Xc

6.5 补集的示意图

6. 结构元素

设有两幅图象BX。若X是被处理的对象,而B是用来处理X的,则称B为结构元素(structure element),又被形象地称做刷子。结构元素通常都是一些比较小的图象。

7. 对称集

设有一幅图象B,将B中所有元素的坐标取反,即令(xy)变成(-x-y),所有这些点构成的新的集合称为B的对称集,记作Bv,如图6.6所示。

8. 平移

设有一幅图象B,有一个点a(x0,y0),将B平移a后的结果是,把B中所有元素的横坐标加x0,纵坐标加y0,即令(xy)变成(x+x0y+y0),所有这些点构成的新的集合称为B的平移,记作Ba,如图6.7所示。

6.6 对称集的示意图

6.7 平移的示意图

好了,介绍了这么多基本符号和关系,现在让我们应用这些符号和关系,看一下形态学的基本运算。

6.1 腐蚀

把结构元素B平移a后得到Ba,若Ba包含于X,我们记下这个a点,所有满足上述条件的a点组成的集合称做XB腐蚀(Erosion)的结果。用公式表示为:E(X)={a| Ba X}=X B,如图6.8所示。

6.8 腐蚀的示意图

6.8X是被处理的对象,B是结构元素。不难知道,对于任意一个在阴影部分的点aBa 包含于X,所以XB腐蚀的结果就是那个阴影部分。阴影部分在X的范围之内,且比X小,就象X被剥掉了一层似的,这就是为什么叫腐蚀的原因。

值得注意的是,上面的B是对称的,即B的对称集Bv=B,所以XB腐蚀的结果和X Bv腐蚀的结果是一样的。如果B不是对称的,让我们看看图6.9,就会发现XB腐蚀的结果和X Bv腐蚀的结果不同。

6.9 结构元素非对称时,腐蚀的结果不同

6.8和图6.9都是示意图,让我们来看看实际上是怎样进行腐蚀运算的。

在图6.10中,左边是被处理的图象X(二值图象,我们针对的是黑点),中间是结构元素B,那个标有origin的点是中心点,即当前处理元素的位置,我们在介绍模板操作时也有过类似的概念。腐蚀的方法是,拿B的中心点和X上的点一个一个地对比,如果B上的所有点都在X的范围内,则该点保留,否则将该点去掉;右边是腐蚀后的结果。可以看出,它仍在原来X的范围内,且比X包含的点要少,就象X被腐蚀掉了一层。

6.10 腐蚀运算

6.11为原图,图6.12为腐蚀后的结果图,能够很明显地看出腐蚀的效果。

6.11 原图

6.12 腐蚀后的结果图

下面的这段程序,实现了上述的腐蚀运算,针对的都是黑色点。参数中有一个BOOL变量,为真时,表示在水平方向进行腐蚀运算,即结构元素B ;否则在垂直方向上进行腐蚀运算,即结构元素B

BOOL Erosion(HWND hWnd,BOOL Hori)

{

DWORD OffBits,BufSize;

LPBITMAPINFOHEADER lpImgData;

LPSTR lpPtr;

HLOCAL hTempImgData;

LPBITMAPINFOHEADER lpTempImgData;

LPSTR lpTempPtr;

HDC hDc;

HFILE hf;

LONG x,y;

unsigned char num;

int i;

//为了处理方便,仍采用256级灰度图,不过只用调色板中0255两项

if( NumColors!=256){

MessageBox(hWnd,"Must be a mono bitmap with grayscale palette!",

"Error Message",MB_OK|MB_ICONEXCLAMATION);

return FALSE;

}

OffBits=bf.bfOffBits-sizeof(BITMAPFILEHEADER);

//BufSize为缓冲区大小

BufSize=OffBits+bi.biHeight*LineBytes;

//为新的缓冲区分配内存

if((hTempImgData=LocalAlloc(LHND,BufSize))==NULL)

{

MessageBox(hWnd,"Error alloc memory!","Error Message",

MB_OK|MB_ICONEXCLAMATION);

return FALSE;

}

lpImgData=(LPBITMAPINFOHEADER)GlobalLock(hImgData);

lpTempImgData=(LPBITMAPINFOHEADER)LocalLock(hTempImgData);

//拷贝头信息和位图数据

memcpy(lpTempImgData,lpImgData,BufSize);

if(Hori)

{

//在水平方向进行腐蚀运算

for(y=0;y

//lpPtr指向原图数据,lpTempPtr指向新图数据

lpPtr=(char *)lpImgData+(BufSize-LineBytes-y*LineBytes)+1;

lpTempPtr=(char*)lpTempImgData+

(BufSize-LineBytes-y*LineBytes)+1;

for(x=1;x

//注意为防止越界,x的范围从1到宽度-2

num=(unsigned char)*lpPtr;

if (num==0){ //因为腐蚀掉的是黑点,所以只对黑点处理

*lpTempPtr=(unsigned char)0; //先置成黑点

for(i=0;i<3;i++){

num=(unsigned char)*(lpPtr+i-1);

if(num==255){

//自身及上下邻居中若有一个不是黑点,则将该点腐

//蚀成白点

*lpTempPtr=(unsigned char)255;

break;

}

}

}

//原图中就是白点的,新图中仍是白点

else *lpTempPtr=(unsigned char)255;

//指向下一个象素

lpPtr++;

lpTempPtr++;

}

}

}

else{

//在垂直方向进行腐蚀运算

for(y=1;y注意为防止越界,y的范围从1到高度-2

//lpPtr指向原图数据,lpTempPtr指向新图数据

lpPtr=(char *)lpImgData+(BufSize-LineBytes-y*LineBytes);

lpTempPtr=(char *)lpTempImgData+(BufSize-LineBytes-y*LineBytes);

for(x=0;x

num=(unsigned char)*lpPtr;

if (num==0){ //因为腐蚀掉的是黑点,所以只对黑点处理

*lpTempPtr=(unsigned char)0; //先置成黑点

for(i=0;i<3;i++){

num=(unsigned char)*(lpPtr+(i-1)*LineBytes);

if(num==255){

//自身及上下邻居中若有一个不是黑点,则将该点腐

//蚀成白点

*lpTempPtr=(unsigned char)255;

break;

}

}

}

//原图中就是白点的,新图中仍是白点

else *lpTempPtr=(unsigned char)255;

//指向下一个象素

lpPtr++;

lpTempPtr++;

}

}

}

if(hBitmap!=NULL)

DeleteObject(hBitmap);

hDc=GetDC(hWnd);

//产生新的位图

hBitmap=CreateDIBitmap(hDc,(LPBITMAPINFOHEADER)lpTempImgData,

(LONG)CBM_INIT,

(LPSTR)lpTempImgData+

sizeof(BITMAPINFOHEADER)+

NumColors*sizeof(RGBQUAD),

(LPBITMAPINFO)lpTempImgData, DIB_RGB_COLORS);

//起不同的结果文件名

if(Hori)

hf=_lcreat("c:\\herosion.bmp",0);

else

hf=_lcreat("c:\\verosion.bmp",0);

_lwrite(hf,(LPSTR)&bf,sizeof(BITMAPFILEHEADER));

_lwrite(hf,(LPSTR)lpTempImgData,BufSize);

_lclose(hf);

//释放内存及资源

ReleaseDC(hWnd,hDc);

LocalUnlock(hTempImgData);

LocalFree(hTempImgData);

GlobalUnlock(hImgData);

return TRUE;

}

6.2 膨胀

膨胀(dilation)可以看做是腐蚀的对偶运算,其定义是:把结构元素B平移a后得到Ba,若Ba击中X,我们记下这个a点。所有满足上述条件的a点组成的集合称做XB膨胀的结果。用公式表示为:D(X)={a | BaX}=X B,如图6.13所示。图6.13X是被处理的对象,B是结构元素,不难知道,对于任意一个在阴影部分的点aBa击中X,所以XB膨胀的结果就是那个阴影部分。阴影部分包括X的所有范围,就象X膨胀了一圈似的,这就是为什么叫膨胀的原因。

同样,如果B不是对称的,XB膨胀的结果和X Bv膨胀的结果不同。

让我们来看看实际上是怎样进行膨胀运算的。在图6.14中,左边是被处理的图象X(二值图象,我们针对的是黑点),中间是结构元素B。膨胀的方法是,拿B的中心点和X上的点及X周围的点一个一个地对,如果B上有一个点落在X的范围内,则该点就为黑;右边是膨胀后的结果。可以看出,它包括X的所有范围,就象X膨胀了一圈似的。

6.13 膨胀的示意图

6.14 膨胀运算

6.15为图6.11膨胀后的结果图,能够很明显的看出膨胀的效果。

6.15 6.11膨胀后的结果图

下面的这段程序,实现了上述的膨胀运算,针对的都是黑色点。参数中有一个BOOL变量,为真时,表示在水平方向进行膨胀运算,即结构元素B ;否则在垂直方向上进行膨胀运算,即结构元素B

BOOL Dilation(HWND hWnd,BOOL Hori)

{

DWORD OffBits,BufSize;

LPBITMAPINFOHEADER lpImgData;

LPSTR lpPtr;

HLOCAL hTempImgData;

LPBITMAPINFOHEADER lpTempImgData;

LPSTR lpTempPtr;

HDC hDc;

HFILE hf;

LONG x,y;

unsigned char num;

int i;

//为了处理的方便,仍采用256级灰度图,不过只调色板中0255两项

if( NumColors!=256){

MessageBox(hWnd,"Must be a mono bitmap with grayscale palette!",

"Error Message",MB_OK|MB_ICONEXCLAMATION);

return FALSE;

}

OffBits=bf.bfOffBits-sizeof(BITMAPFILEHEADER);

//BufSize为缓冲区大小

BufSize=OffBits+bi.biHeight*LineBytes;

//为新的缓冲区分配内存

if((hTempImgData=LocalAlloc(LHND,BufSize))==NULL)

{

MessageBox(hWnd,"Error alloc memory!","Error Message",

MB_OK|MB_ICONEXCLAMATION);

return FALSE;

}

lpImgData=(LPBITMAPINFOHEADER)GlobalLock(hImgData);

lpTempImgData=(LPBITMAPINFOHEADER)LocalLock(hTempImgData);

//拷贝头信息和位图数据

memcpy(lpTempImgData,lpImgData,BufSize);

if(Hori)

{

//在水平方向进行膨胀运算

for(y=0;y

//lpPtr指向原图数据,lpTempPtr指向新图数据

lpPtr=(char *)lpImgData+(BufSize-LineBytes-y*LineBytes)+1;

lpTempPtr=(char*)lpTempImgData+

(BufSize-LineBytes-y*LineBytes)+1;

for(x=1;x

//注意为防止越界,x的范围从1到宽度-2

num=(unsigned char)*lpPtr;

//原图中是黑点的,新图中肯定也是,所以要考虑的是那些原图

//中的白点,看是否有可能膨胀成黑点

if (num==255){

*lpTempPtr=(unsigned char)255; //先置成白点

for(i=0;i<3;i++){

num=(unsigned char)*(lpPtr+i-1);

//只要左右邻居中有一个是黑点,就膨胀成黑点

if(num==0){

*lpTempPtr=(unsigned char)0;

break;

}

}

}

//原图中就是黑点的,新图中仍是黑点

else *lpTempPtr=(unsigned char)0;

//指向下一个象素

lpPtr++;

lpTempPtr++;

}

}

}

else{

//在垂直方向进行腐蚀运算

for(y=1;y注意为防止越界,y的范围从1到高度-2

lpPtr=(char *)lpImgData+(BufSize-LineBytes-y*LineBytes);

lpTempPtr=(char *)lpTempImgData+(BufSize-LineBytes-y*LineBytes);

for(x=0;x

num=(unsigned char)*lpPtr;

if (num==255){

*lpTempPtr=(unsigned char)255;

for(i=0;i<3;i++){

num=(unsigned char)*(lpPtr+(i-1)*LineBytes);

//只要上下邻居中有一个是黑点,就膨胀成黑点

if(num==0){

*lpTempPtr=(unsigned char)0;

break;

}

}

}

else *lpTempPtr=(unsigned char)0;

lpPtr++;

lpTempPtr++;

}

}

}

if(hBitmap!=NULL)

DeleteObject(hBitmap);

hDc=GetDC(hWnd);

//产生新的位图

hBitmap=CreateDIBitmap(hDc,(LPBITMAPINFOHEADER)lpTempImgData,

(LONG)CBM_INIT,

(LPSTR)lpTempImgData+

sizeof(BITMAPINFOHEADER)+

NumColors*sizeof(RGBQUAD),

(LPBITMAPINFO)lpTempImgData,

DIB_RGB_COLORS);

//起不同的结果文件名

if(Hori)

hf=_lcreat("c:\\hdilation.bmp",0);

else

hf=_lcreat("c:\\vdilation.bmp",0);

_lwrite(hf,(LPSTR)&bf,sizeof(BITMAPFILEHEADER));

_lwrite(hf,(LPSTR)lpTempImgData,BufSize);

_lclose(hf);

//释放内存及资源

ReleaseDC(hWnd,hDc);

LocalUnlock(hTempImgData);

LocalFree(hTempImgData);

GlobalUnlock(hImgData);

return TRUE;

}

腐蚀运算和膨胀运算互为对偶的,用公式表示为(X B)c=(Xc B),即X B腐蚀后的补集等于X的补集被B膨胀。这句话可以形象的理解为:河岸的补集为河面,河岸的腐蚀等价于河面的膨胀。你可以自己举个例子来验证一下这个关系。在有些情况下,这个对偶关系是非常有用的。例如:某个图象处理系统用硬件实现了腐蚀运算,那么不必再另搞一套膨胀的硬件,直接利用该对偶就可以实现了。

6.3

先腐蚀后膨胀称为开(open),即OPEN(X)=D(E(X))

让我们来看一个开运算的例子(见图6.16)

6.16开运算

在图16上面的两幅图中,左边是被处理的图象X(二值图象,我们针对的是黑点),右边是结构元素B,下面的两幅图中左边是腐蚀后的结果;右边是在此基础上膨胀的结果。可以看到,原图经过开运算后,一些孤立的小点被去掉了。一般来说,开运算能够去除孤立的小点,毛刺和小桥(即连通两块区域的小点),而总的位置和形状不变。这就是开运算的作用。要注意的是,如果B是非对称的,进行开运算时要用B的对称集Bv膨胀,否则,开运算的结果和原图相比要发生平移。图6.17和图6.18能够说明这个问题。

6.17 B膨胀后,结果向左平移了

6.18 Bv膨胀后位置不变

6.17是用B膨胀的,可以看到,OPEN(X)向左平移了。图18是用Bv膨胀的,可以看到,总的位置和形状不变。

6.19为图6.11经过开运算后的结果。

6.19 6.11经过开运算后的结果

开运算的源程序可以很容易的根据上面的腐蚀,膨胀程序得到,这里就不给出了。

6.4

先膨胀后腐蚀称为闭(close),即CLOSE(X)=E(D(X))

让我们来看一个闭运算的例子(见图6.20)

6.20 闭运算

在图6.20上面的两幅图中,左边是被处理的图象X(二值图象,我们针对的是黑点),右边是结构元素B,下面的两幅图中左边是膨胀后的结果,右边是在此基础上腐蚀的结果可以看到,原图经过闭运算后,断裂的地方被弥合了。一般来说,闭运算能够填平小湖(即小孔),弥合小裂缝,而总的位置和形状不变。这就是闭运算的作用。同样要注意的是,如果B是非对称的,进行闭运算时要用B的对称集Bv膨胀,否则,闭运算的结果和原图相比要发生平移。

6.21为图6.11经过闭运算后的结果。

6.21 .611经过闭运算后的结果

闭运算的源程序可以很容易的根据上面的膨胀,腐蚀程序得到,这里就不给出了。

你大概已经猜到了,开和闭也是对偶运算,的确如此。用公式表示为(OPEN(X))c=CLOSE((Xc)),或者(CLOSE(X))c =OPEN((Xc))。即X 开运算的补集等于X的补集的闭运算,或者X 闭运算的补集等于X的补集的开运算。这句话可以这样来理解:在两个小岛之间有一座小桥,我们把岛和桥看做是处理对象X,则X的补集为大海。如果涨潮时将小桥和岛的外围淹没(相当于用尺寸比桥宽大的结构元素对X进行开运算),那么两个岛的分隔,相当于小桥两边海域的连通(Xc做闭运算)

6.5 细化

细化(thinning)算法有很多,我们在这里介绍的是一种简单而且效果很好的算法,用它就能够实现从文本抽取骨架的功能。我们的对象是白纸黑字的文本,但在程序中为了处理的方便,还是采用256级灰度图,不过只用到了调色板中0255两项。

所谓细化,就是从原来的图中去掉一些点,但仍要保持原来的形状。实际上,是保持原图的骨架。所谓骨架,可以理解为图象的中轴,例如一个长方形的骨架是它的长方向上的中轴线;正方形的骨架是它的中心点;圆的骨架是它的圆心,直线的骨架是它自身,孤立点的骨架也是自身。文本的骨架嘛,前言中的例子显示的很明白。那么怎样判断一个点是否能去掉呢?显然,要根据它的八个相邻点的情况来判断,我们给几个例子(如图6.22所示)

6.22 根据某点的八个相邻点的情况来判断该点是否能删除

6.22中,(1)不能删,因为它是个内部点,我们要求的是骨架,如果连内部点也删了,骨架也会被掏空的;(2)不能删,和(1)是同样的道理;(3)可以删,这样的点不是骨架;(4)不能删,因为删掉后,原来相连的部分断开了;(5)可以删,这样的点不是骨架;(6)不能删,因为它是直线的端点,如果这样的点删了,那么最后整个直线也被删了,剩不下什么;(7)不能删,因为孤立点的骨架就是它自身。

总结一下,有如下的判据:(1)内部点不能删除;(2)孤立点不能删除;(3)直线端点不能删除;(4)如果P是边界点,去掉P后,如果连通分量不增加,则P可以删除。

我们可以根据上述的判据,事先做出一张表,从0255共有256个元素,每个元素要么是0,要么是1。我们根据某点(当然是要处理的黑色点了)的八个相邻点的情况查表,若表中的元素是1,则表示该点可删,否则保留。

查表的方法是,设白点为1,黑点为0;左上方点对应一个8位数的第一位(最低位),正上方点对应第二位,右上方点对应的第三位,左邻点对应第四位,右邻点对应第五位,左下方点对应第六位,正下方点对应第七位,右下方点对应的第八位,按这样组成的8位数去查表即可。例如上面的例子中(1)对应表中的第0项,该项应该为0(2)对应37,该项应该为0(3)对应173,该项应该为1(4)对应231,该项应该为0(5)对应237,该项应该为1(6)对应254,该项应该为0(7)对应255,该项应该为0

这张表我已经替大家做好了,可花了我不少时间呢!

static int erasetable[256]={

0,0,1,1,0,0,1,1, 1,1,0,1,1,1,0,1,

1,1,0,0,1,1,1,1, 0,0,0,0,0,0,0,1,

0,0,1,1,0,0,1,1, 1,1,0,1,1,1,0,1,

1,1,0,0,1,1,1,1, 0,0,0,0,0,0,0,1,

1,1,0,0,1,1,0,0, 0,0,0,0,0,0,0,0,

0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,

1,1,0,0,1,1,0,0, 1,1,0,1,1,1,0,1,

0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,

0,0,1,1,0,0,1,1, 1,1,0,1,1,1,0,1,

1,1,0,0,1,1,1,1, 0,0,0,0,0,0,0,1,

0,0,1,1,0,0,1,1, 1,1,0,1,1,1,0,1,

1,1,0,0,1,1,1,1, 0,0,0,0,0,0,0,0,

1,1,0,0,1,1,0,0, 0,0,0,0,0,0,0,0,

1,1,0,0,1,1,1,1, 0,0,0,0,0,0,0,0,

1,1,0,0,1,1,0,0, 1,1,0,1,1,1,0,0,

1,1,0,0,1,1,1,0, 1,1,0,0,1,0,0,0

};

有了这张表,算法就很简单了,每次对一行一行的将整个图象扫描一遍,对于每个点(不包括边界点),计算它在表中对应的索引,若为0,则保留,否则删除该点。如果这次扫描没有一个点被删除,则循环结束,剩下的点就是骨架点,如果有点被删除,则进行新的一轮扫描,如此反复,直到没有点被删除为止。

实际上,该算法有一些缺陷。举个简单的例子,有一个黑色矩形,如图6.23所示。

6.23经过细化后,我们预期的结果是一条水平直线,且位于该黑色矩形的中心。实际的结果确实是一条水平直线,但不是位于黑色矩形的中心,而是最下面的一条边。

为什么会这样,我们来分析一下:在从上到下,从左到右的扫描过程中,我们遇到的第一个黑点就是黑色矩形的左上角点,经查表,该点可以删。下一个点是它右边的点,经查表,该点也可以删,如此下去,整个一行被删了。每一行都是同样的情况,所以都被删除了。到了最后一行时,黑色矩形已经变成了一条直线,最左边的黑点不能删,因为它是直线的端点,它右边的点也不能删,因为如果删除,直线就断了,如此下去,直到最右边的点,也不能删,因为它是直线的右端点。所以最下面的一条边保住了,但这并不是我们希望的结果。

解决的办法是,在每一行水平扫描的过程中,先判断每一点的左右邻居,如果都是黑点,则该点不做处理。另外,如果某个黑点被删除了,那么跳过它的右邻居,处理下一个点。这样就避免了上述的问题。

6.23 黑色矩形

6.24 6.23细化后的结果

解决了上面的问题,我们来看看处理后的结果,如图6.24所示。这次变成一小段竖线了,还是不对,是不是很沮丧?别着急,让我们再来分析一下:在上面的算法中,我们遇到的第一个能删除的点就是黑色矩形的左上角点;第二个是第一行的最右边的点,即黑色矩形的右上角点;第三个是第二行的最左边的点;第四个是第二行的最右边的点;……;整个图象处理这样一次后,宽度减少2。每次都是如此,直到剩最中间一列,就不能再删了。为什么会这样呢?原因是这样的处理过程只实现了水平细化,如果在每一次水平细化后,再进行一次垂直方向的细化(只要把上述过程的行列换一下),就可以了。

这样一来,每处理一次,删除点的顺序变成:(先是水平方向扫描)第一行最左边的点;第一行最右边的点;第二行最左边的点;第二行最右边的点;……最后一行最左边的点;最后一行最右边的点;(然后是垂直方向扫描)第二列最上边的点(因为第一列最上边的点已被删除);第二列最下边的点;第三列最上边的点;第三列最下边的点;……倒数第二列最上边的点(因为倒数第一列最上边的点已被删除);倒数第二列最下边的点。我们发现,刚好剥掉了一圈,这也正是细化要做的事。实际的结果也验证了我们的想法。

以下是源程序,黑体字部分是值得注意的地方。

BOOL Thinning(HWND hWnd)

{

DWORD OffBits,BufSize;

LPBITMAPINFOHEADER lpImgData;

LPSTR lpPtr;

HLOCAL hTempImgData;

LPBITMAPINFOHEADER lpTempImgData;

LPSTR lpTempPtr;

HDC hDc;

HFILE hf;

LONG x,y;

int num;

BOOL Finished;

int nw,n,ne,w,e,sw,s,se;

//为了处理的方便,仍采用256级灰度图,不过只用调色板中0255两项

if( NumColors!=256){

MessageBox(hWnd,"Must be a mono bitmap with grayscale palette!",

"Error Message",MB_OK|MB_ICONEXCLAMATION);

return FALSE;

}

OffBits=bf.bfOffBits-sizeof(BITMAPFILEHEADER);

//BufSize为缓冲区大小

BufSize=OffBits+bi.biHeight*LineBytes;

//为新的缓冲区分配内存

if((hTempImgData=LocalAlloc(LHND,BufSize))==NULL)

{

MessageBox(hWnd,"Error alloc memory!","Error Message",

MB_OK|MB_ICONEXCLAMATION);

return FALSE;

}

lpImgData=(LPBITMAPINFOHEADER)GlobalLock(hImgData);

lpTempImgData=(LPBITMAPINFOHEADER)LocalLock(hTempImgData);

//拷贝头信息和位图数据

memcpy(lpTempImgData,lpImgData,BufSize);

//结束标志置成假

Finished=FALSE;

while(!Finished){ //还没有结束

//结束标志置成假

Finished=TRUE;

//先进行水平方向的细化

for (y=1;y注意为防止越界,y的范围从1到高度-2

//lpPtr指向原图数据,lpTempPtr指向新图数据

lpPtr=(char *)lpImgData+(BufSize-LineBytes-y*LineBytes);

lpTempPtr=(char *)lpTempImgData+(BufSize-LineBytes-y*LineBytes);

x=1; //注意为防止越界,x的范围从1到宽度-2

while(x

if(*(lpPtr+x)==0){ //是黑点才做处理

w=(unsigned char)*(lpPtr+x-1); //左邻点

e=(unsigned char)*(lpPtr+x+1); //右邻点

if( (w==255)|| (e==255)){

//如果左右两个邻居中至少有一个是白点才处理

nw=(unsigned char)*(lpPtr+x+LineBytes-1); //左上邻点

n=(unsigned char)*(lpPtr+x+LineBytes); //上邻点

ne=(unsigned char)*(lpPtr+x+LineBytes+1); //右上邻点

sw=(unsigned char)*(lpPtr+x-LineBytes-1); //左下邻点

s=(unsigned char)*(lpPtr+x-LineBytes); //下邻点

se=(unsigned char)*(lpPtr+x-LineBytes+1); //右下邻点

//计算索引

num=nw/255+n/255*2+ne/255*4+w/255*8+e/255*16+

sw/255*32+s/255*64+se/255*128;

if(erasetable[num]==1){ //经查表,可以删除

//在原图缓冲区中将该黑点删除

*(lpPtr+x)=(BYTE)255;

//结果图中该黑点也删除

*(lpTempPtr+x)=(BYTE)255;

Finished=FALSE; //有改动,结束标志置成假

x++; //水平方向跳过一个象素

}

}

}

x++; //扫描下一个象素

}

}

//再进行垂直方向的细化

for (x=1;x注意为防止越界,x的范围从1到宽度-2

y=1; //注意为防止越界,y的范围从1到高度-2

while(y

lpPtr=(char *)lpImgData+(BufSize-LineBytes-y*LineBytes);

lpTempPtr=(char*)lpTempImgData+

(BufSize-LineBytes-y*LineBytes);

if(*(lpPtr+x)==0){ //是黑点才做处理

n=(unsigned char)*(lpPtr+x+LineBytes);

s=(unsigned char)*(lpPtr+x-LineBytes);

if( (n==255)|| (s==255)){

//如果上下两个邻居中至少有一个是白点才处理

nw=(unsigned char)*(lpPtr+x+LineBytes-1);

ne=(unsigned char)*(lpPtr+x+LineBytes+1);

w=(unsigned char)*(lpPtr+x-1);

e=(unsigned char)*(lpPtr+x+1);

sw=(unsigned char)*(lpPtr+x-LineBytes-1);

se=(unsigned char)*(lpPtr+x-LineBytes+1);

//计算索引

num=nw/255+n/255*2+ne/255*4+w/255*8+e/255*16+

sw/255*32+s/255*64+se/255*128;

if(erasetable[num]==1){ //经查表,可以删除

//在原图缓冲区中将该黑点删除

*(lpPtr+x)=(BYTE)255;

//结果图中该黑点也删除

*(lpTempPtr+x)=(BYTE)255;

Finished=FALSE; //有改动,结束标志置成假

y++;//垂直方向跳过一个象素

}

}

}

y++; //扫描下一个象素

}

}

}

if(hBitmap!=NULL)

DeleteObject(hBitmap);

hDc=GetDC(hWnd);

//产生新的位图

hBitmap=CreateDIBitmap(hDc,(LPBITMAPINFOHEADER)lpTempImgData,

(LONG)CBM_INIT,

(LPSTR)lpTempImgData+

sizeof(BITMAPINFOHEADER)+

NumColors*sizeof(RGBQUAD),

(LPBITMAPINFO)lpTempImgData,

DIB_RGB_COLORS);

hf=_lcreat("c:\\thinning.bmp",0);

_lwrite(hf,(LPSTR)&bf,sizeof(BITMAPFILEHEADER));

_lwrite(hf,(LPSTR)lpTempImgData,BufSize);

_lclose(hf);

//释放内存及资源

ReleaseDC(hWnd,hDc);

LocalUnlock(hTempImgData);

LocalFree(hTempImgData);

GlobalUnlock(hImgData);

return TRUE;

}