• Stars
    star
    359
  • Rank 118,537 (Top 3 %)
  • Language
    Java
  • Created over 7 years ago
  • Updated about 6 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

It's an refresh animation that opens the shutter

RecyclerRefreshLayout

English | 中文版

ShootRefreshView is a refresh animation. In fact, It's an animation that opens the shutter. the main point of this animation is how to draw the five line of the shutter. Mainly related to the formula of the circle and line.

Analysis

Note: the following uses the 'Shutter line' represent the six lines of the shutter.

Step 1: Rotate the 'Shutter line', but the shutter does not open.
The red arc indicates the rotation of the 'Shutter line'

Step 2: Rotate the 'Shutter Line' and open the shutter.
The core idea is how to calculate the intersection of two lines on the following picture.

The following is the formula

Step3: Take the center of the 'Shutter Line' as the base point, and zoom 'Shutter Line'
The core idea is how to calculate the intersection of a lines and a circle on the following picture.

The following is the formula

Step4: Perform a refresh animation, rotate the gradient ring
The last step is easy to implement, just set the SweepGradient to the Paint and draw a circle.

Misc

QQ Group: 342748245

License

Copyright 2015-2019 dinus

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.