android循環滾動
A. Android實現橫縱滾動標題不動框架
用自定義標題欄。
用自定義標題欄,只要把系統自帶的標題欄去掉就行。做法:requestWindowFeature(Window.FEATURE_NO_TITLE),自己再寫兩個布局塊(LinearLayout布局)充當頂部和底部的標題欄即可,中間使用ScrollView即可完成。
如果應用需要添加水平滾動條,則可藉助於另一個滾動視圖HorizontalScrollView來實現。
B. 實現RecyclerView循環滾動
無限循環RecyclerView的完美實現方案
Android RecyclerView打造自動循環效果
C. android如何利用horizon scrollview實現循環滾動
把要滾動的布局放在scrollview裡面,
D. Android 自動滾動的RecyclerView
RecycelrView 自動滾動,頂部item上移動,底部item有動畫效果的出來,用於一些條目循環等操作,動漫自動觀看
BRVAH官方使用指南(持續更新) -
GitHub - wangtao2855/PictureVideoDemo: RecyerlView自動滾動功能
E. 求助大神ScrollView循環滾動問題
android 中scrollview可以通過控制滑動速度的屬性來解決太慢的問題,示例如下: /** * 快/慢滑動ScrollView */ public class SlowScrollView extends ScrollView { public SlowScrollView(Context context, AttributeSet attrs, int defStyle) ...
F. android怎麼viewpager實現循環切換圖片
Android中的ViewPager則實現了左右滑動的效果,ViewPager類提供了多界面切換的新效果。利用ViewPager實現圖片循環滾動代碼如下:
1、首先是布局文件,使用了一個ViewPager控制項:
java"><spanstyle="padding:0px;margin:0px;font-size:14px;"><RelativeLayoutxmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v4.view.ViewPager>
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_alignBottom="@id/viewpager"
android:background="#33000000"
android:orientation="vertical"
android:padding="5dip">
<TextView
android:id="@+id/tv_image_description"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:text="第一個引導頁面"
android:textColor="@android:color/white"
android:textSize="14sp"/>
<LinearLayout
android:id="@+id/ll_points"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="5dip"
android:layout_gravity="center_horizontal"
android:orientation="horizontal">
</LinearLayout>
</LinearLayout>
</RelativeLayout></span>
2、接下來實現一個繼承PagerAdapter的MyAdapter類,實現一個PagerAdapter,代碼如下:
<spanstyle="padding:0px;margin:0px;font-size:14px;">packagecom.example.viewpagertest;
importjava.util.List;
importandroid.support.v4.view.PagerAdapter;
importandroid.view.View;
importandroid.view.ViewGroup;
importandroid.widget.ImageView;
{
privateList<ImageView>mImageViewList;
publicViewPagerAdapter(List<ImageView>imageViewList){
super();
this.mImageViewList=imageViewList;
}
/**
*該方法將返回所包含的Item總個數。為了實現一種循環滾動的效果,返回了基本整型的最大值,這樣就會創建很多的Item,
*其實這並非是真正的無限循環。
*/
@Override
publicintgetCount(){
returnInteger.MAX_VALUE;
}
/**
*判斷出去的view是否等於進來的view如果為true直接復用
*/
@Override
publicbooleanisViewFromObject(Viewarg0,Objectarg1){
returnarg0==arg1;
}
/**
*銷毀預載入以外的view對象,會把需要銷毀的對象的索引位置傳進來,就是position,
*因為mImageViewList只有五條數據,而position將會取到很大的值,
*所以使用取余數的方法來獲取每一條數據項。
*/
@Override
publicvoiddestroyItem(ViewGroupcontainer,intposition,Objectobject){
container.removeView(mImageViewList.get(position%mImageViewList.size()));
}
/**
*創建一個view,
*/
@Override
publicObjectinstantiateItem(ViewGroupcontainer,intposition){
container.addView(mImageViewList.get(position%mImageViewList.size()));
returnmImageViewList.get(position%mImageViewList.size());
}
}
</span>
3、最後是主界面部分的代碼:
<spanstyle="padding:0px;margin:0px;font-size:14px;">packagecom.example.viewpagertest;
importjava.util.ArrayList;
importjava.util.List;
importandroid.app.Activity;
importandroid.os.Bundle;
importandroid.os.Handler;
importandroid.os.Message;
importandroid.os.SystemClock;
importandroid.support.v4.view.ViewPager;
importandroid.support.v4.view.ViewPager.OnPageChangeListener;
importandroid.view.View;
importandroid.widget.ImageView;
importandroid.widget.LinearLayout;
importandroid.widget.LinearLayout.LayoutParams;
importandroid.widget.TextView;
{
privateList<ImageView>imageViewList;
privateTextViewtvDescription;
privateLinearLayoutllPoints;
privateString[]imageDescriptions;
=0;
privateViewPagermViewPager;
privatebooleanisLoop=true;
privateHandlerhandler=newHandler(){
@Override
publicvoidhandleMessage(Messagemsg){
super.handleMessage(msg);
mViewPager.setCurrentItem(mViewPager.getCurrentItem()+1);
}
};
@Override
protectedvoidonCreate(BundlesavedInstanceState){
super.onCreate(savedInstanceState);
setView();
initView();
}
publicvoidsetView(){
setContentView(R.layout.activity_splash_viewpager);
//自動切換頁面功能
newThread(newRunnable(){
@Override
publicvoidrun(){
while(isLoop){
SystemClock.sleep(2000);
handler.sendEmptyMessage(0);
}
}
}).start();
}
publicvoidinitView(){
mViewPager=(ViewPager)findViewById(R.id.viewpager);
tvDescription=(TextView)findViewById(R.id.tv_image_description);
llPoints=(LinearLayout)findViewById(R.id.ll_points);
prepareData();
ViewPagerAdapteradapter=newViewPagerAdapter(imageViewList);
mViewPager.setAdapter(adapter);
mViewPager.setOnPageChangeListener(this);
tvDescription.setText(imageDescriptions[previousSelectPosition]);
llPoints.getChildAt(previousSelectPosition).setEnabled(true);
/**
*2147483647/2=1073741820-1
*設置ViewPager的當前項為一個比較大的數,以便一開始就可以左右循環滑動
*/
intn=Integer.MAX_VALUE/2%imageViewList.size();
intitemPosition=Integer.MAX_VALUE/2-n;
mViewPager.setCurrentItem(itemPosition);
}
privatevoidprepareData(){
imageViewList=newArrayList<ImageView>();
int[]imageResIDs=getImageResIDs();
imageDescriptions=getImageDescription();
ImageViewiv;
Viewview;
for(inti=0;i<imageResIDs.length;i++){
iv=newImageView(this);
iv.setBackgroundResource(imageResIDs[i]);
imageViewList.add(iv);
//添加點view對象
view=newView(this);
view.setBackgroundDrawable(getResources().getDrawable(R.drawable.point_background));
LayoutParamslp=newLayoutParams(5,5);
lp.leftMargin=10;
view.setLayoutParams(lp);
view.setEnabled(false);
llPoints.addView(view);
}
}
privateint[]getImageResIDs(){
returnnewint[]{
R.drawable.bg1,
R.drawable.bg2,
R.drawable.bg3,
R.drawable.pic_01,
R.drawable.pic_02
};
}
privateString[]getImageDescription(){
returnnewString[]{
"第一個引導頁面",
"第二個引導頁面",
"第三個引導頁面",
"第四個引導頁面",
"第五個引導頁面"
};
}
@Override
(intarg0){
}
@Override
publicvoidonPageScrolled(intarg0,floatarg1,intarg2){
}
@Override
publicvoidonPageSelected(intposition){
//改變圖片的描述信息
tvDescription.setText(imageDescriptions[position%imageViewList.size()]);
//切換選中的點,把前一個點置為normal狀態
llPoints.getChildAt(previousSelectPosition).setEnabled(false);
//把當前選中的position對應的點置為enabled狀態
llPoints.getChildAt(position%imageViewList.size()).setEnabled(true);
previousSelectPosition=position%imageViewList.size();
}
@Override
protectedvoidonDestroy(){
super.onDestroy();
isLoop=false;
}
}
</span>
G. 如何讓coordinatorlayout自動往上滾動 android
一個自動滾動,輪播循環視圖組件。 使用 (1) 引入公共庫 引入Android Auto Scroll ViewPager@Github作為你項目的library(如何拉取代碼及添加公共庫)。 (2) 調用 僅需簡單兩步: a. 布局定義 <cn.trinea.android.view.autoscrollviewpager.AutoScrollViewPager android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="wrap_content" /> 代替一般的ViewPager定義 b. 啟動ViewPager自動滾動 startAutoScroll() 啟動自動滾動 stopAutoScroll() 停止自動滾動 3、設置 setInterval(long) 設置自動滾動的間隔時間,單位為毫秒 setDirection(int) 設置自動滾動的方向,默認向右 setCycle(boolean) 是否自動循環輪播,默認為true setScrollDurationFactor(double) 設置ViewPager滑動動畫間隔時間的倍率,達到減慢動畫或改變動畫速度的效果 setStopScrollWhenTouch(boolean) 當手指碰到ViewPager時是否停止自動滾動,默認為true setSlideBorderMode(int) 滑動到第一個或最後一個Item的處理方式,支持沒有任何操作、輪播以及傳遞到父View三種模式 setBorderAnimation(boolean) 設置循環滾動時滑動到從邊緣滾動到下一個是否需要動畫,默認為true 4、其他 (1) 指示器,圓形或是方形指示器請配合ViewPagerIndicator使用 (2)無限循環,如果希望在最後一張繼續播放第一張而不是退回到第一張,請參考AutoScrollViewPagerSingleDemo.java,注意這個特性不能和 ViewPagerIndicator 使用。 要是還不能解決? 你來我們群里說吧 這里是開發者互相學習交流的 有大神 讓他們給你解釋你的疑問 q un號: 1881 68040
H. Android RecyclerView實現循環列表-點擊事件
源碼鏈接
效果圖
實現步驟:
1.在build.gradle文件中加入recyclerView庫
2.在main.xml中使用recyclerView布局
3.滾動列表中的每一項對應一個對象,他們屬於同一類的實例。接著定義實體類,我做的是歌單列表,定義序號,名字和時長
4.設計列表項的樣式
4.使用適配器為列表項設置顯示的數據
4.1定義適配器的內部類與列表項綁定
4.2適配器繼承自recyclerView.Adapter,要重寫三個方法,創建列表項視圖,復用載入,獲取列表項數量,到這一步,循環列表已經可以實現滾動效果了。
5.為列表項添加點擊監聽事件,使用介面回調
5.1仍然是在適配器中,定義介面
5.2在onBindViewHolder中為列表項設置監聽
5.3在MainActivity中使用,實現onclick方法
I. Android TV中實現RecyView循環功能
RecycleView 用法 :
1. [endif]在Gradle中添加
implementation 'com.android.support:recyclerview-v7:26.0.2'
2. [endif]在主布局文件里添加RecycleView
3. [endif]創建item布局文件
在電視開發中,需要添加focusable 與 focusableintouchmode 才可以獲得焦點。
4. [endif]創建adapter繼承RecyclerView.Adapter
5. [endif] 在adapter中添加預設方法
1) [endif]On create ViewHolder()方法是將item布局載入到recycleView 的方法
View view = LayoutInflater. from (parent.getContext()).inflate(R.layout. item_2 , parent, false);
創建一個ViewHolder,並添加到ViewHolder裡面去,最後返回這個ViewHolder:
ViewHolder holder = new ViewHolder(view);return holder;
2) OnbindViewHolder()是將ViewHolder綁定到RecycleView上面時調用的方法
可在這里做更新View的操作。
3) [endif]GetItemCount 方法為返回數據長度的方法。一般返回值為:
return XXX.size();
4) [endif]在adapter中創建一個viewHolder,繼承
RecyclerView.ViewHolder
在這里創建item布局中的控制項對象,在public ViewHolder(View itemView)
方法中初始化:
tvItem2 = itemView.findViewById(R.id. tv_item_2 );
6. 在adapter 中創建一個數據對象用來接收想要傳入的數據,在結構體中接收傳入的數據例如:
private List mData;
在Activity中的操作
1. [endif]創建recycleView對象,創建layoutManager(布局管理器)對象,創建adapter對象,創建數據對象
2. 實例化recycleView對象,layoutManager對象,adapter對象
RecycleView有幾種布局管理器可用,可實現線性,網格,以及瀑布流的界面,以下為線性布局:
mlayoutManager = new LinearLayoutManager(this);
以下為網格布局:
//mlayoutManager = new GridLayoutManager(this,3,GridLayoutManager.HORIZONTAL,false);
3.為recycleview 設置布局管理器:
viewRecy2.setLayoutManager(mlayoutManager);
4.為recycleview設置adapter:
//3 設置數據適配器viewRecy2.setAdapter(myAdapter);
如果要在每一個item中添加事件,採取事件回調的方法,其他自定義View的回調皆類似,以下以添加點擊事件為例:
1) 在adapter中添加點擊事件的介面,並添加介面方法:
public interface onItemClickListener { void onItemClick(View view, int position);}
2) [endif]在adapter中創建介面實例
private onItemClickListener onItemClickListener;
3) 在adapter創建對應set方法體來接收Activity傳入的對象
public void setOnItemClickListener(onItemClickListener onItemClickListener) { this.onItemClickListener = onItemClickListener;}
4)在onbindViewholde中判斷是否設置了監聽器
if (onItemClickListener !=null) {
//為ItemView設置監聽器
holder.tvItem2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
int position =holder.getLayoutPosition();
onItemClickListener.onItemClick(holder.tvItem2, position);
//onItemClickListener.onItemClick();
}
});
}
}
5) 最後在activity中通過adapter對象調用onset方法,實現點擊事件
myAdapter.setOnItemClickListener(new MyAdapter.onItemClickListener() {
@Override
public void onItemClick(View view, int position) {
lastPosition =currentPosition;
currentPosition = position;
// Toast.makeText(RecycleActivity_2.this, "click+" + position, Toast.LENGTH_SHORT).show();
myAdapter.notifyItemChanged(currentPosition);
myAdapter.notifyItemChanged(lastPosition);
}
});
Android TV中RecycleView的Item循環實現
(1) 在TV中遙控器的按鍵取代了手機的滑動,因此我們要監聽遙控器的按鍵,因此在adapter中的item監聽setonkeylistener方法。
並獲取item所在位置的position,存到tag裡面
holder.tvItem2.setTag(position);
當在第一個Item中按向上鍵時,position<0,此時我們調用移動到最後一個,同理,當在最後一個時,移動到第一個。
smoothScrollToPosition(getItemCount() - 1)
holder.tvItem2.setOnKeyListener(new View.OnKeyListener() {
@Override
public boolean onKey(View v, int keyCode, KeyEvent event) {
int action = event.getAction();
// Log.e("---", keyCode + "");
switch (keyCode) {
case KeyEvent.KEYCODE_DPAD_UP:
int positionUp = (int) v.getTag();
if (action == KeyEvent.ACTION_DOWN) {
if (positionUp <=0) {
recyclerView.smoothScrollToPosition(getItemCount() -1);
return true;
}
}
break;
case KeyEvent.KEYCODE_DPAD_DOWN:
int positionDown = (int) v.getTag();
if (action == KeyEvent.ACTION_DOWN) {
if (positionDown >= getItemCount() -1) {
recyclerView.smoothScrollToPosition(0);
return true;
}
}
break;
}
return false;
}
});
(2) 然後在activity中封裝了一個回滾方法來判斷按鍵是否到達底部,並重新獲取焦點
public void scroolChange(RecyclerView recyclerView, boolean toFirst, boolean toLast) {
LinearLayoutManager manager = (LinearLayoutManager) recyclerView.getLayoutManager();
int lastVisibleItem = manager.();
int firstVisibleItem = manager.();
int totalItemCount = manager.getItemCount();
//向下滾動,到底部
if (lastVisibleItem == (totalItemCount -1) && toLast) {
View view = recyclerView.getChildAt(lastVisibleItem);
LinearLayoutManager llM = (LinearLayoutManager) recyclerView.getLayoutManager();
if (view !=null) {
view.requestFocus();
}else if (llM.findViewByPosition(lastVisibleItem) !=null) {
llM.findViewByPosition(lastVisibleItem).requestFocus();
}else {
recyclerView.requestFocus();
}
}
//向上滾動,到頂部
if (firstVisibleItem ==0 && toFirst) {
View view = recyclerView.getChildAt(firstVisibleItem);
LinearLayoutManager llM = (LinearLayoutManager) recyclerView.getLayoutManager();
if (view !=null) {
view.requestFocus();
}else if (llM.findViewByPosition(firstVisibleItem) !=null) {
llM.findViewByPosition(firstVisibleItem).requestFocus();
}else {
recyclerView.requestFocus();
}
}
}
(3) 最後在recycleView 調用addscrolllistener方法,來監聽recycleView的滾動狀態
由於setonScrollListener有時回產生空指針,因此建議使用add方法
viewRecy2.addOnScrollListener(new RecyclerView.OnScrollListener() {
boolean toLast =false;
boolean toFirst =false;
@Override
public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
super.onScrollStateChanged(recyclerView, newState);
if (newState == recyclerView.SCROLL_STATE_IDLE) {
// Log.e("---", "底部");
scroolChange(recyclerView, toFirst, toLast);
}
}
@Override
public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
super.onScrolled(recyclerView, dx, dy);
if (dy >0) {
toLast =true;
}else {
toFirst =true;
}
}
});
Add中包含兩個方法,都可以來判斷是否到達頂部或底部。至此,實現了Android TV中RecycleView的循環功能。
J. android開發圖片(ImageView)要實現循環勻速滾動,速度可調,怎麼實現呢,用什麼組件好呢
採用畫廊視圖,GalleryView,自動勻速定時切換的話可以使用Timetask。網上搜一搜,很多案例。望採納。