Android 개발 ScrollView 기반 그 라 데 이 션 내 비게 이 션 표시 줄 효과 예시
4300 단어 AndroidScrollView
며칠 전에 프로젝트 는 원래 의 페이지 에 그 라 데 이 션 네 비게 이 션 표시 줄 의 기능 을 추가 하고 많은 자 료 를 찾 았 다.많은 자원 들 이 listview 의 높이 를 감청 하여 그 라 데 이 션 표시 줄 의 효 과 를 실현 하지만 프로젝트 안의 많은 화면 은 ScrollView 를 사용 하여 미끄럼 효 과 를 실현 했다.
정말 어 쩔 수 없 이 스스로 테스트 를 써 서 이 효 과 를 실현 했다.
말 이 많 지 않 으 니 바로 생각 을 살 펴 보 세 요.사실 그 라 데 이 션 바 는 네 비게 이 션 바 의 투명 도 를 바 꾸 는 것 이 아니 라 높이 를 설정 할 수 있 습 니 다.이 높이 에 따라 ScrollView 가 미 끄 러 지 는 거 리 를 감청 하여 그 라 데 이 션 바 의 효 과 를 실현 할 수 있 습 니 다.
코드 를 보 겠 습 니 다.
먼저 스크롤 뷰 를 사용자 정의 합 니 다.
1、ObservableScrollView.java
package com.example.test;
import android.content.Context;
import android.os.Build;
import android.util.AttributeSet;
import android.widget.ScrollView;
public class ObservableScrollView extends ScrollView implements
ObservableScrollable {
private boolean mDisableEdgeEffects = true;
private OnScrollChangedCallback mOnScrollChangedListener;
public ObservableScrollView(Context context) {
super(context);
}
public ObservableScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public ObservableScrollView(Context context, AttributeSet attrs,
int defStyle) {
super(context, attrs, defStyle);
}
@Override
protected void onScrollChanged(int l, int t, int oldl, int oldt) {
super.onScrollChanged(l, t, oldl, oldt);
if (mOnScrollChangedListener != null) {
mOnScrollChangedListener.onScroll(l, t);
}
}
@Override
protected float getTopFadingEdgeStrength() {
if (mDisableEdgeEffects
&& Build.VERSION.SDK_INT < Build.VERSION_CODES.HONEYCOMB) {
return 0.0f;
}
return super.getTopFadingEdgeStrength();
}
@Override
protected float getBottomFadingEdgeStrength() {
if (mDisableEdgeEffects
&& Build.VERSION.SDK_INT < Build.VERSION_CODES.HONEYCOMB) {
return 0.0f;
}
return super.getBottomFadingEdgeStrength();
}
@Override
public void setOnScrollChangedCallback(OnScrollChangedCallback callback) {
mOnScrollChangedListener = callback;
}
}
이 안 에는 두 개의 인터페이스 가 정의 되 어 있다.2、ObservableScrollable.java
package com.example.test;
public interface ObservableScrollable {
void setOnScrollChangedCallback(OnScrollChangedCallback callback);
}
3、OnScrollChangedCallback.java
package com.example.test;
public interface OnScrollChangedCallback {
void onScroll(int l, int t);
}
이곳 의 반전 함 수 는 ScrollView 에 대한 감청 을 실현 하 였 다.그리고 메 인 방법.
4、MainActivity.java
package com.example.test;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.Window;
import android.widget.RelativeLayout;
import android.widget.ScrollView;
public class MainActivity extends Activity implements OnScrollChangedCallback {
ObservableScrollable sv;
RelativeLayout rl;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.activity_main);
rl = (RelativeLayout) findViewById(R.id.rl);
sv = (ObservableScrollable) findViewById(R.id.sv);
sv.setOnScrollChangedCallback(this);
}
@Override
public void onScroll(int l, int t) {
float newAlpha = (float)t/500;
rl.setAlpha(newAlpha);
}
}
main 에서 ScrollView 에 대한 감청 을 설정 하고 감청 높이 를 500 으로 설정 하 며 500 을 100%로 나 누 어 그 라 데 이 션 네 비게 이 션 표시 줄 의 변 화 를 실현 합 니 다.그리고 xml 파일 에 Observable ScrollView 클래스 를 계승 하면 됩 니 다.
더 많은 안 드 로 이 드 관련 내용 에 관심 이 있 는 독자 들 은 본 사이트 의 주 제 를 볼 수 있다.,,,,,,,
본 고 에서 말 한 것 이 여러분 의 안 드 로 이 드 프로 그래 밍 에 도움 이 되 기 를 바 랍 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.