当前位置: 首页 > news >正文

国外做问卷网站好移动建站公司

国外做问卷网站好,移动建站公司,建设一个网站需要多少费用,做网站的方法注:该列出的代码,都在文章内示例出 1. 另存为按钮事件: const saveAsHandler async () > {const { path, sessionId } recordInfoif(typeof message ! string) return;// 因为我的图片是加密的,所以我需要根据接口返回的路…

注:该列出的代码,都在文章内示例出

1. 另存为按钮事件:

const saveAsHandler = async () => {const { path, sessionId } = recordInfoif(typeof message !== 'string') return;// 因为我的图片是加密的,所以我需要根据接口返回的路径,然后根据不同图片的密钥(sessionId)去进行解密(decodeAvatarUrl)处理,最后返回blob,所以这块儿不必纠结const res = await decodeAvatarUrl(path, sessionId, false)// blob转ArrayBufferblobToArrayBuffer(res, async (buffer: ArrayBuffer) => {const type = await getImageType(res) // 将Blob数据传给getImageType,经处理后获取图片类型, 请看标题2的代码示例// saveAsPicture 这个就是渲染进程与Electron的通信 ,请看标题3的代码示例saveAsPicture({ buffer, name: getNowTime(), type }).then(() => setOpen(false))})}

2. getImageType代码:

/*** get image type In image buffer*/
export function getImageType (blob: Blob) {return new Promise((resolve: (type: string) => void, reject) => {const reader = new FileReader();reader.onload = (event: any) => {// 使用Uint8Array和DataView来读取文件头部const arr = new Uint8Array(event.target.result);const view = new DataView(arr.buffer);// 根据文件头部的magic number判断文件类型switch (view.getUint16(0, false)) {case 0xffd8: // JPEGresolve('image/jpeg');break;case 0x8950: // PNGresolve('image/png');break;case 0x4749: // GIFresolve('image/gif');break;case 0x4949: // TIFFcase 0x4d4d: // TIFFresolve('image/tiff');break;default:reject(new Error('Unsupported image type'));}};reader.onerror = reject;// 读取Blob为ArrayBufferreader.readAsArrayBuffer(blob);})
}

3. saveAsPicture的主要代码:

/** 校验:另存为 */
type saveAsPicturePrams = {buffer: ArrayBuffer;name: string;type: string;
} 
/** 另存为 */
export const saveAsPicture = (params: saveAsPicturePrams) => {// 关于与Electron的UI.SAVEASPATH的通信,请看标题4return ipcRenderer.invoke(UI.SAVEASPATH, params)
}

4. Electron进程与渲染进程的交互

/*** 对话窗口:另存为图片时,需要获取选择要存储的路径* @param buffer 数据* @name 文件名* @type 文件类型*/
ipcMain.handle(UI.SAVEASPATH, (e, arg: { buffer: ArrayBuffer, name: string, type: string; }) => {return new Promise(async (resolve, reject) => {const { buffer, name, type } = arg;const imageType = type?.split('/').pop() //获取图片格式const imageName = `xxxxxxx_${name}`const defaultPath = path.join(app.getPath('downloads'),`${imageName}.${imageType}`)await dialog.showSaveDialog(mainWindow, {title: '另存为...',buttonLabel: '保存',defaultPath,properties: ['createDirectory'],filters: [{name: `图片文件(*.${imageType})`,extensions: [imageType]}]}).then((res: any) => {if(res.canceled) {resolve(res)return;};fs.writeFileSync(res.filePath, new DataView(buffer))resolve(res)})})})

效果图:

在这里插入图片描述

http://www.yayakq.cn/news/266957/

相关文章:

  • 微网站套餐昆明公司网站
  • 网络违法犯罪网站举报新闻最新消息
  • 汕头网站上排名成都电商设计招聘网站
  • 专业企业建站公司基于构件的软件开发流程
  • 怎么在网站中做视频背景WordPress页面开发
  • 福州培训网站建设小程序制作模板免费
  • 网站建设备案图片手机网站预览
  • 哪家做网站做的好wordpress 怎么加页面
  • html5微网站源码长沙招聘网站哪个最好
  • 网站建设文件上传附近的广告设计公司在哪
  • 哈尔滨网站建设流程怎么提高网站打开速度
  • 回忆网站模板网站服务器租赁合同
  • 网站建设是不是都需要交费数据查询网站模板
  • 做任务的网站源码移动端网站模板怎么做的
  • 保定市做网站的电话安宁网站建设与制作
  • 深圳做网站公司 南山个人网站要备案嘛
  • 有免费的网站域名吗wordpress微信公众号推送
  • 做钓鱼网站软件莱芜定制网站建设公司
  • 做纺织行业的网站济南网页设计培训
  • seo对各类网站的作用wordpress企业网站插件
  • 前端asp网站开发兴安盟seo
  • 阿里云服务器做网站需要备案北京病例最新消息今天
  • 长沙网站设计费用韩国做网站网站违法不
  • 做网站背景音乐怎么开发直播平台
  • 做女装的网站有哪些好玩网页游戏
  • 织梦cms 获得网站流量次数高端网站设计 上海
  • 高米店网站建设公司优化 网站访问速度
  • 网站单页支付宝支付怎么做的内江手机网站建设
  • 交易平台网站怎么做陕西省私募基金协会
  • 哪个网站做体检预约的品牌营销策划师