欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

舉例講解iOS開發(fā)中拖動視圖的實現(xiàn)

 更新時間:2015年10月23日 10:53:36   作者:念茜的博客  
這篇文章主要介紹了舉例講解iOS開發(fā)中的拖動視圖實現(xiàn),代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下

預(yù)備知識
iOS處理屏幕上的觸摸動作,主要涉及到以下幾個方法:

復(fù)制代碼 代碼如下:

touchesBegan:withEvent:          //觸摸屏幕的最開始被調(diào)用
touchesMoved:withEvent:         //移動過程中被調(diào)用
touchesEnded:withEvent:         //動作結(jié)束時被調(diào)用
touchesCancelled:WithEvent:


從方法的命名可以清晰的看出該方法何時被調(diào)用,最后一個比較特殊。touchesCancelled:WithEvent:在Cocoa Touch必須響應(yīng)持續(xù)觸摸事件的系統(tǒng)中斷時調(diào)用。
我們只要重寫這些方法,來作我們想要作的事情就可以了。

如何實現(xiàn)拖動視圖?
1.設(shè)置userInteractionEnabled屬性為YES,允許用戶交互。
2.在觸摸動作開始時記錄起始點。
3.在移動過程中,計算當(dāng)前位置坐標(biāo)與起始點的差值,即偏移量,并且移動視圖中心點至偏移量大小的地方。
4.分別限制x坐標(biāo)、與y坐標(biāo),保證用戶不可將視圖托出屏幕

備注:分別限制x坐標(biāo)與y坐標(biāo)的原因是,即使向右拖動不了了,仍需保證可以向下拖動。

其實,功能比較簡單,就是iOS手勢動畫中的拖動。來看一下基本的寫法:

1.注冊拖動動畫

復(fù)制代碼 代碼如下:

UIPanGestureRecognizer * panGestureRecognizer = [[UIPanGestureRecognizer alloc] initWithTarget:self
                                                                                            action:@selector(doHandlePanAction:)];
    [self.vLight addGestureRecognizer:panGestureRecognizer];


注:vLight就是要加入拖動的View子類。

2.拖動處理函數(shù)

復(fù)制代碼 代碼如下:

- (void) doHandlePanAction:(UIPanGestureRecognizer *)paramSender{
   
    CGPoint point = [paramSender translationInView:self.view];
    NSLog(@"X:%f;Y:%f",point.x,point.y);
   
    paramSender.view.center = CGPointMake(paramSender.view.center.x + point.x, paramSender.view.center.y + point.y);
    [paramSender setTranslation:CGPointMake(0, 0) inView:self.view];
   

}


實現(xiàn)代碼
以子類化UIImageView為例

復(fù)制代碼 代碼如下:

#import <UIKit/UIKit.h> 
 
@interface GragView : UIImageView 

    CGPoint startPoint; 

@end 

#import "GragView.h" 
 
@implementation GragView 
 
- (id)initWithFrame:(CGRect)frame 

    self = [super initWithFrame:frame]; 
    if (self) { 
        // Initialization code 
        //允許用戶交互 
        self.userInteractionEnabled = YES; 
    } 
    return self; 

 
- (id)initWithImage:(UIImage *)image 

    self = [super initWithImage:image]; 
    if (self) { 
        //允許用戶交互 
        self.userInteractionEnabled = YES; 
    } 
    return self; 

 
- (void) touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event 

    //保存觸摸起始點位置 
    CGPoint point = [[touches anyObject] locationInView:self]; 
    startPoint = point; 
     
    //該view置于最前 
    [[self superview] bringSubviewToFront:self]; 

 
-(void) touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event 

    //計算位移=當(dāng)前位置-起始位置 
    CGPoint point = [[touches anyObject] locationInView:self]; 
    float dx = point.x - startPoint.x; 
    float dy = point.y - startPoint.y; 
     
    //計算移動后的view中心點 
    CGPoint newcenter = CGPointMake(self.center.x + dx, self.center.y + dy); 
     
     
    /* 限制用戶不可將視圖托出屏幕 */ 
    float halfx = CGRectGetMidX(self.bounds); 
    //x坐標(biāo)左邊界 
    newcenter.x = MAX(halfx, newcenter.x); 
    //x坐標(biāo)右邊界 
    newcenter.x = MIN(self.superview.bounds.size.width - halfx, newcenter.x); 
     
    //y坐標(biāo)同理 
    float halfy = CGRectGetMidY(self.bounds); 
    newcenter.y = MAX(halfy, newcenter.y); 
    newcenter.y = MIN(self.superview.bounds.size.height - halfy, newcenter.y); 
     
    //移動view 
    self.center = newcenter; 

 
/* 
// Only override drawRect: if you perform custom drawing. 
// An empty implementation adversely affects performance during animation. 
- (void)drawRect:(CGRect)rect 

    // Drawing code 

*/ 
 
@end 


20151023105257759.gif (698×354)

相關(guān)文章

最新評論