先看看官网对于AppBarLayout.OnOffsetChangedListener的解释:
Interface definition for a callback to be invoked when an AppBarLayout's vertical offset changes.
当AppBarLayout垂直方向上的偏移量发生改变时,为触发一个回调方法定义的接口。
触发的回调方法是:
onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset)
再来看看对于onOffsetChanged的解释:
Called when the AppBarLayout's layout offset has been changed. This allows child views to implement custom behavior based on the offset (for instance pinning a view at a certain y value).
在AppBarLayout的布局偏移量发生改变时被调用。这个方法允许子view根据偏移量实现自定义的行为(比如在特定Y值的时候固定住一个View)。
解释的非常清楚了,不过我们需要点例子才好理解。
就以stackoverflow上的一个问题为例吧。
http://stackoverflow.com/questions/30779667/android-collapsingtoolbarlayout-and-swiperefreshlayout/30785823#30785823
当我把CollapsingToolbarLayout,CollapsingToolbarLayout以及SwipeRefreshLayout用在一起的时候:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
xmlns:android=
"http://schemas.android.com/apk/res/android"
xmlns:app=
"http://schemas.android.com/apk/res-auto"
android:id=
"@+id/drawer_layout"
android:layout_width=
"match_parent"
android:layout_height=
"match_parent"
android:fitsSystemWindows=
"true"
>
android:id=
"@+id/coordinator_layout"
android:layout_width=
"match_parent"
android:layout_height=
"match_parent"
android:fitsSystemWindows=
"true"
>
android:id=
"@+id/appbar"
android:layout_width=
"match_parent"
android:layout_height=
"@dimen/collapse_toolbar_height"
android:fitsSystemWindows=
"true"
android:theme=
"@style/ThemeOverlay.AppCompat.Dark.ActionBar"
>
android:id=
"@+id/collapsing_toolbar"
android:layout_width=
"match_parent"
android:layout_height=
"match_parent"
app:contentScrim=
"?attr/colorPrimary"
android:fitsSystemWindows=
"true"
app:expandedTitleMarginStart=
"48dp"
app:expandedTitleMarginEnd=
"64dp"
app:layout_scrollFlags=
"scroll|exitUntilCollapsed"
>
android:id=
"@+id/toolbar_image"
android:layout_width=
"match_parent"
android:layout_height=
"match_parent"
android:scaleType=
"centerCrop"
android:fitsSystemWindows=
"true"
app:layout_collapseMode=
"parallax"
/>
layout=
"@layout/activity_main_toolbar"
/>
android:id=
"@+id/swipe_container"
android:layout_width=
"match_parent"
android:layout_height=
"match_parent"
app:layout_behavior=
"@string/appbar_scrolling_view_behavior"
>
android:id=
"@+id/mainList"
android:layout_width=
"match_parent"
android:layout_height=
"match_parent"
android:scrollbars=
"vertical"
/>
android:id=
"@+id/floating_action_button"
android:layout_height=
"wrap_content"
android:layout_width=
"wrap_content"
app:layout_anchor=
"@id/appbar"
app:layout_anchorGravity=
"bottom|right|end"
android:layout_margin=
"16dp"
app:fabSize=
"mini"
android:src=
"@drawable/ic_action_edit"
android:onClick=
"assignSelectedWebCamsToCategory"
/>
android:id=
"@+id/floating_action_menu"
android:layout_width=
"match_parent"
android:layout_height=
"match_parent"
android:layout_gravity=
"bottom|end"
android:paddingRight=
"10dp"
android:paddingBottom=
"8dp"
android:paddingLeft=
"10dp"
fab:menu_shadowColor=
"#37000000"
fab:menu_colorNormal=
"#DA4336"
fab:menu_colorPressed=
"#E75043"
fab:menu_colorRipple=
"#99FFFFFF"
fab:menu_icon=
"@drawable/fab_add"
fab:menu_buttonSpacing=
"10dp"
fab:menu_labels_textColor=
"@color/very_dark_grey"
fab:menu_labels_textSize=
"14sp"
fab:menu_labels_colorNormal=
"@color/white"
fab:menu_labels_colorPressed=
"@color/next_grey"
fab:menu_labels_colorRipple=
"#99FFFFFF"
fab:menu_labels_margin=
"8dp"
fab:menu_backgroundColor=
"@color/black_transparent"
>
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:src=
"@drawable/ic_action_content_import"
fab:fab_size=
"mini"
fab:fab_label=
"@string/pref_import_from_server"
fab:fab_colorNormal=
"@color/white"
app:fab_colorPressed=
"@color/next_grey"
app:fab_colorRipple=
"#99FFFFFF"
android:onClick=
"showSelectionDialog"
/>
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:src=
"@drawable/ic_action_content_manually"
fab:fab_size=
"mini"
fab:fab_label=
"@string/create_manually"
fab:fab_colorNormal=
"@color/white"
app:fab_colorPressed=
"@color/next_grey"
app:fab_colorRipple=
"#99FFFFFF"
android:onClick=
"showAddDialog"
/>
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:src=
"@drawable/ic_action_content_suggestion"
fab:fab_size=
"mini"
fab:fab_label=
"@string/submit_suggestion"
fab:fab_colorNormal=
"@color/white"
app:fab_colorPressed=
"@color/next_grey"
app:fab_colorRipple=
"#99FFFFFF"
android:onClick=
"showSuggestionDialog"
/>
layout=
"@layout/activity_main_drawer"
/>
|
java代码:
1
2
|
swipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.swipe_container);
swipeRefreshLayout.setOnRefreshListener(
this
);
|
如何才能让滑动刷新只发生在collapsing toolbar完全展开并且 scrollview (或者recyclerview)在顶部 的时候呢?类似于g+和Inbox中的效果。
错误的效果:
正确的效果:
可以尝试为AppBarLayout添加 offset change listener同时根据情况启用或者关闭滑动刷新,需要增加的代码在这里:
https://gist.github.com/blackcj/001a90c7775765ad5212
关键改动:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
public class MainActivity extends AppCompatActivity implements AppBarLayout.OnOffsetChangedListener {
...
private AppBarLayout appBarLayout;
private SwipeRefreshLayout mSwipeRefreshLayout;
@Override
protected void onCreate(Bundle savedInstanceState) {
super
.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
...
mSwipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.contentView);
appBarLayout = (AppBarLayout) findViewById(R.id.appBarLayout);
}
@Override
public void onOffsetChanged(AppBarLayout appBarLayout, int i) {
if
(i == 0) {
mSwipeRefreshLayout.setEnabled(
true
);
}
else
{
mSwipeRefreshLayout.setEnabled(
false
);
}
}
@Override
protected void onResume() {
super
.onResume();
appBarLayout.addOnOffsetChangedListener(
this
);
}
@Override
protected void onPause() {
super
.onPause();
appBarLayout.removeOnOffsetChangedListener(
this
);
}}
|