Android 개발 ScrollView 기반 그 라 데 이 션 내 비게 이 션 표시 줄 효과 예시

4300 단어 AndroidScrollView
이 사례 는 안 드 로 이 드 개발 이 ScrollView 를 바탕 으로 하 는 그 라 데 이 션 네 비게 이 션 바 효 과 를 보 여 준다.여러분 께 참고 하도록 공유 하 겠 습 니 다.구체 적 으로 는 다음 과 같 습 니 다.
며칠 전에 프로젝트 는 원래 의 페이지 에 그 라 데 이 션 네 비게 이 션 표시 줄 의 기능 을 추가 하고 많은 자 료 를 찾 았 다.많은 자원 들 이 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 클래스 를 계승 하면 됩 니 다.
더 많은 안 드 로 이 드 관련 내용 에 관심 이 있 는 독자 들 은 본 사이트 의 주 제 를 볼 수 있다.,,,,,,,
본 고 에서 말 한 것 이 여러분 의 안 드 로 이 드 프로 그래 밍 에 도움 이 되 기 를 바 랍 니 다.

좋은 웹페이지 즐겨찾기