NodeJS は画像テキスト分割を実現します

NodeJS は画像テキスト分割を実現します

この記事では、画像テキストセグメンテーションを実装するためのNodeJSの具体的なコードを参考までに紹介します。具体的な内容は次のとおりです。

var fs = require('fs');
var jpeg = require('jpeg-js')
 
 
関数 getSumRGB(データ, i)
{
 var cr = データ.データ[i+0]
 var cg = データ.データ[i+1]
 var cb = データ.データ[i+2]
 var srgb = (cr+cg+cb)
 srgbを返す
}
 
関数 getTopRGB(データ, i)
{
 var topIndex = (データ幅 * 4 * -1)
 i = i + トップインデックス;
 var cr = データ.データ[i+0]
 var cg = データ.データ[i+1]
 var cb = データ.データ[i+2]
 
 [cr,cg,cb]を返す
}
 
関数 getHeightRGB(データ, i, haveRGB)
{
 var 幅 = データ.幅
 var 高さ = data.height
 var len = 幅 * 高さ * 4
 var 持っている数 = 0
 
 (i=i;i<len;i+=width*4) の場合
 {
  getSumRGB(データ、i) == haveRGBの場合
  {
   数値++を持つ
  }
 }
 
 haveNumを返す
}
 
関数 ClearBackGround(データ)
{ 
 var 幅 = データ.幅
 var 高さ = data.height
 var len = 幅 * 高さ * 4
 変数 i, tmp
 (i=0;i<len;i+=4) の場合 
 {
  tmp = getSumRGB(データ、i)
  tmp > 120*3の場合{
   データ.データ[i+0]=255
   データ.データ[i+1]=255
   データ.データ[i+2]=255
  }
 }
 
 (i=0;i<len;i+=4) の場合
 {
  tmp = getSumRGB(データ、i)
  tmp <= 32*3の場合{
   tmp = getTopRGB(データ、i)
   データ.data[i+0]=tmp[0]
   データ.データ[i+1]=tmp[1]
   データ.データ[i+2]=tmp[2]
  }
 }
 
 (i=0;i<len;i+=4) の場合
 {
  tmp = getSumRGB(データ、i)
  tmp != 255*3 の場合
   データ.データ[i+0]=0
   データ.データ[i+1]=0
   データ.データ[i+2]=0
  }
 }
 
 var 最大幅 = 幅 * 4
 var 引数リスト = []
 引数リスト[0]=[]
 引数リスト[1]=[]
 引数リスト[2]=[]
 引数リスト[3]=[]
 配列数 = 0
 ブロック = 0
 
 (i=0;i<最大幅;i+=4)の場合
 {
  tmp = getHeightRGB(データ, i, 0)
  tmp==0の場合{
   if(ブロック != 0) {
    arrlist[arrnum] = [ブロック/4,i/4]
    ブロック=0
    arnum++ 引数
   }
  } そうでない場合(tmp >0) {
   if(ブロック == 0) {
    ブロック = i
   }
  }
 }
 
 console.log(arrlist)
 
 データを返す
}
 
 
var picname = "tmp.jpg"
var 新しい画像名 = "000.jpg"
var jpegData = fs.readFileSync(picname)
var rawImageData = jpeg.decode(jpegData, {useTArray: true})
rawImageData = ClearBackGround(rawImageData)
var jpegImageData = jpeg.encode(rawImageData,100)
fs.writeFileSync(新しい画像名、jpegImageData.data)

JS で画像の切り取りを実装する方法を紹介します。

//画像の切り取り var ImgCropper = Class.create();
ImgCropper.プロトタイプ = {
  //コンテナオブジェクト、コントロールレイヤー、イメージアドレス初期化: function(container, handle, url, options) {
    this._Container = $(container);//コンテナ オブジェクトthis._layHandle = $(handle);//コントロール レイヤーthis.Url = url;//画像アドレスthis._layBase = this._Container.appendChild(document.createElement("img"));//下部レイヤーthis._layCropper = this._Container.appendChild(document.createElement("img"));//カット レイヤーthis._layCropper.onload = Bind(this, this.SetPos);
    //サイズを設定するために使用します this._tempImg = document.createElement("img");
    this._tempImg.onload = Bind(this, this.SetSize);
    
    オプションを設定します。
    
    this.Opacity = Math.round(this.options.Opacity);
    this.Color = this.options.Color;
    this.Scale = !!this.options.Scale;
    this.Ratio = Math.max(this.options.Ratio, 0);
    this.Width = Math.round(this.options.Width);
    this.Height = Math.round(this.options.Height);
    
    //プレビューオブジェクトを設定する var oPreview = $(this.options.Preview); //プレビューオブジェクト if (oPreview) {
        oPreview.style.position = "相対的";
        oPreview.style.overflow = "非表示";
        this.viewWidth = Math.round(this.options.viewWidth);
        this.viewHeight = Math.round(this.options.viewHeight);
        // プレビュー画像オブジェクト this._view = oPreview.appendChild(document.createElement("img"));
        this._view.style.position = "絶対";
        this._view.onload = Bind(this, this.SetPreview);
    }
    //ドラッグ アンド ドロップを設定します。 this._drag = new Drag(this._layHandle, { Limit: true, onMove: Bind(this, this.SetPos), Transparent: true });
    //ズームを設定 this.Resize = !!this.options.Resize;
    if(this.Resize){
        var op = this.options、_resize = new Resize(this._layHandle、{Max: true、onResize: Bind(this、this.SetPos) });
        //ズームトリガーオブジェクトを設定します op.RightDown && (_resize.Set(op.RightDown, "right-down"));
        op.LeftDown && (_resize.Set(op.LeftDown, "左下"));
        op.RightUp && (_resize.Set(op.RightUp, "右上"));
        op.LeftUp && (_resize.Set(op.LeftUp, "左上"));
        op.Right && (_resize.Set(op.Right, "right"));
        op.Left && (_resize.Set(op.Left, "left"));
        op.Down && (_resize.Set(op.Down, "down"));
        op.Up && (_resize.Set(op.Up, "up"));
        // 最小範囲制限 this.Min = !!this.options.Min;
        this.minWidth = Math.round(this.options.minWidth);
        this.minHeight = Math.round(this.options.minHeight);
        //スケーリング オブジェクトを設定します this._resize = _resize;
    }
    //スタイルを設定します this._Container.style.position = "relative";
    this._Container.style.overflow = "非表示";
    this._layHandle.style.zIndex = 200;
    this._layCropper.style.zIndex = 100;
    this._layBase.style.position = this._layCropper.style.position = "絶対";
    this._layBase.style.top = this._layBase.style.left = this._layCropper.style.top = this._layCropper.style.left = 0; //配置 //初期化設定 this.Init();
  },
  //デフォルトのプロパティを設定する SetOptions: function(options) {
    this.options ={//デフォルト値不透明度: 50、//透明度 (0 ~ 100)
        Color: "", //背景色Width: 0, //画像の高さHeight: 0, //画像の高さ//スケーリング トリガー objectResize: false, //スケーリングを設定するかどうかRight: "", //右スケーリング objectLeft: "", //左スケーリング objectUp: "", //上部スケーリング objectDown: "", //下部スケーリング objectRightDown: "", //右下スケーリング objectLeftDown: "", //左下スケーリング objectRightUp: "", //右上スケーリング objectLeftUp: "", //左上スケーリング objectMin: false, //幅と高さの最小制限を設定するかどうか (以下の min パラメーターは true の場合に便利です)
        minWidth: 50, // 最小幅 minHeight: 50, // 最小高さ Scale: false, // 比例して拡大縮小するかどうか Ratio: 0, // 拡大縮小率 (幅/高さ)
        //プレビューオブジェクト設定 Preview: "", //プレビューオブジェクト viewWidth: 0, //プレビューの幅 viewHeight: 0 //プレビューの高さ };
    Extend(this.options、オプション || {});
  },
  // オブジェクトを初期化する Init: function() {
    //背景色を設定します this.Color && (this._Container.style.backgroundColor = this.Color);
    //画像を設定します this._tempImg.src = this._layBase.src = this._layCropper.src = this.Url;
    //透明に設定する if(isIE){
        this._layBase.style.filter = "alpha(不透明度:" + this.Opacity + ")";
    } それ以外 {
        this._layBase.style.opacity = this.Opacity / 100;
    }
    //プレビュー オブジェクトを設定します this._view && (this._view.src = this.Url);
    //ズームを設定する if (this.Resize) {
        (this._resize){で
            スケール = this.Scale; 比率 = this.Ratio; 最小 = this.Min; 最小幅 = this.minWidth; 最小高さ = this.minHeight;
        }
    }
  },
  //カットスタイルを設定する SetPos: function() {
    //IE6 レンダリング バグ
    if (isIE6) { with (this._layHandle.style) { zoom = .9; zoom = 1; }; };
    //位置パラメータを取得します var p = this.GetPos();
    //ドラッグ アンド ドロップ オブジェクトのパラメータに従ってカットします。this._layCropper.style.clip = "rect(" + p.Top + "px " + (p.Left + p.Width) + "px " + (p.Top + p.Height) + "px " + p.Left + "px)";
    //プレビューを設定します this.SetPreview();
  },
  //プレビュー効果を設定する SetPreview: function() {
    if(this._view){
        //プレビュー表示の幅と高さ var p = this.GetPos(), s = this.GetSize(p.Width, p.Height, this.viewWidth, this.viewHeight), scale = s.Height / p.Height;
        //パラメータを比例的に設定します var pHeight = this._layBase.height * scale, pWidth = this._layBase.width * scale, pTop = p.Top * scale, pLeft = p.Left * scale;
        //プレビューオブジェクトを(this._view.style){で設定します
            //スタイルを設定します。幅 = pWidth + "px"; 高さ = pHeight + "px"; 上 = - pTop + "px "; 左 = - pLeft + "px";
            //プレビュー画像の切り取り clip = "rect(" + pTop + "px " + (pLeft + s.Width) + "px " + (pTop + s.Height) + "px " + pLeft + "px)";
        }
    }
  },
  //画像サイズを設定する SetSize: function() {
    var s = this.GetSize(this._tempImg.width、this._tempImg.height、this.Width、this.Height);
    // ベースマップとカッティングマップを設定します。this._layBase.style.width = this._layCropper.style.width = s.Width + "px";
    this._layBase.style.height = this._layCropper.style.height = s.Height + "px";
    //ドラッグアンドドロップ範囲を設定します。this._drag.mxRight = s.Width; this._drag.mxBottom = s.Height;
    //ズーム範囲を設定します if (this.Resize) { this._resize.mxRight = s.Width; this._resize.mxBottom = s.Height; }
  },
  //現在のスタイルを取得する GetPos: function() {
    (this._layHandle) で{
        戻り値: 上: offsetTop、左: offsetLeft、幅: offsetWidth、高さ: offsetHeight }
    }
  },
  //サイズを取得する GetSize: function(nowWidth, nowHeight, fixWidth, fixHeight) {
    var iWidth = nowWidth、iHeight = nowHeight、scale = iWidth / iHeight;
    //比率に応じて設定します if (fixHeight) { iWidth = (iHeight = fixHeight) * scale; }
    if(fixWidth && (!fixHeight || iWidth > fixWidth)){ iHeight = (iWidth = fixWidth) / スケール; }
    //サイズオブジェクトを返す return { 幅: iWidth, 高さ: iHeight }
  }
}

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • jsを使用して大きなファイルを分割してアップロードする

<<:  Centos7 での MySQL 5.7.20 のインストールと設定に関する詳細なチュートリアル

>>:  SSH経由でローカルLinux仮想マシンに接続するプロセスを記録する

推薦する

純粋なCSS3で実装されたネオンライト効果

達成される効果は次のとおりです。 マウスがボタン内に移動すると、ネオンライトのような効果が生成され、...

IIS 7.5では、HTMLはSHTMLのようなinclude関数(モジュールマッピングの追加)をサポートします。

最初はたくさんのエラーを見つけましたが、実際には非常に簡単です。shtm の元の設定を参照するだけで...

HTMLの行間設定方法と問題点

<p></p> の行間隔を設定するには、style="line-h...

Ubuntu環境にAnaconda3をインストールするための完全な手順

目次Anaconda の紹介1. ダウンロード1.1 インストールパッケージを保存するフォルダを作成...

vue3+ts+EsLint+Prettier 標準コード実装

目次使用EsLintの使用プロフィールを追加するPrettierの使用huskyとlint-stag...

Mysql 5.7.19 無料インストール バージョンで遭遇した落とし穴 (コレクション)

1. 公式ウェブサイトから 64 ビットの zip ファイルをダウンロードします。 2. インスト...

MySQL 8.0 の新機能 - チェック制約の紹介

目次序文チェック制約作成、削除、表示制限要約する序文MySQL 8.0 では、チェック制約という非常...

MySQLテーブルにタイムスタンプを追加するいくつかの方法

シナリオ:テーブル内のデータは、同期ツールを使用して他のデータベースと同期する必要があり、増分同期に...

Linuxのテキスト処理コマンドsortの詳細な説明

テキストファイルの内容を並べ替える使用方法: ソート + オプション + ファイル名 (複数のファイ...

Nginx 構成の実装 https

目次1: https証明書を準備する2: nginx sslモジュールを準備する3: SSL証明書を...

IEウェブページのポップアップウィンドウの共通パラメータは自分で設定できます

ポップアップは、現在のウィンドウにメニューツールバーがあるかどうかとは関係ありません。ページにスクリ...

Vueは画像切り替え効果を実現

この記事の例では、画像切り替え効果を実現するためのVueの具体的なコードを参考までに共有しています。...

K8Sの5つのコントローラーの紹介と使用

目次k8sのコントローラータイプポッドとコントローラの関係デプロイメント(ステートレスアプリケーショ...

超シンプルな QPS 統計手法 (推奨)

過去 N 秒間の QPS 値の統計 (1 秒あたりの選択、挿入などを含む) mysql> se...

Vueカスタムテーブル列実装プロセス記録

目次序文レンダリングsetTable コンポーネント使用結論序文フォームを使用して PC 側のプロジ...