教你在iOS上繪製自然的簽名

來源:互聯網
上載者:User

這裡有一篇很棒的文章寫如何在Android上擷取流暢的簽名:Smoother Signatures,但是我沒有找到一篇是寫在iOS上如何?。那麼,究竟怎麼做才能在iOS裝置上擷取使用者的簽名呢?

雖然我沒有找到任何關於擷取簽名的文章,但是在App store上已經有了實現得很好的app。 Paper by 53 是一個畫畫的iPad應用程式,它擁有漂亮並且靈敏的畫筆,這也是我所要追求的使用者體驗。

代碼可以從這裡得到:SignatureDemo

連點成線

最簡單得辦法是,依次擷取觸摸點並且用直線把它們連起來。

在UIView子類的初始化方法中建立path和用於捕獲觸摸事件的gesture recongnizer .

// Create a path to connect lines  path = [UIBezierPath bezierPath];        // Capture touches  UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(pan:)];  pan.maximumNumberOfTouches = pan.minimumNumberOfTouches = 1;  [self addGestureRecognizer:pan];

將捕獲到的pan事件location資料依次加入到貝塞爾path中,連點成線。

- (void)pan:(UIPanGestureRecognizer *)pan {      CGPoint currentPoint = [pan locationInView:self];            if (pan.state == UIGestureRecognizerStateBegan) {          [path moveToPoint:currentPoint];      } else if (pan.state == UIGestureRecognizerStateChanged)          [path addLineToPoint:currentPoint];            [self setNeedsDisplay];  }

畫出軌跡

- (void)drawRect:(CGRect)rect  {      [[UIColor blackColor] setStroke];      [path stroke];  }

用這種方法畫個字母J就暴露出一些問題了。

當簽名速度較慢時,iOS可以捕獲到足夠的touch位置資訊,讓串連起來的直線看起來不那麼明顯。但是當手指移動速度很快時就有麻煩了。

在2012蘋果開發人員大會中介紹的 Building Advanced Gesture Recognizers 提到,可以用數學來解決這個問題。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.