【原】UIView实现点击着重效果的解决方案
我們知道,在IOS中UIButton UIControl都有一個(gè)默認(rèn)的選中效果,即點(diǎn)中后會(huì)圖標(biāo)會(huì)變暗,移開(kāi)后又恢復(fù)正常。如何讓UIView UIImageView等這些普通的view也實(shí)現(xiàn)同樣的效果呢?
最近的一個(gè)項(xiàng)目里面,需要實(shí)現(xiàn)一個(gè)類似iPad/iPhone的主界面效果,但是不同的是,每個(gè)item里面顯示圖片的都必須是UIImageView,因?yàn)閕con的圖片是從服務(wù)端異步下載下來(lái)的。而iPad的主界面里面,顯示圖片的載體應(yīng)該是一個(gè)Button,已經(jīng)自帶著重效果了。現(xiàn)在的任務(wù)是實(shí)現(xiàn)UIImageView的陰影著重效果。
其實(shí)要實(shí)現(xiàn)只需往Item(item = UIImageView + UILabel)添加三個(gè)touch事件:
[item addTarget:self action:@selector(itemTouchedUpInside:) forControlEvents:UIControlEventTouchUpInside]; [item addTarget:self action:@selector(itemTouchedUpOutside:) forControlEvents:UIControlEventTouchUpOutside]; [item addTarget:self action:@selector(itemTouchedDown:) forControlEvents:UIControlEventTouchDown];[item addTarget:self action:@selector(itemTouchedCancel:) forControlEvents:UIControlEventTouchCancel];
下面我們用改變UImageView的alph透明度來(lái)代替陰影著重效果。陰影著重效果很簡(jiǎn)單,但點(diǎn)擊的時(shí)候覆蓋一層黑色的半透明的View的即可,而代碼的位置也跟setAlpha:的位置相對(duì)應(yīng)。
-(void)itemTouchedUpOutside:(MyLauncherItem *)item {item.imagView.alpha = 1; } -(void)itemTouchedDown:(MyLauncherItem *)item {item.imageView,alpha = 0.5; } - (void)itemTouchedUpInside:(MyLauncherItem *)item {item.imageView.alpha = 1; }- (void)itemTouchedCancel:(MyLauncherItem *)item {item.imageView.alpha = 1; } ?
其中,只有touchDown才降低alhpa值,其他兩個(gè)事件都是用來(lái)恢復(fù)到原先狀態(tài)的。當(dāng)我們觸摸item時(shí),首先被響應(yīng)的是touchDown事件,然后接下來(lái)響應(yīng)的是touchUpInside還是touchUpOuside要取決于手指是否移動(dòng)了。增加touchCancel處理是因?yàn)橛袝r(shí)會(huì)出現(xiàn)按鈕按下后恢復(fù)不了原狀的情況,特別是在暴力測(cè)試情況下下,用多跟手指同時(shí)滑動(dòng)圖標(biāo)。
以上就是大體思路。若覺(jué)得著重的時(shí)間太短,可以在touchUpInside里面寫(xiě)個(gè)GDB的dispatch_after延時(shí)處理操作,一半只要延時(shí)0.05秒最有效果就不錯(cuò)了。
我的辦法比較土,如果有更好的方法可以留言交流一下。
轉(zhuǎn)載于:https://www.cnblogs.com/wengzilin/p/3301862.html
總結(jié)
以上是生活随笔為你收集整理的【原】UIView实现点击着重效果的解决方案的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 免费仿站_扒站工具下载-IDM站点抓取
- 下一篇: 两段关于统计日期的sql语句