android页面设置background为图片后,页面滑动掉帧问题

最近在做一个视频demo。在seekBar 左边有一个当前时间的 textview,会根据onprogress 的值每秒刷新。

当设置了背景图时,每次 textview 在setText 时视频都会发生卡顿。明显可见的每秒卡一下。

去除背景图片,或者是移除每秒setText 之后都不卡了。

两种背景图设置的方法都会卡

rootView = findViewById(android.R.id.content);

// 设置方法1
rootView.setBackgroundResource(R.drawable.sony1);

// 设置方法2
View view = new View(mContext);
view.setBackground(getResources().getDrawable(R.drawable.sony1));

FrameLayout.LayoutParams flp = new FrameLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
view.setLayoutParams(flp);
rootView.addView(view, 0, flp);

直到查询之后才发现

背景图片的资源图片文件要放到mipmap-xxxx文件夹下,或者放到drawable-xxxx文件夹下,不能直接放在drawable文件夹下

原来的文件就是直接放在drawable 文件夹下面的,移到mipmap 目录后卡顿解决。

当然,别人推荐的还有一点:

manifests清单文件中,application的属性hardwareAccelerated要设置为开启

android:hardwareAccelerated="false"

 

这个问题应该是和drawable 下的图片进行了自动缩放有关

不过测试在背景 RelativeLayout 中设置background,重写 layout 的ondraw、onLayout、onMeasure,并没有出现每秒触发。

 

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
可以通过使用ViewPager和FragmentPagerAdapter来实现在页面上方有一个图片栏ImageView,并且可以循环播放三张图片,也可以通过滑动切换。下面是实现步骤: 1. 在布局文件中添加ViewPager和ImageView组件。 ``` <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <androidx.viewpager.widget.ViewPager android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="200dp" /> <ImageView android:id="@+id/image_view" android:layout_width="match_parent" android:layout_height="wrap_content" android:adjustViewBounds="true" android:scaleType="fitCenter" android:src="@drawable/ic_launcher_background" /> </LinearLayout> ``` 2. 创建三个Fragment用来显示轮播图。 ``` public class BannerFragment extends Fragment { private int mPosition; public static BannerFragment newInstance(int position) { BannerFragment fragment = new BannerFragment(); Bundle args = new Bundle(); args.putInt("position", position); fragment.setArguments(args); return fragment; } @Override public void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); mPosition = getArguments().getInt("position"); } @Nullable @Override public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { ImageView imageView = new ImageView(getActivity()); switch (mPosition) { case 0: imageView.setImageResource(R.drawable.banner_1); break; case 1: imageView.setImageResource(R.drawable.banner_2); break; case 2: imageView.setImageResource(R.drawable.banner_3); break; } imageView.setScaleType(ImageView.ScaleType.CENTER_CROP); return imageView; } } ``` 3. 创建一个FragmentPagerAdapter用来管理轮播图的Fragment。 ``` public class BannerPagerAdapter extends FragmentPagerAdapter { public BannerPagerAdapter(FragmentManager fm) { super(fm); } @Override public Fragment getItem(int position) { return BannerFragment.newInstance(position % 3); } @Override public int getCount() { return Integer.MAX_VALUE; } } ``` 4. 在Activity中设置ViewPager和ImageView的适配器,并设置ViewPager的滑动监听器和ImageView的图片资源。 ``` public class MainActivity extends AppCompatActivity { private ViewPager mViewPager; private ImageView mImageView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mViewPager = findViewById(R.id.view_pager); mImageView = findViewById(R.id.image_view); BannerPagerAdapter adapter = new BannerPagerAdapter(getSupportFragmentManager()); mViewPager.setAdapter(adapter); mViewPager.setCurrentItem(Integer.MAX_VALUE / 2); mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { } @Override public void onPageSelected(int position) { mImageView.setImageResource(getBannerResId(position % 3)); } @Override public void onPageScrollStateChanged(int state) { } }); mImageView.setImageResource(getBannerResId(0)); } private int getBannerResId(int position) { switch (position) { case 0: return R.drawable.banner_1; case 1: return R.drawable.banner_2; case 2: return R.drawable.banner_3; default: return R.drawable.ic_launcher_background; } } } ``` 这样就可以实现在页面上方有一个图片栏ImageView,并且可以循环播放三张图片,也可以通过滑动切换。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值