-
Notifications
You must be signed in to change notification settings - Fork 10
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
9ff97a6
commit 86279ab
Showing
1 changed file
with
128 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,128 @@ | ||
# long_picture_view | ||
加载 长图控件,防微博加载方式 | ||
## 长图优化 | ||
|
||
现在市面上 95 % 以上,APP 都有预览图片的功能,那么是怎么做的勒,今天我们就来仿照 **微博** 预览长图,来对长图优化。 | ||
|
||
### 怎么使用 | ||
|
||
[代码传送阵](https://github.com/yangkun19921001/long_picture_view) | ||
|
||
1. project/build.gradle | ||
|
||
```java | ||
allprojects { | ||
repositories { | ||
... | ||
maven { url 'https://jitpack.io' } | ||
} | ||
} | ||
``` | ||
|
||
2. app/build.gradle | ||
|
||
```java | ||
dependencies { | ||
implementation 'com.github.yangkun19921001:long_picture_view:1.0.1' | ||
} | ||
``` | ||
|
||
3. xml 中直接使用 | ||
|
||
```java | ||
<com.yk.big_picture_library.BigView | ||
android:id="@+id/bv_img" | ||
android:layout_width="wrap_content" | ||
android:layout_height="wrap_content" | ||
/> | ||
``` | ||
|
||
4. 代码中 | ||
|
||
```java | ||
BigView bigView=findViewById(R.id.bv_img); | ||
//加载路径 | ||
bigView.setImage(BIG_IMAGE_PAHT); | ||
//加载 InputStream | ||
bigView.setImage(InputStream is) | ||
``` | ||
|
||
### 效果对比 | ||
|
||
#### 微博长图效果 | ||
|
||
![](https://user-gold-cdn.xitu.io/2019/5/26/16aefd9b96175a8b?w=398&h=849&f=gif&s=10198989) | ||
|
||
#### 仿照微博预览长图效果 | ||
|
||
![](https://user-gold-cdn.xitu.io/2019/5/26/16aefd85af90e911?w=398&h=849&f=gif&s=7074708) | ||
|
||
|
||
|
||
效果是不是很丝滑,原图是 12 M 压缩后不到 2 M ,加载前可以压缩下,我用的是我自己的另一个[图片压缩开源项目](<https://github.com/yangkun19921001/LIBJPEG_SAMPLE>)利用哈夫曼算法对图片压缩。 | ||
|
||
### 内存使用状态 | ||
|
||
![](https://user-gold-cdn.xitu.io/2019/5/26/16aefd82d6c92d0d?w=1138&h=559&f=gif&s=3438441) | ||
|
||
内存无泄漏,无抖动,无溢出 。这里在提一下如果对内存优化不了解的可以看下[性能优化(三)...](<https://juejin.im/post/5cd82a3ee51d456e781f20ce>) | ||
|
||
**Java 堆内存:** 5 - 6 M 之间 | ||
|
||
**Native 占用内存:** 25 M 左右 | ||
|
||
### 解决思路 | ||
|
||
![](https://user-gold-cdn.xitu.io/2019/5/26/16aefd7f3d23ddcc?w=1033&h=759&f=gif&s=198623) | ||
|
||
粗略步骤: | ||
|
||
1. 沿着对角线缩放 | ||
2. 加载屏幕能够看见的区域 | ||
3. 复用上一个 bitmap 区域的内存 | ||
4. 处理滑动 | ||
|
||
详细步骤 | ||
|
||
1. 定义 Rect 图片需要加载的区域 | ||
2. 定义图片复用 BitmapFactory.Options() | ||
3. 定义手势识别 GestureDetector 上下左右滑动的帮助类 | ||
4. 定义一个滑动帮组类 Scroller | ||
5. 加载图片信息并不是加载真正的图片 | ||
6. 开启内存复用功能 | ||
7. 创建一个区域解码器,只解码一部分。 | ||
8. 刷新 requestLayout | ||
9. 确定加载图片的区域,计算缩放比列 | ||
10. onDraw 绘制区域图片 | ||
11. 将图片区域缩放得到 View 的大小 | ||
12. drawBitmap 绘制图片 | ||
13. 处理滑动事件交给手势处理 | ||
14. 随着手指滑动改变现实区域 Rect,判断头部底部界限 | ||
15. invalidate 不断重绘 | ||
16. onFling , computeScroll 处理惯性问题 | ||
17. invalidate 不断重绘 | ||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|