首页 > 系统相关 > 【HarmonyOS】一文教你如何通过内存图片方式使用image组件加载网络图片资源

【HarmonyOS】一文教你如何通过内存图片方式使用image组件加载网络图片资源

时间:2023-09-21 11:35:28浏览次数:49  
标签:getInstance get image object bytes DataInstance HarmonyOS new 图片

【关键字】

内存图片方式、image组件、网络图片资源、api6、服务卡片


1、写在前面

之前写过一篇元服务卡片的开发指导,有需求的可以参考以下文章:

【HarmonyOS】低代码开发之FA卡片开发流程

在2.6 初始化卡片部分,我们实现了加载网络资源的图片,但是直接使用image组件加载网络资源似乎在新版本设备上不太友好,所以今天我们来换一种实现方式。


2、代码实现

这次我们准备通过内存图片的方式来使用image组件加载网络图片资源,详细的教程可以参考官方文档:

通过内存图片方式使用image组件

我们的实现还是以【HarmonyOS】低代码开发之FA卡片开发流程 这篇文章中的代码为例,我们需要修改的是WidgetImpl.java这个类。

首先,我们要准备一个工具类,用户获取网络资源的字节流,这里我们定义HttpRequestUtils.java类,实现doGetRequestForFile()方法,返回一个字节数组,详情如下:

import ohos.hiviewdfx.HiLog;
import ohos.hiviewdfx.HiLogLabel;

import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;

public class HttpRequestUtils {
    private static final HiLogLabel TAG = new HiLogLabel(HiLog.DEBUG, 0x0, MainAbility.class.getName());

    public final static byte[] doGetRequestForFile(String urlStr) {
        InputStream is = null;
        HttpURLConnection conn = null;
        byte[] buff = new byte[1024];
        try {
            URL url = new URL(urlStr);
            conn = (HttpURLConnection) url.openConnection();

            conn.setDoInput(true);
            conn.setRequestMethod("GET");
            conn.setReadTimeout(6000);
            conn.connect();
            is = conn.getInputStream();
            if (conn.getResponseCode() == 200) {
                buff = readInputStream(is);
            } else{
                buff=null;
            }
        } catch (Exception e) {
            HiLog.error(TAG,"【获取图片异常】",e);
        }
        finally {
            try {
                if(is != null){
                    is.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
            conn.disconnect();
        }
        return buff;
    }
}

 【HarmonyOS】一文教你如何通过内存图片方式使用image组件加载网络图片资源_java

然后我们进入WidgetImpl类中,我们需要修改初始化卡片数据以及点击事件时需要更新的卡片样式的代码,实现的思路都是一样的。

首先获取当前时间戳用来拼接图片名称,这样是为了保证唯一性:

long onlyOne = System.currentTimeMillis();

 【HarmonyOS】一文教你如何通过内存图片方式使用image组件加载网络图片资源_ide_02

然后通过ZSONObject,将{imageSrc,memory:// + picName}的键值对添加到ZSONObject中:

object.put("btnSrc", "memory://btnsrc" + onlyOne + ".png");

 【HarmonyOS】一文教你如何通过内存图片方式使用image组件加载网络图片资源_System_03

然后使用该ZSONObject去创建一个FormBindingData:

FormBindingData bindingData = new FormBindingData(object);
ProviderFormInfo formInfo = new ProviderFormInfo();
formInfo.setJsBindingData(bindingData);

 【HarmonyOS】一文教你如何通过内存图片方式使用image组件加载网络图片资源_System_04

然后获取网络图片资源的字节流:

bytes = HttpRequestUtils.doGetRequestForFile(DataInstance.getInstance().getList().get(0).getBtnSrc());

 【HarmonyOS】一文教你如何通过内存图片方式使用image组件加载网络图片资源_ide_05

最后通过addImageData接口添加数据:addImageData("xxx.png", bytes),其中,"xxx.png"为picName,必须和上面添加到ZSONObject中的键值对的picName一致,否则上面的内存图片路径("memory://xxx.png")将读取不到这里添加进去的图片数据。

bindingData.addImageData("btnsrc" + onlyOne + ".png", bytes);

 【HarmonyOS】一文教你如何通过内存图片方式使用image组件加载网络图片资源_ide_06

WidgetImpl类的完整代码如下:

public class WidgetImpl extends FormController {

    private static final HiLogLabel TAG = new HiLogLabel(HiLog.DEBUG, 0x0, "jscard");
    private static final int DIMENSION_1X2 = 1;
    private static final int DIMENSION_2X2 = 2;
    private Context mContext;

    public WidgetImpl(Context context, String formName, Integer dimension) {
        super(context, formName, dimension);
        HiLog.info(TAG, "WidgetImpl");
        this.mContext = context;
    }

    @Override
    public ProviderFormInfo bindFormData(long formId) {
        HiLog.info(TAG, "222---" + new Date().getTime());
        HiLog.info(TAG, "bind form data");
        ZSONObject object = new ZSONObject();
        long onlyOne = System.currentTimeMillis();
        byte[] bytes = null;
        if (dimension == DIMENSION_1X2) {
            object.put("smallCard", true);
            object.put("normalCard", false);
            object.put("type", DataInstance.getInstance().getList().get(0).getType());
            object.put("title", DataInstance.getInstance().getList().get(0).getTitle());
            // 根据动态获取的云侧配置项里的字段值动态修改标题内容
            if (!TextUtils.isEmpty(DataInstance.getInstance().getExtFaParamStr())) {
                object.put("title", DataInstance.getInstance().getExtFaParamStr());
            }
        } else if (dimension == DIMENSION_2X2) {
            object.put("smallCard", false);
            object.put("normalCard", true);
            object.put("type", DataInstance.getInstance().getList().get(2).getType());
            object.put("title", DataInstance.getInstance().getList().get(2).getTitle());
            // 根据动态获取的云侧配置项里的字段值动态修改标题内容
            if (!TextUtils.isEmpty(DataInstance.getInstance().getExtFaParamStr())) {
                object.put("title", DataInstance.getInstance().getExtFaParamStr());
            }
        }
        object.put("btnSrc", "memory://btnsrc" + onlyOne + ".png");
        FormBindingData bindingData = new FormBindingData(object);
        ProviderFormInfo formInfo = new ProviderFormInfo();
        formInfo.setJsBindingData(bindingData);
        if (dimension == DIMENSION_1X2) {
            if (!DataInstance.getInstance().isPlay()) {
                bytes = HttpRequestUtils.doGetRequestForFile(DataInstance.getInstance().getList().get(0).getBtnSrc());
            } else {
                bytes = HttpRequestUtils.doGetRequestForFile(DataInstance.getInstance().getList().get(1).getBtnSrc());
            }
        } else if (dimension == DIMENSION_2X2) {
            if (!DataInstance.getInstance().isPlay()) {
                bytes = HttpRequestUtils.doGetRequestForFile(DataInstance.getInstance().getList().get(2).getBtnSrc());
            } else {
                bytes = HttpRequestUtils.doGetRequestForFile(DataInstance.getInstance().getList().get(3).getBtnSrc());
            }
        }
        bindingData.addImageData("btnsrc" + onlyOne + ".png", bytes);
        return formInfo;
    }

    @Override
    public void updateFormData(long formId, Object... vars) {
        HiLog.info(TAG, "updateFormData");
    }

    @Override
    public void onTriggerFormEvent(long formId, String message) {
        HiLog.info(TAG, "onTriggerFormEvent");
        if (!TextUtils.isEmpty(message)) {
            byte[] bytes = null;
            ZSONObject zsonObject = ZSONObject.stringToZSON(message);
            String msg = zsonObject.getString("message");
            if (!TextUtils.isEmpty(msg) && "play".equals(msg)) {
                if (!DataInstance.getInstance().isPlay()) {
                    DataInstance.getInstance().setPlay(true);
                    if (dimension == DIMENSION_1X2) {
                        bytes = HttpRequestUtils.doGetRequestForFile(DataInstance.getInstance().getList().get(1).getBtnSrc());
                    } else if (dimension == DIMENSION_2X2) {
                        bytes = HttpRequestUtils.doGetRequestForFile(DataInstance.getInstance().getList().get(3).getBtnSrc());
                    }
                    updateForm(formId, bytes);
                    play();
                } else {
                    DataInstance.getInstance().setPlay(false);
                    if (dimension == DIMENSION_1X2) {
                        bytes = HttpRequestUtils.doGetRequestForFile(DataInstance.getInstance().getList().get(0).getBtnSrc());
                    } else if (dimension == DIMENSION_2X2) {
                        bytes = HttpRequestUtils.doGetRequestForFile(DataInstance.getInstance().getList().get(2).getBtnSrc());
                    }
                    updateForm(formId, bytes);
                    pause();
                }
            }
        }
    }

    @Override
    public Class<? extends AbilitySlice> getRoutePageSlice(Intent intent) {
        return null;
    }

    // 更新数据
    private void updateForm(long formId, byte[] bb) {
        ZSONObject object = new ZSONObject();
        long onlyOne = System.currentTimeMillis();
        object.put("btnSrc", "memory://btnsrc" + onlyOne + ".png");
        FormBindingData bindingData = new FormBindingData(object);
        ProviderFormInfo formInfo = new ProviderFormInfo();
        formInfo.setJsBindingData(bindingData);
        bindingData.addImageData("btnsrc" + onlyOne + ".png", bb);
        try {
            if (mContext instanceof Ability) {
                ((Ability) mContext).updateForm(formId, bindingData);
            }
        } catch (FormException e) {
            HiLog.error(TAG, e.getMessage());
        }
    }

    // 暂停音乐
    private void pause() {
        DataInstance.getInstance().getPlayer().pause();
    }

    // 播放音乐
    private void play() {
        DataInstance.getInstance().getPlayer().play();
    }
}

 【HarmonyOS】一文教你如何通过内存图片方式使用image组件加载网络图片资源_ide_07

OK,通过上面的代码,我们就可以实现使用image组件加载网络图片资源啦。


标签:getInstance,get,image,object,bytes,DataInstance,HarmonyOS,new,图片
From: https://blog.51cto.com/u_15687416/7552024

相关文章

  • 【HarmonyOS】一文教你如何通过内存图片方式使用image组件加载网络图片资源
    ​【关键字】内存图片方式、image组件、网络图片资源、api6、服务卡片 1、写在前面之前写过一篇元服务卡片的开发指导,有需求的可以参考以下文章:【HarmonyOS】低代码开发之FA卡片开发流程在2.6初始化卡片部分,我们实现了加载网络资源的图片,但是直接使用image组件加载网络资......
  • File文件流与base64图片格式转换
    //base64转文件exportfunctionbase64ToFile(base64:any,fileName:string){if(!base64)returnletdata=base64.split(',');lettype=data[0].match(/:(.*?);/)[1];constbstr=window.atob(data[1]);letn=bstr.length;constu8arr=......
  • Android 妙用TextView实现左边文字,右边图片
    有时候,需要文字在左边,右边有个箭头,我个人之前会有两种做法:使用线性布局来实现或者使用约束布局,一个左对齐,一个右对齐这几天突然想到是否可以使用TextView的设置图标的方式实现,研究发现确实可以实现我的需求,也是记录下文字和图标左右显示效果:代码:<TextViewandroid:id="@+id/......
  • 在开启contenteditable可编辑div光标处插入图片
     $("#Content").focus();//创建img元素varimg=document.createElement('img');img.src='xxxx';img.style.display='block';//插入img元素if(window.getSelection){vareditableDiv=document.getEle......
  • 谷歌优化里的图片搜索运算符
    与网页搜索类似,Google图片也支持专用的搜索运算符,即 src: 和 imagesize:。这些运算符仅适用于Google图片;它们对其他Google产品和服务不起作用。src: 搜索运算符src: 搜索运算符将返回在 src 属性中引用了运算符中提供的图片网址的网页。例如:src:https://example.com/me......
  • java实现百度OCR图片文字识别
    java实现百度OCR图片文字识别最近在做一个扫描图片识别文字的功能,决定用百度AI开发平台完成1打开网址​ 打开地址:https://ai.baidu.com/手机验证码登录2选择通用文字识别开放能力->文字识别->通用文字识别3进入到通用文字识别页面4API的调用使用方式(1)首先......
  • HarmonyOS ArkTS应用沉浸式状态栏
    开始学习鸿蒙,自己写个项目,app开发中,经常会需要隐藏顶部导航栏,在网上没找到资料,去翻看鸿蒙开发文档,找到了解决方法项目我使用的Stage模型1. 找到自动生成入口文件EntryAbility.ets 文件中,类继承的UIAbility2. 在onWindowStageCreate方法里写以下代码设置setWindowLayou......
  • 基于pHash+hammingdistance的图片相似度比较
    参考文献图片相似度计算方法总结-知乎(zhihu.com)PythonOpenCV视觉特征提取和匹配-知乎(zhihu.com)图像相似度中的Hash算法-Yumeka-博客园(cnblogs.com)汉明距离及其高效计算方式(zhihu.com)开源仓库https://github.com/python-pillow/Pillowhttps://github.com/cybe......
  • dedebiz 清理冗余废弃未引用图片方法
    原理描述:在原有织梦后台菜单中增加"清理冗余图片按钮",实现清理冗余图片的功能.操作步骤:1.打开后台admin\sys_sql_query.php代码在该文件中搜索如下代码://修复全部表elseif($dopost=="repairAll"){  $dsql->SetQuery("ShowTables");  $dsql->Execute('t'); ......
  • qt图片处理界面
     #ifndefMAINWINDOW_H#defineMAINWINDOW_H#include<QMainWindow>#include<opencv2/opencv.hpp>usingnamespacecv;QT_BEGIN_NAMESPACEnamespaceUi{classMainWindow;}QT_END_NAMESPACEclassMainWindow:publicQMainWindow{Q_OBJECT......