| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1976 人关注过本帖
标题:手机端屏幕旋转后全图被拉伸怎么处理
取消只看楼主 加入收藏
qq249956453
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2019-10-18
收藏
 问题点数:0 回复次数:2 
手机端屏幕旋转后全图被拉伸怎么处理
程序代码:
<style type="text/css">
            
            #fullPage{
                display: none;
                background: black;
                position: fixed;
                top: 0;
                left: 0;
                width: 100%;
                height: 100%;
                z-index: 99999;
            }
            #fullPage img{
                display: block;
                width: 100%;
            }
            #canvas{
                width: 100%;
                height: 100%;
                background: none;
                display: block;
            }
        </style>

<div id="productMainImage" >
<img id="img" src="img/t1.png">

</div>


<div id="fullPage" style="display: none;">
            <canvas id="canvas"></canvas>
        </div>

<script>


function ImgInfo(params){
    this.pageW=params.pageW;
    this.pageH=params.pageH;
    this.pageScale=this.pageH/this.pageW;
}
ImgInfo.prototype={
    constructor:ImgInfo,
    reset:function(el){   //重置选中的图片,获取该图片以及它的宽高
        this.img=el;
        var boundClient=this.img.getBoundingClientRect();
        this.scale=boundClient.height/boundClient.width;
        this.ifFullByHeight=this.scale>this.pageScale;    //true:高度铺满屏幕   false:宽度铺满屏幕
        this.ifFullByHeight ? this.setHeight(this.pageH) : this.setWidth(this.pageW);    
        this.startAnitScale=0.2;
    },
    setWidth:function(w){   //缩放时候设置宽度
        this.w=w;
        this.h=this.w*this.scale;
        this.x=(this.pageW-this.w)/2;
        this.y=(this.pageH-this.h)/2;
    },
    setHeight:function(w){   //缩放时候设置宽度
        this.h=this.pageH;
        this.w=this.h/this.scale;
        this.y=0;
        this.x=(this.pageW-this.w)/2;
    },
    endScale:function(){
        if(this.w>this.pageW||this.h>this.pageH){
            return;
        }
        this.ifFullByHeight ? this.setHeight(this.pageH) : this.setWidth(this.pageW);
    },

    moveX:function(distX){
        //X轴方向的移动
        if(this.x>0 || (this.x+this.w)<this.pageW){   //超出屏幕时候弹性回收
            this.x+=distX/5;
        }
        else{
            this.x+=distX;
        }
    },
    moveY:function(distY){
        //Y轴方向的移动
        if(this.h<=this.pageH){
            return;
        }
        if((this.h>this.pageH && this.y>0) || (this.h>this.pageH && (this.y+this.h)<this.pageH)){
            this.y+=distY/5;
        }
        else{
            this.y+=distY;
        }
    },
    move:function(distX,distY){
        this.moveX(distX);
        this.moveY(distY);
    },
    endMove:function(){
        //手指松开的时候,X轴回弹
        if(this.x>0){
            this.x=this.ifFullByHeight&&this.w<this.pageW ? (this.pageW-this.w)/2 : 0;
        }
        else if((this.x+this.w)<this.pageW){
            this.x=this.ifFullByHeight&&this.w<this.pageW ? (this.pageW-this.w)/2 :  (this.pageW-this.w);
        }
        //手指松开的时候,Y轴回弹
        if(this.h>this.pageH && this.y>0){
            this.y=0;
        }
        else if(this.h>this.pageH && (this.y+this.h)<this.pageH){
            this.y=this.pageH-this.h;
        }
    },
    startAnit:function(ctx){   //点击图片放大的动画
        var _this=this;
        this.startAnitScale+=0.05;
        this.startAnitDraw(ctx);
        if(this.startAnitScale>=1){
            this.startAnitScale=1;
            this.startAnitDraw(ctx);
            this.startAnitScale=0.2;
            return;
        }
        requestAnimationFrame(function(){
            _this.startAnit(ctx);
        })
    },
    startAnitDraw:function(ctx){
        ctx.clearRect(0,0,this.pageW,this.pageH);
        ctx.save();
        var w=this.w*this.startAnitScale;
        var h=this.h*this.startAnitScale;
        ctx.translate((this.pageW-w)/2,(this.pageH-h)/2);
        ctx.beginPath();
        ctx.drawImage(this.img,0,0,w,h);
        ctx.closePath();
        ctx.restore();
    },
    draw:function(ctx){
        ctx.clearRect(0,0,this.pageW,this.pageH);
        ctx.save();
        ctx.beginPath();
        ctx.drawImage(this.img,this.x,this.y,this.w,this.h);
        ctx.closePath();
        ctx.restore();
    }
}



function WxScale(params){
    this.moveData={   //单指移动数据
        ifStart:false,    //是否开始移动
        startX:1,   //手指开始接触的x坐标
        startY:1,   //手指开始接触的y坐标
    };
    this.scaleData={   //双指缩放数据
        ifStart:false,    //是否开始移动
        startDist:1,     //手机开始接触时双指的距离,用来计算缩放比例
    };
    this.init(params);
    this.bindEvent();
}
WxScale.prototype={
    constructor:WxScale,
    init:function(params){
        this.fullPage=params.fullPage;
        this.canvas=params.canvas;
        this.fullPage.style.display="block";  //如果不先显示出fullpage那么会获取不到fullpage的宽高
        var clientRect=this.canvas.getBoundingClientRect();
        this.w=this.canvas.width=clientRect.width;
        this.h=this.canvas.height=clientRect.height;
        this.ctx=canvas.getContext("2d");
        this.img=new ImgInfo({
            pageW:this.w,
            pageH:this.h
        });
        this.fullPage.style.display="none"; 
    },
    start:function(el){
        this.fullPage.style.display="block";
        this.img.reset(el);
        this.img.startAnit(this.ctx);
    },
    bindEvent:function(){
        var _this=this;
        this.fullPage.addEventListener("touchstart",function(e){
            _this.touchstart(e);
        },false)
        this.fullPage.addEventListener("touchmove",function(e){
            _this.touchmove(e);
        },false)
        this.fullPage.addEventListener("touchend",function(e){
            _this.touchend(e);
        },false)
        this.fullPage.addEventListener("click",function(){
            this.style.display="none";
        },false)
    },
    touchstart:function(e){
        if(e.touches.length==1){   //单指移动
            this.moveData.ifStart=true;
            this.moveData.startX=e.touches[0].pageX;
            this.moveData.startY=e.touches[0].pageY;
        }
        else if(e.touches.length>=2){   //双指缩放
            this.scaleData.ifStart=true;
            this.scaleData.startDist=this.getDistance(e.touches[0],e.touches[1]);
            this.imgBaseWidth=this.img.w;
        }
    },
    touchmove:function(e){
        e.preventDefault();
        if(this.moveData.ifStart&&e.touches.length==1){   //单指移动
            var distX=e.touches[0].pageX-this.moveData.startX;
            var distY=e.touches[0].pageY-this.moveData.startY;
            this.moveData.startX=e.touches[0].pageX;
            this.moveData.startY=e.touches[0].pageY;
            this.img.move(distX,distY);
        }
        else if(this.scaleData.ifStart&&e.touches.length>=2){   //双指缩放
            var moveDist=this.getDistance(e.touches[0],e.touches[1]);
            var scale=(moveDist/this.scaleData.startDist).toFixed(2); //得到缩放比例
            this.img.setWidth(this.imgBaseWidth*scale);
        }
        this.img.draw(this.ctx);
    },
    touchend:function(e){
        if(this.scaleData.ifStart){  //双指缩放
            this.scaleData.ifStart=false;
            this.moveData.ifStart=false;
            this.img.endScale();
            this.img.draw(this.ctx);
        }
        else if(this.moveData.ifStart){  //单指移动
            this.moveData.ifStart=false;
            this.img.endMove();
            this.img.draw(this.ctx);
        }
        
    },
    getDistance:function(p1, p2){
        var x=p2.pageX-p1.pageX,
            y=p2.pageY-p1.pageY;
        return Math.sqrt(x*x+y*y);
    }
}
</script>

<script type="text/javascript">
            //使用方法
            var wxScale=new WxScale({
                fullPage:document.querySelector("#fullPage"),
                canvas:document.querySelector("#canvas")
            });
            
            var productMainImage=document.querySelectorAll("#productMainImage img");
            for(var i=0; i<productMainImage.length; i++){
                productMainImage[i].onclick=function(e){
                    wxScale.start(this);   //这里的this指向需要放大的这张图片
                }
            }


        </script>


演示地址:https://demo.demohuo.top/jquery/46/4694/demo/
当点开图片全图时如果移动端自动旋转屏幕,这时图片会被拉伸。
能不能通过这个函数重新加载或者计算高度/宽度。
$(window).on('orientationchange', function() {

});

具体怎么写呢。谢谢!
搜索更多相关主题的帖子: this var function img canvas 
2019-10-18 23:59
qq249956453
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2019-10-18
收藏
得分:0 
图片附件: 游客没有浏览图片的权限,请 登录注册
图片附件: 游客没有浏览图片的权限,请 登录注册
2019-10-18 23:59
qq249956453
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2019-10-18
收藏
得分:0 
各路神仙,来帮忙呀
2019-10-19 22:34
快速回复:手机端屏幕旋转后全图被拉伸怎么处理
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.032448 second(s), 10 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved