鸿蒙 加载长图(大图自动适用屏幕的宽度)

1.引入:

implementation 'io.openharmony.tpc.thirdlib:glide:1.0.3'
implementation 'io.openharmony.tpc.thirdlib:subsampling-scale-image-view:1.0.4'//加载长图

2.xml

 <com.davemorrissey.labs.subscaleview.SubsamplingScaleImageView
        ohos:id="$+id:longImg"
        ohos:image_src="$media:test2"
        ohos:height="match_content"
        ohos:layout_alignment="center"
        ohos:width="match_content"/>

3.java 代码

private void initView() {

        GlideUrl glideUrl = new GlideUrl(url, new LazyHeaders.Builder()
                .build());

        Glide.with(context)
                .asBitmap()
                .load(glideUrl)
                .apply(new RequestOptions()
                        .placeholder(ResourceTable.Media_boy)
                        .error(ResourceTable.Media_boy)
                        .skipMemoryCache(true) // 不使用内存缓存
                        .diskCacheStrategy(DiskCacheStrategy.NONE) // 不使用磁盘缓存
                )
                .into(new SimpleTarget<PixelMap>() {
                    public void onResourceReady(PixelMap pixelMap, Transition<? super PixelMap> transition) {
                        longImg.setPixelMap(pixelMap);
                        int phoneWidth = DisplayUtils.getDisplayWidthInPx(context);
                        int phoneHeight = DisplayUtils.getDisplayHeightInPx(context);
                        Log.d("屏幕-宽度", phoneWidth + "");
                        Log.d("屏幕-高度", phoneHeight + "");
                        int picWidth = pixelMap.getImageInfo().size.width;
                        int picHeight = pixelMap.getImageInfo().size.height;
                        Log.d("图片-宽度", picWidth + "");
                        Log.d("图片-高度", picHeight + "");
                        float scaleNum = ((float) phoneWidth / (float) picWidth);
                        Log.d("放大比率-宽度", scaleNum + "");
                        //如果 图片的高度度 大于 屏幕的宽度 就把原始图片放大到屏幕的宽度 放大的比率是 手机屏幕的宽度除以图片的宽度
                        if (picHeight >= phoneHeight) {
                            Log.d("设置最小放大比率", "小====");
                            longImg.setMinScale(scaleNum);
                        }
                    }
                });
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值