ホームページ > ウェブフロントエンド > H5 チュートリアル > カメラを呼び出して写真を撮影し、HTML5 で画像を圧縮する方法の詳細な例

カメラを呼び出して写真を撮影し、HTML5 で画像を圧縮する方法の詳細な例

黄舟
リリース: 2017-07-24 15:08:38
オリジナル
2730 人が閲覧しました

この記事では、H5 がカメラを呼び出して写真を撮影し、圧縮するサンプル コードを主に紹介します。編集者はこれが非常に優れていると考えたので、参考として共有します。エディターをフォローして見てみましょう

ドキュメントを整理し、カメラを呼び出して写真を撮って圧縮するサンプル コードを検索し、共有するために整理して少し合理化します。

背景

私は最近h5ページを作成しました。主な機能は、カメラを呼び出して写真を撮るか、アルバムから写真を選択し、写真をbase64に圧縮してからバックエンドサーバーにアップロードすることです。認識結果を返します。

フロントエンドの主な機能ポイントは次のとおりです:

  1. H5でカメラを呼び出す方法

  2. 写真を圧縮する方法

  3. 写真をbase64に変換する

H5でカメラを呼び出す/アルバム

カメラを呼び出す最も簡単な方法 入力ファイルの [カメラ] 属性を使用するだけです:


<input type="file" capture=camera accept="image/*">//相机
<input type="file" accept="image/*">//相册
ログイン後にコピー

このメソッドの互換性にはまだ問題がありますが、カメラは iPhone 上で正常に開くことができます。 Android スマートフォンをクリックすると、カメラ、ギャラリー、ファイル マネージャーなどが開きます。選択が混在しています。インターネットでいろいろ調べましたが、良い解決策が見つからず、書き続けるしかありません。 。 。

画像圧縮

画像圧縮が使用されますFileReader<canvas>

FileReader オブジェクトを使用すると、Web アプリケーションは、File または Blob オブジェクトを使用して、読み取るファイルまたはデータを指定し、コンピューターに保存されているファイルの内容を非同期的に読み取ることができます。

<canvas> は、スクリプトを使用してグラフィックスや簡単なアニメーションを描画できる HTML 要素です。

画像圧縮では、画像の解像度と品質を圧縮する必要があります。解像度圧縮の場合、画像の最大側を 800 に設定し、もう一方の側は画像の元の比率に従って拡大縮小することもできます。画像の拡大率。


var MAX_WH=800;
var image=new Image();
image.onload=function () {
  if(image.height > MAX_WH) {
    // 宽度等比例缩放 *= 
    image.width *= MAX_WH/ image.height;
    image.height = MAX_WH;
  }
  if(image.width > MAX_WH) {
    // 宽度等比例缩放 *= 
    image.height *= MAX_WH/ image.width;
    image.width = MAX_WH;
  }
}
image.src=dataURL;//dataURL通过FileReader获取
ログイン後にコピー

次に、圧縮画像の品質ですが、ここでの圧縮は 80% に設定されており、設定が小さすぎると画像が歪みます。 <canvas> タグを動的に作成し、画像を圧縮します:


var quality=80;
var cvs = document.createElement(&#39;canvas&#39;);
cvs.width = image.width;
cvs.heigh = image.height;
var context=cvs.getContext("2d");
context.drawImage(image, 0, 0,image.width, image.height);
dataURL = cvs.toDataURL(&#39;image/jpeg&#39;, quality/100);
ログイン後にコピー

それからサーバーにアップロードし、サーバーの結果を表示します。 。 。 iOS スマートフォンで写真を撮影すると、圧縮された後に写真が不可解に回転します。問題の解決を続けます。

IOS画像回転の解決策

まずexif.jsを引用し、EXIF.getDataとEXIF.getTagを通じて写真の方向情報を取得します。


//file通过input标签获取
EXIF.getData(file,function(){
  orientation=EXIF.getTag(file,&#39;Orientation&#39;);
});
ログイン後にコピー

iPhoneでの写真撮影に対応する各向きの値の意味は次のとおりです:

orientationDescription
3iPhoneの横画面撮影、この時点ではホームボタンは左側にあります 側面では、元の位置に対して写真が 180 度回転されます
6 このとき、ホームボタンは下にあります(通常の押し方向) Phone)、写真は元の位置に対して反時計回りに 90 度回転できます
8 このとき、iPhone はポートレートモードで撮影されており、写真は 90 度回転します。元の位置に対して時計回りに度

画像の方向情報を取得したら、取得した値に基づいて対応する回転操作を実行します。


switch (orientation) {
  case 6:
  case 8:
    cvs.width = height;
    cvs.height = width;
    break;
}
var context=cvs.getContext("2d");
switch(orientation){
  //iphone横屏拍摄,此时home键在左侧
  case 3:
  // 180度向左旋转
  context.translate(width, height);
  context.rotate(Math.PI);
  break;
  //iphone竖屏拍摄,此时home键在下方(正常拿手机的方向)
  case 6:
  context.rotate(0.5 * Math.PI);
  context.translate(0, -height);
  break;
  //iphone竖屏拍摄,此时home键在上方
  case 8:
  // 逆时针旋转90度
  context.rotate(-0.5 * Math.PI);
  context.translate(-width, 0);
  break;
}
ログイン後にコピー

その後、写真をアップロードしたところ、IOSでは写真が正常であることがわかりました。

完全なコードを以下に示します:


$(&#39;input[type=file]&#39;).change(function(e) {
  var file = this.files[0];
  var mime_type=file.type;
  var orientation=0;
  if (file && /^image\//i.test(file.type)) {
    EXIF.getData(file,function(){
      orientation=EXIF.getTag(file,&#39;Orientation&#39;);
    });

    var reader = new FileReader();
    reader.onloadend = function () {
      var width,height;
      var MAX_WH=800;
      var image=new Image();
      image.onload=function () {
        if(image.height > MAX_WH) {
          // 宽度等比例缩放 *= 
          image.width *= MAX_WH / image.height;
          image.height = MAX_WH;
        }
        if(image.width > MAX_WH) {
          // 宽度等比例缩放 *= 
          image.height *= MAX_WH / image.width;
          image.width = MAX_WH;
        }
        //压缩
        var quality=80;
        var cvs = document.createElement(&#39;canvas&#39;);
        cvs.width = width = image.width;
        cvs.height =height = image.height;

        switch (orientation) {
          case 6:
          case 8:
            cvs.width = height;
            cvs.height = width;
            break;
        }

        var context=cvs.getContext("2d");

        //解决ios图片旋转问题 
        switch(orientation){
          //iphone横屏拍摄,此时home键在左侧
          case 3:
          // 180度向左旋转
          context.translate(width, height);
          context.rotate(Math.PI);
          break;
          //iphone竖屏拍摄,此时home键在下方(正常拿手机的方向)
          case 6:
          context.rotate(0.5 * Math.PI);
          context.translate(0, -height);
          break;
          //iphone竖屏拍摄,此时home键在上方
          case 8:
          // 逆时针旋转90度
          context.rotate(-0.5 * Math.PI);
          context.translate(-width, 0);
          break;
        }
        context.drawImage(image, 0, 0,image.width, image.height);
        dataURL = cvs.toDataURL(&#39;image/jpeg&#39;, quality/100);
        //获取识别结果
        ...
      }
      image.src=dataURL;
    };
    reader.readAsDataURL(file);
  }else{
    alert("只能识别图片!")
  }
});
ログイン後にコピー

以上がカメラを呼び出して写真を撮影し、HTML5 で画像を圧縮する方法の詳細な例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート