真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

iOS如何實現(xiàn)圖片折疊效果-創(chuàng)新互聯(lián)

這篇文章主要介紹了iOS如何實現(xiàn)圖片折疊效果,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

福山網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站開發(fā)等網(wǎng)站項目制作,到程序開發(fā),運營維護。成都創(chuàng)新互聯(lián)公司2013年成立到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選成都創(chuàng)新互聯(lián)。

具體內(nèi)容如下

一、分析與說明

1.1 分析界 效果

當(dāng)鼠標(biāo)在圖片上拖動的時候,圖片上有一個折疊的效果.
這種折疊效果其實就是圖片的上半部分繞著X軸做一個旋轉(zhuǎn)的操作.
我們圖片的旋轉(zhuǎn)都是繞著錨點進 旋轉(zhuǎn)的.所以如果是一張圖片的,辦不到只上圖 的上半部 分進 個旋轉(zhuǎn).
其實是兩張圖片, 把兩張圖片合成一張圖片的方法,
實現(xiàn)方案.弄上下兩張圖 ,上部圖片只顯示上半部分, 下部圖片只顯示下半部分.

1.2 如果讓 張圖 只顯 上半部分或者下半部分?

利用 CALayer的一個屬性contentsRect = CGRectMake(0, 0, 1, 0.5);
contentsRect就是要顯示的范圍.它是取值范圍是(0~1);
想讓上部圖片只顯示上半部分contentsRect設(shè)置CGRectMake(0, 0, 1, 0.5); 讓下部圖片只顯示下半部分contentsRect設(shè)置為CGRectMake(0, 0.5, 1, 0.5)

1.3 讓上部圖 繞著錨點進 旋轉(zhuǎn),但是圖 的默認(rèn)錨點在中 ,所以要把上部圖 的錨點設(shè)在 最底部.

修改上部分的錨點為anchorPoint = CGPointMake(0.5, 1)
但是修過錨點之后, 會出現(xiàn)一個問題,就是上部分的圖片,會往上走.導(dǎo)致兩個圖片中間有一個空隙.
解決辦法為*.把兩張圖片放到一起.設(shè)置上部分圖片的錨點后.上部分圖 會上走一半的距離.
然后再設(shè)置下部圖片的錨點.設(shè)置下部圖 錨點值為anchorPoint = CGPointMake(0.5, 0);
這樣就能夠辦到兩張圖片合成一張的效果.

1.4 添加一個添加手勢的view(Drag View)

弄一個和圖片V相同的View,把手勢添加給這個UIView.
添加完手勢時, 在手勢方法當(dāng)中去旋轉(zhuǎn)上部分圖片.
用來計算旋轉(zhuǎn)的角度,上半部分旋轉(zhuǎn)的角度是根據(jù)手指向下拖動的Y值來決定.當(dāng) 指到最下部 時正好旋轉(zhuǎn)180度.
假設(shè)手指移動到最下部為200.那旋轉(zhuǎn) 度應(yīng)該為 angel = transP.Y * M_PI / 200.0;

1.5 拖動的時候讓它有一個立體產(chǎn)效果

立體的效果就是有一種近大遠(yuǎn)小的感覺.
想要設(shè)置立體效果.要修改它的TransForm當(dāng)中的一個M34值,
設(shè)置方式為弄一個空的TransFrom3D

CATransform3D transform = CATransform3DIdentity;

200.0可以理解為,人的眼睛離手機屏幕的垂直距離,

transform.m34 = - 1 / 200.0;
transform = CATransform3DRotate(transform, angle, 1, 0, 0);

1.6 給下部分圖片添加陰影的效果.陰影是有漸變的效果.是從透明到黑色的一個漸變.

我們可以通過CAGradientLayer這個層來創(chuàng)建漸變.這個層我們就稱它是一個漸變層.
漸變層也是需要添加到一個層上面才能夠顯.
漸變層里面有一個 colors屬性.這個屬性就是設(shè)置要漸變的顏色.它是一個數(shù)組.
數(shù)組當(dāng)中要求我們傳入都是 CGColorRef類型,所以我們要把顏 轉(zhuǎn)成CGColor.
但是轉(zhuǎn)成CGColor后,數(shù)組就認(rèn)識它是一個對象了,就要通過在前面加上一個(id)來告訴編譯器是 一個對象.
可以設(shè)置漸變的方向:
通過startPoint和endPoint這兩個屬性來設(shè)置漸變的方向.它的取值范圍也是(0~1)
默認(rèn) 向為上下漸變?yōu)?

gradientL.startPoint = CGPointMake(0, 0); 
gradientL.endPoint = CGPointMake(0, 1);

設(shè)置左右漸變

gradientL.startPoint = CGPointMake(0, 0); 
gradientL.endPoint = CGPointMake(1, 0);

可以設(shè)置漸變從一個顏色到下一個顏色的位置
設(shè)置屬性為locations = @[@0.3,@0.7]
漸變層同時還有一個opacity屬性.這個屬性是調(diào)協(xié)漸變層的不透明度.
它的取值范圍同樣也是 0-1, 當(dāng)為0時代表透明, 當(dāng)為1明,代碼不透明.
所以我們可以給下部分圖片添加一個漸變層,漸變層的顏色為從透明到黑.

gradientL.colors =
@[(id)[UIColor clearColor].CGColor,(id)[UIColor blackColor].CGColor];

開始時沒有漸變,所以可以把漸變層設(shè)為透明狀態(tài).
之后隨著手指向下拖動的時,漸變層的透明度跟著改變.
當(dāng)手指拖到最下面的時候,漸變層的透明度正好為1.

CGFloat opacity = 1 * transP.y / 200.0;

1.7 在手指松開后有一個反彈動畫

在手指松開后,我們添加一個反彈動畫。
當(dāng)手勢狀態(tài)為結(jié)束時:
1.把漸變的透明度改為 0
2.情況之前的形變

//手指松開,圖片復(fù)位
if(pan.state == UIGestureRecognizerStateEnded){
 //把漸變效果透明
 self.gradient.opacity = 0;

 //delay:動畫延時執(zhí)行時間
 //Damping:彈性系數(shù),設(shè)的超小, 彈性就越大
 //Velocity:彈性的初始速度
 //options:以什么樣樣式來做動畫,開始有結(jié)束慢,
 [UIView animateWithDuration:1 delay:0 usingSpringWithDamping:0.1 initialSpringVelocity:0 options:UIViewAnimationOptionCurveLinear animations:^{
  //上部分圖片復(fù)位
  self.topIv.layer.transform = CATransform3DIdentity;
 } completion:nil];
}

二、代碼

//
// ViewController.m
// 03_UIView74_圖片折疊
//
// Created by 杞文明 on 17/7/19.
// Copyright © 2017年 杞文明. All rights reserved.
//

#import "ViewController.h"

@interface ViewController ()
@property (weak, nonatomic) IBOutlet UIImageView *topIv;
@property (weak, nonatomic) IBOutlet UIImageView *bottomIv;
@property (weak, nonatomic) IBOutlet UIView *dragView;
@property (nonatomic, weak) CAGradientLayer *gradient;

#define MAX_H self.dragView.bounds.size.height

@end

@implementation ViewController

- (void)viewDidLoad {
 [super viewDidLoad];
 //讓上部圖層顯示上半部分
 self.topIv.layer.contentsRect = CGRectMake(0, 0, 1, 0.5);
 self.topIv.layer.anchorPoint = CGPointMake(0.5, 1);

 //讓下部圖片只顯示下半部分
 self.bottomIv.layer.contentsRect = CGRectMake(0, 0.5, 1, 0.5);
 self.bottomIv.layer.anchorPoint = CGPointMake(0.5, 0);

 //添加手勢
 UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc]initWithTarget:self action:@selector(pan:)];
 [self.dragView addGestureRecognizer:pan];

 //漸變層
 [self gradientLayer];
}

-(void)gradientLayer{
 //漸變層
 CAGradientLayer *gradient = [CAGradientLayer layer];
 gradient.frame = self.bottomIv.bounds;
 //設(shè)置漸變的顏色
 gradient.colors = @[(id)[UIColor clearColor].CGColor,(id)[UIColor blackColor].CGColor];

 [self.bottomIv.layer addSublayer:gradient];
 gradient.opacity = 0;
 self.gradient = gradient;
}

-(void)pan:(UIPanGestureRecognizer*)pan{
 //獲取當(dāng)前手指的偏移量
 CGPoint tranP = [pan translationInView:self.dragView];

 //大旋轉(zhuǎn)180
 //當(dāng)手指偏移量為dragView的高度時為180
 CGFloat angle = tranP.y * M_PI / MAX_H;

 CATransform3D transform = CATransform3DIdentity;

 //設(shè)置立體效果(近大遠(yuǎn)?。? //設(shè)置眼睛和屏幕的距離
 transform.m34 = -1 /300.0;

 //設(shè)置漸變層的不透明度
 self.gradient.opacity = tranP.y / MAX_H;

 //讓上層圖片繞x軸旋轉(zhuǎn)
 self.topIv.layer.transform = CATransform3DRotate(transform, -angle, 1, 0, 0);

 //手指松開,圖片復(fù)位
 if(pan.state == UIGestureRecognizerStateEnded){
  //把漸變效果透明
  self.gradient.opacity = 0;

  //delay:動畫延時執(zhí)行時間
  //Damping:彈性系數(shù),設(shè)的超小, 彈性就越大
  //Velocity:彈性的初始速度
  //options:以什么樣樣式來做動畫,開始有結(jié)束慢,
  [UIView animateWithDuration:1 delay:0 usingSpringWithDamping:0.1 initialSpringVelocity:0 options:UIViewAnimationOptionCurveLinear animations:^{
   //上部分圖片復(fù)位
   self.topIv.layer.transform = CATransform3DIdentity;
  } completion:nil];
 }
}

@end

三、圖示

iOS如何實現(xiàn)圖片折疊效果

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“iOS如何實現(xiàn)圖片折疊效果”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)建站,關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


當(dāng)前題目:iOS如何實現(xiàn)圖片折疊效果-創(chuàng)新互聯(lián)
URL地址:http://weahome.cn/article/desjhj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部