| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 移动开发 -> Android自定义轮播效果,android常见面试题 -> 正文阅读 |
|
[移动开发]Android自定义轮播效果,android常见面试题 |
================== clipChildren 属性要放在 父控件上,意思是是否把子控件的多余部分隐藏,要配合子控件的?android:layout_gravity="" 使用。 效果展示 布局代码 <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android” xmlns:app=“http://schemas.android.com/apk/res-auto” xmlns:tools=“http://schemas.android.com/tools” android:layout_width=“match_parent” android:layout_height=“match_parent” android:orientation=“horizontal” android:clipChildren=“false” //放在父控件上 tools:context=".MainActivity"> <LinearLayout android:layout_width=“match_parent” android:layout_height=“40dp” android:layout_gravity=“bottom” android:orientation=“horizontal”> <ImageView android:layout_width=“0dp” android:layout_height=“match_parent” android:layout_weight=“1” android:src="@mipmap/ic_launcher"/> <ImageView android:layout_width=“0dp” android:layout_height=“match_parent” android:layout_weight=“1” android:src="@mipmap/ic_launcher"/> <ImageView android:layout_width=“0dp” android:layout_height=“70dp” android:layout_weight=“1” android:layout_gravity=“bottom” //子控件配合 android:src="@mipmap/ic_launcher"/> <ImageView android:layout_width=“0dp” android:layout_height=“match_parent” android:layout_weight=“1” android:src="@mipmap/ic_launcher"/> <ImageView android:layout_width=“0dp” android:layout_height=“match_parent” android:layout_weight=“1” android:src="@mipmap/ic_launcher"/> 了解?PagerTransformer ===================
注意点:根布局 和 ViewPager 都得加?clipChildren = “false" 属性,缺一不可 <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android” xmlns:app=“http://schemas.android.com/apk/res-auto” xmlns:t android:layout_width=“match_parent” android:layout_height=“match_parent” android:orientation=“horizontal” android:clipChildren=“false” //不能少 tools:context=".MainActivity"> <androidx.viewpager.widget.ViewPager android:id="@+id/vp_my_viewpager" android:layout_width=“match_parent” android:layout_height=“200dp” android:layout_marginLeft=“80dp” //写这个属性的目的是 不能让单个 ViewPager 项占满整个横屏 android:layout_marginRight=“80dp” android:clipChildren=“false” //不能少 />
package com.wust.myhorizontalscrollview; import androidx.annotation.NonNull; import androidx.appcompat.app.AppCompatActivity; import androidx.viewpager.widget.PagerAdapter; import androidx.viewpager.widget.ViewPager; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.View; import android.view.ViewGroup; import android.view.animation.AccelerateInterpolator; import android.widget.ImageView; import java.lang.reflect.Field; import java.util.ArrayList; import java.util.List; public class MainActivity extends AppCompatActivity { private ViewPager vp_my_viewpager; private List imgList; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //准备图片资源 imgList = new ArrayList<>(); imgList.add(R.drawable.test); imgList.add(R.drawable.test2); imgList.add(R.drawable.test); imgList.add(R.drawable.test2); imgList.add(R.drawable.test); //第一步:找到 ViewPager 这个控件 vp_my_viewpager = findViewById(R.id.vp_my_viewpager); //第二步:设置 ViewPager 的一些属性 // 这个属性的目的 是设置 预加载3张 防止 滚动时出现断层 vp_my_viewpager.setOffscreenPageLimit(3); // 这个属性的目的 是设置 每个Item之间的距离间隔 vp_my_viewpager.setPageMargin(10); //第三步:设置适配器 vp_my_viewpager.setAdapter(new myPagerAdapter()); } private class myPagerAdapter extends PagerAdapter { @Override public int getCount() { return imgList.size(); } @Override public boolean isViewFromObject(@NonNull View view, @NonNull Object object) { return view == object; } @NonNull @Override public Object instantiateItem(@NonNull ViewGroup container, int position) { ImageView iv = new ImageView(getApplicationContext()); iv.setImageResource(imgList.get(position)); container.addView(iv); return iv; } @Override public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) { container.removeView((View) object); } } } 写到这里,基本的效果已经出来了 如果想要更酷炫的效果,那我们的主角得登场了?PagerTransformer
transformPage(@NonNull View page, float position) #参数一: 视图 #参数二: 参数一视图对应的位置变化 经过上面的分析,我们可知我们最关心的是 屏幕显示项 + 屏幕显示项两侧布局 的动画效果,他们的 position 变化我们也通过图解描述的很清楚 package com.wust.myhorizontalscrollview; import androidx.annotation.NonNull; import androidx.appcompat.app.AppCompatActivity; import androidx.viewpager.widget.PagerAdapter; 经过上面的分析,我们可知我们最关心的是 屏幕显示项 + 屏幕显示项两侧布局 的动画效果,他们的 position 变化我们也通过图解描述的很清楚 package com.wust.myhorizontalscrollview; import androidx.annotation.NonNull; import androidx.appcompat.app.AppCompatActivity; import androidx.viewpager.widget.PagerAdapter; |
|
移动开发 最新文章 |
Vue3装载axios和element-ui |
android adb cmd |
【xcode】Xcode常用快捷键与技巧 |
Android开发中的线程池使用 |
Java 和 Android 的 Base64 |
Android 测试文字编码格式 |
微信小程序支付 |
安卓权限记录 |
知乎之自动养号 |
【Android Jetpack】DataStore |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/24 12:33:31- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |