Egret中实现生成<img>标签的二维码功能。

一  在index.html上给egret的div增加 id = "gameDiv"。我们会根据id获取这个div,并动态添加一个<img>。

<div style="margin: auto;width: 100%;height: 100%;" class="egret-player" id="gameDiv"
data-entry-class="Main"
data-orientation="portrait"
data-scale-mode="fixedWidth"
data-frame-rate="30"
data-content-width="640"
data-content-height="1136"
data-show-paint-rect="false"
data-multi-fingered="2"
data-show-fps="false" data-show-log="false"
data-show-fps-style="x:0,y:0,size:12,textColor:0xffffff,bgAlpha:0.9">
</div>

二 自定义操作<img>的二维码类QRCode

/**
* 生成<img>标签二维码
* @author chenkai
* @date 2016/12/26
*/
class QRCode{
/**二维码img标签*/
private myImg: HTMLImageElement;
/**二维码图片地址*/
private imgUrl:string;
/**Egret中eui.Image二维码图片,用于定位*/
private codeImg:egret.DisplayObject; /**重置位置*/
private onResize(){
console.log("屏幕旋转,重置二维码位置");
if(this.imgUrl && this.codeImg){
this.showCode(this.imgUrl,this.codeImg);
}
} /**
* 显示二维码
* imgUrl 二维码图片地址
* codeImg egret中二维码图片 (二维码图片容器必须和stage相等高宽)
*/
public showCode(imgUrl: string, codeImg: egret.DisplayObject): void {
this.imgUrl = imgUrl;
this.codeImg = codeImg;      //横竖屏旋转,重置二维码位置
App.StageUtils.getStage().addEventListener( //这里的App.StageUtils是我自定义的可全局访问的stage,可以替换成你自己的stage
egret.StageOrientationEvent.ORIENTATION_CHANGE,this.onResize,this); //二维码不存在,则创建一个
if(this.myImg == null){
var gameDiv = document.getElementById("gameDiv");
this.myImg = document.createElement("img");
this.myImg.src = imgUrl;
this.myImg.style.position = "absolute";
this.myImg.style.display = "none";
gameDiv.appendChild(this.myImg);
} //竖屏
if(document.body.clientWidth < document.body.clientHeight){
var wScale = document.body.clientWidth / App.StageUtils.stageWidth;
var hScale = document.body.clientHeight / App.StageUtils.stageHeight;
this.myImg.style.width = codeImg.width * wScale + "px";
this.myImg.style.height = codeImg.height * hScale + "px";
this.myImg.style.left = codeImg.x * wScale + "px";
this.myImg.style.top = codeImg.y * hScale + "px";
this.myImg.style.display = "inline";
//横屏
}else{
var wScale = document.body.clientWidth / App.StageUtils.stageHeight;
var hScale = document.body.clientHeight / App.StageUtils.stageWidth;
this.myImg.style.width = codeImg.height*wScale + "px";
this.myImg.style.height = codeImg.width*hScale + "px";
this.myImg.style.top = (App.StageUtils.stageWidth - codeImg.x - codeImg.width)*hScale + "px";
this.myImg.style.left = codeImg.y*wScale + "px";
this.myImg.style.display = "inline";
} } /**隐藏二维码*/
public hideCode(): void {
if(this.myImg) {
this.myImg.style.display = "none";
}
} /**销毁*/
public onDestroy(){
App.StageUtils.getStage().removeEventListener(egret.StageOrientationEvent.ORIENTATION_CHANGE,this.onResize,this);
this.codeImg = null;
}
}

三  直接在Egret的exml放置二维码图片,变量名为codeImg

竖屏时效果

横屏时效果

四  使用QRCode生成<img>二维码

var codeImg:eui.Image;    //exml上二维码图片
var qrCode:QRCode = new QRCode();
qrCode.showCode("resource/assets/Button/button_down.png", codeImg); //button_down.png 随便找的一个蓝色小方块图片

使用QRCode类,在exml的二维码上覆盖一层<img>标签,这里是蓝色透明的,方便观察覆盖的效果,图片有点模糊,懒得找了 - -!

实际使用时,应该将button_down.png换成你实际的二维码图片。

竖屏时效果

横屏时效果

在Egret实现二维码长按识别的更多相关文章

  1. C# ZXing.Net生成二维码、识别二维码、生成带Logo的二维码(二)

    1.使用ZXint.Net生成带logo的二维码 /// <summary> /// 生成带Logo的二维码 /// </summary> /// <param name ...

  2. C# - VS2019 WinFrm程序调用ZXing.NET实现条码、二维码和带有Logo的二维码的识别

    前言 C# WinFrm程序调用ZXing.NET实现条码.二维码和带有Logo的二维码的识别. ZXing.NET导入 GitHub开源库 ZXing.NET开源库githib下载地址:https: ...

  3. 分享一个二维码图片识别控制台程序Demo

    怎么用NuGet和配置log4net就不介绍了,直接上代码(QRDecodeDemo.zip). (Visual Studio 2015 下的项目,用的.NET Framework 4.5.2) 吐槽 ...

  4. 微信小程序实战篇-图片的预览、二维码的识别

    开篇 今天,做的小程序项目要求,个人中心的客服图片在用户长按时可以识别其二维码,各种翻阅查找,采坑很多,浪费了很多时间,在这里记录下需要注意的点,以及对小程序官方提供的API做一个正确和清晰的认知,希 ...

  5. C#_WPF中创建二维码、识别二维码

    第三方库: WPFMediaKit.dll (WPFMediaKit摄像头处理) zing.dll NuGet安装这两个第三方dll 项目截图预览: 项目代码: using System; using ...

  6. iOS QRcode识别及相册图片二维码读取识别

    https://www.jianshu.com/p/48e44fe67c1d 2016.03.30 10:32* 字数 892 阅读 16197评论 5喜欢 34赞赏 1 最近碰到一个用户 在使用我们 ...

  7. vue 二维码长按保存和复制内容

    效果图: 二维码用了 qrcode.vue npm install qrcode.vue --save 复制内容用了 vue-clipboard2 npm install vue-clipboard2 ...

  8. spa(单页应用)中,使用history模式时,微信长按识别二维码在ios下失效的问题

    spa(单页应用,vue)中,使用history模式时,微信长按识别二维码在ios下失效的问题. 触发条件: spa单页应用: 路由模式 history 从其他页面跳转到带有微信二维码识别的页面(不是 ...

  9. Android二维码识别 开源项目ZXing的编译

    Android二维码识别 开源项目ZXing的编译 Android端的条形码/二维码识别功能 因为手机端的输入不是很方便,所以条形码/二维码的扫描是一种很有效的解决手段. 比较流行的手机应用中,常用的 ...

随机推荐

  1. AMQP与RabbitMQ简介

    MQ(Message Queue,消息队列)是一种应用系统之间的通信方法.是通过读写出入队列的消息来通信(RPC则是通过直接调用彼此来通信的). 1.AMQP协议 在了解RabbitMQ之前,首先要了 ...

  2. Git工作流指南:Pull Request工作流

    参考地址:http://blog.jobbole.com/76854/ Pull Requests是Bitbucket上方便开发者之间协作的功能.提供了一个用户友好的Web界面,在集成提交的变更到正式 ...

  3. 18、SQL提高篇(变量的使用 拓展)

    一  例题 例题用表:[cost] 注:费用类型个数不定 将上图所示的表根据type列的类型转为下图样式 *用变量将类型名分组动态提取的方法: ) set @sql1='' select @sql1= ...

  4. 浅谈C#中的接口和抽象类

    C#中接口为"其他方面互不相干"的类型提供公共的服务和特征:C#中class只支持但继承,使用接口却支持多继承,例如:C#中System.String是从System空间中的4个i ...

  5. Linux线程-pthread_kill

    该函数可以用于向指定的线程发送信号: int pthread_kill(pthread_t threadId,int signal); 如果线程内不对信号进行处理,则调用默认的处理程式,如SIGQUI ...

  6. source insight shift+tab问题

    之前用的好好的,shift+tab功能为向左缩进(即tab的相反功能),但是突然就有问题了:现象为只是光标向左移动,但文本不动. 解决方法: 1 使用快捷键f9 2 重新定义快捷键,把shift+ta ...

  7. C# 反射遍历对象

    在项目中需要遍历各种对象,可以通过如下方法遍历. /// <summary> /// 返回对象字符串 /// </summary> /// <param name=&qu ...

  8. 记录以下boost::shared_ptr的一个使用细节

    shared_ptr<T>::operator->返回的是T*类型指针,非const T*指针.因此通过const shared_ptr<T>&类型的ptr可以直 ...

  9. 解析HTTP协议六种请求方法,get,head,put,delete,post有什么区别

    GET: 请求指定的页面信息,并返回实体主体.HEAD: 只请求页面的首部.POST: 请求服务器接受所指定的文档作为对所标识的URI的新的从属实体.PUT: 从客户端向服务器传送的数据取代指定的文档 ...

  10. WPF 中保存 window(窗口)或者canvas成图片

    最近需要用到这个功能,搜了一下不少代码有问题 ,找到一个效果比较好的,支持多级子元素 记一下. private void button_save_window_Click(object sender, ...