検索
ホームページウェブフロントエンドjsチュートリアルSharp.js: 史上最高の Node.js 画像フレームワーク

Sharp.js: The Best Node.js Image Framework Ever

Node.js 環境で Sharp モジュールを使用して画像を効率的に処理する方法

この記事では、Node.js 環境で Sharp モジュールを使用して画像を効率的に処理する方法を紹介します。実際のコード例を通じて、大きな画像ファイルをネットワーク送信に適した JPEG、PNG、WebP、AVIF 形式に変換する方法を示します。同時に、libvips ライブラリの強力な機能を利用して画像処理の効率を向上させます。

1. シャープモジュールの使用を開始する

1.1 シャープモジュールの概要

今日の視覚情報の爆発的な時代において、画像処理技術は非常に重要になっています。シャープは、Node.js環境をベースとした高性能画像処理モジュールとして、その優れた性能と使いやすさで開発者コミュニティから高い評価を得ています。一般的な JPEG および PNG 形式の画像の処理をサポートするだけでなく、技術トレンドにも対応し、WebP や AVIF などの新しい画像形式のサポートも提供します。これは、モバイル デバイスでもデスクトップ プラットフォームでも、シャープが高品質を維持しながら画像の読み込み速度を向上させ、ユーザー エクスペリエンスを大幅に向上できることを意味します。

1.2 シャープとlibvipsライブラリの関係

このような効率的な画像処理を実現するシャープの能力の鍵は、libvips ライブラリのアプリケーションにあります。 Libvips は、C で書かれた高性能画像処理ライブラリです。これは、サイズ変更、トリミング、色空間変換を含む (ただしこれらに限定されない) さまざまな画像操作をサポートします。 libvips にバインドすることで、Sharp は複雑な画像処理タスクを簡素化します。さらに重要なことは、libvips はストリーミング処理方式を採用しているため、非常に大きな画像を操作する場合でも、過剰なメモリ リソースを消費せず、システムの安定性と応答速度を確保できます。

1.3 シャープモジュールの取り付け方法

シャープのインストールプロセスは比較的簡単です。まず、Node.js が開発環境に正しくインストールされていることを確認する必要があります。次に、コマンドライン ツールを開き、次のコマンドを入力してインストールを開始します。

npm install sharp

インストールが完了したら、Sharp をプロジェクトに導入し、その強力な機能の探索を開始できます。最適なパフォーマンスを得るには、インストール中に Sharp が libvips をコンパイルできるようにすることをお勧めします。このプロセスはオペレーティング システムによって異なる場合があるため、対応する構成については公式ドキュメントを参照してください。

1.4 シャープの基本的な使用例

読者が画像処理に Sharp を使用する方法をよりよく理解できるように、元の画像を読み取り、ネットワーク送信に適した形式に変換する方法を示す簡単なコード例を以下に示します。

npm install sharp

このコードは、最初に Sharp モジュールをインポートし、次に処理フローを定義します。指定されたパスから元の画像 input.jpg を読み取り、幅を 800 ピクセルに変更し、WebP 形式に変換し、最後に出力として保存します。ウェブ。これにより、画像処理手順が簡素化されるだけでなく、作業効率も効果的に向上します。

2. 画像フォーマット変換と処理技術

2.1 JPEG、PNG、WebP 形式の変換

今日のますますリッチになるデジタル メディアでは、Web ページの読み込み速度とユーザー エクスペリエンスを最適化するために画像形式の選択が重要です。強力な変換機能を備えた Sharp モジュールを使用すると、開発者は JPEG、PNG、WebP を簡単に切り替えることができます。 JPEG 形式は、圧縮率が優れているため、インターネットでの写真共有に広く使用されています。 PNG は可逆圧縮特性があるため、背景が透明な画像には理想的な選択肢です。 WebP は新しい形式であり、前の 2 つの利点を継承するだけでなく、画質と圧縮効率もさらに向上します。たとえば、Sharp を使用して JPEG 形式の写真を WebP 形式に変換すると、画質を犠牲にすることなくファイル サイズを大幅に削減できます。これは、読み込み速度の高速化とデータ トラフィック消費量の削減を意味するため、モバイル デバイス ユーザーにとって特に重要です。具体的な操作例は次のとおりです:

const sharp = require('sharp'); 
// Read the local image file
sharp('input.jpg')
     .resize(800) 
     .toFormat('webp') 
     .toFile('output.webp', (err, info) => {
            if (err) throw err;
            console.log(info); 
        });

上記のコードにより、image.jpg という名前の画像が WebP 形式に正常に変換され、image.webp として保存されます。開発者は、さまざまなシナリオのニーズに合わせてパラメーターを調整することで、出力結果を最適化できます。

2.2 AVIF形式変換のメリット

テクノロジーの進歩に伴い、AVIF 画像形式は徐々に一般の注目を集めるようになりました。従来の JPEG や WebP と比較して、AVIF は高い圧縮率と優れた視覚効果を提供します。高効率ビデオコーディング (HEVC) などの最新のコーディング技術を採用しており、同じ画質を維持しながらファイルサイズを半分以上削減できます。これは、AVIF 形式の画像を使用すると、ユーザー エクスペリエンスを低下させることなく帯域幅の占有を大幅に削減できることを意味します。 Sharp モジュールは時代に対応し、AVIF 形式の生成と処理をサポートしているため、開発者は既存の画像をこの高度な形式に簡単に変換できます。簡単な変換例を次に示します:

npm install sharp

このコードは、PNG 形式の画像を品質設定 80% の AVIF 形式に変換し、最終的に最適化された.avif として保存する方法を示しています。このようにして、画像の読み込みパフォーマンスが向上するだけでなく、ユーザーにスムーズなブラウジング エクスペリエンスを提供します。

2.3 画像のサイズ変更とトリミング

実際のアプリケーションでは、さまざまな表示要件を満たすために画像のサイズ変更やトリミングが必要になることがよくあります。シャープモジュールには豊富な機能が内蔵されており、これらの操作が非常に簡単です。画像を縮小してクイック プレビューする場合でも、特定の領域をトリミングして重要なポイントを強調表示する場合でも、わずか数行の簡単なコードで実現できます。たとえば、幅が特大の画像のサイズを標準幅の 800 ピクセルに変更する場合は、次のコードを使用できます。

const sharp = require('sharp'); 
// Read the local image file
sharp('input.jpg')
     .resize(800) 
     .toFormat('webp') 
     .toFile('output.webp', (err, info) => {
            if (err) throw err;
            console.log(info); 
        });

さらに、複雑なシナリオで正確にトリミングするために、シャープは柔軟なソリューションも提供します。たとえば、風景写真の中央部分をサムネイルとして抽出したい場合は、パラメータを追加するだけです:

sharp('image.jpg')
    .toFormat('webp')
    .toFile('image.webp', (err, info) => {
        if (err) throw err;
        console.log(`Converted to WebP: ${info.size} bytes`);
});

これらの実用的な機能を通じて、開発者はさまざまな画像処理の課題に簡単に対処し、ユーザーに表示される各画像が適切であることを確認できます。

2.4 画像の回転と反転

基本的なサイズ変更とフォーマット変換に加えて、シャープは画像の回転と反転の操作もサポートしています。これは、撮影角度のエラーを修正したり、特殊な視覚効果を作成したりする場合に非常に役立ちます。たとえば、画像を時計回りに 90 度回転する必要がある場合は、次のコードを使用できます:

sharp('original.png')
    .toFormat('avif', {
        quality: 80
    }).toFile('optimized.avif', (err, info) => {
        if (err) throw err;
        console.log(`AVIF conversion complete: ${info.size} bytes`);
});

同様に、画像を水平方向に反転したい場合は、flip() メソッドを呼び出すだけです。

sharp('wide-image.jpg')
    .resize(800, null)
    .toFile('resized-image.jpg', (err, info) => {
        if (err) throw err;
        console.log(`Resized image: ${info.width}x${info.height}`);
});

これらの機能は、画像処理の柔軟性を高めるだけでなく、クリエイティブなデザインに無限の可能性をもたらします。プロのカメラマンもアマチュアも、シャープの強力な機能を使って満足のいく作品を簡単に作成できます。

3. 高性能画像処理の実践

3.1 シャープモジュールのパフォーマンス上の利点

画像処理の分野では、パフォーマンスが最も重要です。 Sharp モジュールは、主にその優れたパフォーマンスにより、多くの画像処理ツールの中で際立っています。シャープはlibvipsライブラリの強力なサポートにより、大量の画像データを驚異的な速度で処理することができ、特にハイビジョンや超高精細な画像を扱う場合にその利点がより顕著になります。テストデータによると、他の一般的な JavaScript 画像処理ライブラリと比較して、Sharp は、サイズ変更、トリミング、色変換などの一般的なタスクを実行する際に数倍高速に処理できます。この効率的な処理能力により、開発者の待ち時間が大幅に短縮されるだけでなく、エンドユーザーによりスムーズなエクスペリエンスがもたらされます。さらに重要なのは、シャープの設計コンセプトは常に「軽量」を中心に展開しており、リソースが限られたサーバー環境であっても、安定した稼働状態を維持でき、大量の処理によるシステムのクラッシュや応答の低下を引き起こすことがないことを意味します。画像の数。

3.2 シャープによるバッチ処理

大量の画像をバッチ処理する必要性に直面して、シャープは並外れた能力も発揮します。開発者は、単純な API 呼び出しを通じて、数千、さらには数万の写真を一度に簡単に変換できます。たとえば、電子商取引 Web サイトやソーシャル メディア プラットフォームでは、多数のユーザーが毎日新しい写真をアップロードします。これらの写真をいかに迅速かつ効果的に最適化するかが、ユーザー エクスペリエンスを向上させる鍵となっています。シャープは包括的なソリューションを提供します。非同期処理メカニズムを通じて、複数の画像処理タスクを並行して実行できるため、全体の効率が大幅に向上します。さらに、シャープは連鎖呼び出しをサポートしているため、開発者はサイズ変更、トリミング、形式変換のステップを連続して実行するなど、複数の操作を 1 つのリクエストに連結して、高度に自動化された画像処理フローを実現できます。この柔軟性により、コード作成プロセスが簡素化されるだけでなく、画像処理がより直観的かつ効率的になります。

3.3 キャッシュとパフォーマンスの最適化

実際のアプリケーションでは、キャッシュ メカニズムを適切に使用することが、システムのパフォーマンスを向上させる重要な手段の 1 つです。 Sharp モジュールには、繰り返される処理リクエストを自動的に識別し、キャッシュから結果を直接取得できるインテリジェントなキャッシュ戦略が組み込まれており、不必要な計算オーバーヘッドを回避します。この機能は、多数の類似した画像を処理する場合に特に重要です。共通の操作の結果をメモリに事前にロードすることで、後で同じ要求が発生した場合にシャープは迅速に応答でき、画像処理速度が大幅に高速化されます。さらに、頻繁にアクセスする必要がある画像リソースについては、開発者がキャッシュ ポリシーを手動で設定して、最も頻繁に使用される画像が常にキャッシュ状態になるようにすることもでき、アクセス効率をさらに最適化できます。 libvips ライブラリの効率的なアルゴリズムと組み合わせることで、シャープは単一の画像を処理するだけでなく、画像ライブラリ全体を効率的に管理することができ、あらゆるアクセスにタイムリーに応答できるようになります。

3.4 エラー処理と例外管理

シャープのモジュールは設計上、操作プロセスの簡素化に努めておりますが、実際の使用においてはさまざまな予期せぬ事態に遭遇することは避けられません。システムの安定した動作を保証するために、シャープは、開発者が潜在的な問題を適時に検出して解決できるようにする一連のエラー処理メカニズムを組み込みました。処理中に例外が発生した場合、シャープはエラーの種類、発生場所、考えられる原因分析を含む詳細なエラー レポートを自動的に生成し、問題の迅速な特定を容易にします。同時に、カスタム エラー処理ロジックもサポートしているため、開発者は特定のアプリケーション シナリオに応じてさまざまなエラー応答戦略を設定できます。たとえば、大量の画像を処理する場合、フォーマットの問題により特定の画像の処理が失敗した場合、シャープはその画像を自動的にスキップし、後続のタスクを実行し続けることで、プロセス全体に影響を与えないようにすることができます。このようにして、システムの耐障害性が向上するだけでなく、開発者にとって柔軟性が向上し、面倒なエラーのデバッグに行き詰まることなく、コアのビジネス ロジックの開発に集中できるようになります。

4. シャープモジュールの適用事例の分析

4.1 ケース 1: 画像の圧縮とアップロード

マルチメディア コンテンツが主流となっている今日の時代では、画像の圧縮とアップロードは多くの Web サイトやアプリケーションで不可欠な部分になっています。スタートアップの電子商取引プラットフォームを例に挙げます。彼らは共通の問題に直面しています。それは、ページの読み込み速度を高めるために画質を確保しながら、ファイル サイズを可能な限り削減するにはどうすればよいでしょうか?シャープモジュールの登場は、この問題に対する完璧な解決策を提供します。シャープとの連携により、ユーザーがアップロードした画像の即時圧縮処理を実現したプラットフォームです。具体的には、新しい写真がアップロードされるたびに、システムは自動的にシャープの関連機能を呼び出し、その写真を WebP などのネットワーク送信に適した小さな形式に変換します。統計によると、シャープが処理する画像の平均ファイル サイズは約 60% 削減され、ユーザーのブラウジング エクスペリエンスが大幅に向上するだけでなく、サーバーのストレージ コストも大幅に削減されます。さらに重要なのは、これらすべてがユーザーの認識をほとんど伴わずに行われ、真にシームレスな統合が実現されるということです。

4.2 ケース 2: 動的画像処理サービス

ソーシャル メディア プラットフォームやオンライン フォト アルバム サービスなど、大量の画像のリアルタイム処理が必要な一部のアプリケーション シナリオでも、シャープは独自の利点を示しています。新しく撮影した写真をソーシャル メディアで共有すると、システムがすぐに写真を最適化し、さまざまなデバイスの画面サイズに応じて複数の解像度のバージョンを自動的に生成できることを想像してください。この背後では、シャープのモジュールが静かに動作しています。シャープをベースとした動的画像処理サービスを構築することで、開発者は写真の即時リサイズ、トリミング、フォーマット変換などの機能を簡単に実装できます。さらに重要なのは、シャープが非同期処理メカニズムをサポートしていることです。つまり、複数のタスクを並行して実行できるため、処理効率が大幅に向上します。統計によると、ピーク時には、このサービスは 1 分あたり 1,000 枚以上の写真を処理でき、ユーザーがアップロードしたコンテンツを即座に確認できるようになっています。

4.3 事例3:画像編集機能の実現

多くの画像編集アプリケーションでは、ユーザーは多くの場合、回転、反転、トリミングなど、画像に対してさまざまな編集操作を実行できることを望んでいます。 Sharp モジュールの強みは、これらの基本タスクを効率的に実行できるだけでなく、単純な API 呼び出しを通じて複雑な機能の組み合わせを実現できることです。たとえば、写真愛好家向けのモバイル アプリケーションでは、開発者はシャープを使用して写真のリアルタイム プレビューおよび編集機能を実装します。ユーザーは任意の画像を選択し、インターフェイス上のコントロール ボタンを使用して回転、反転、トリミングなどの操作を実行できます。これらすべての変更はシャープによってバックグラウンドで処理され、リアルタイムでプレビュー ウィンドウに更新されます。これにより、ユーザーは各操作による変化を直感的に確認できるようになり、編集エクスペリエンスが大幅に向上します。統計によると、アプリケーションのリリース後、ユーザーのアクティビティは 30% 近く増加し、ユーザー エクスペリエンスを向上させるシャープの大きな可能性を十分に示しています。

4.4 事例4:画像フォーマット変換APIの構築

画像フォーマットを頻繁に変換する必要があるエンタープライズレベルのアプリケーションの場合、安定した信頼性の高い API インターフェースを構築することが特に重要です。 Sharp モジュールの柔軟性により、開発者はこのようなプラットフォームを簡単に構築できます。オンライン教育会社を例に挙げます。 Web ページの読み込み速度を最適化するために、教師がアップロードしたさまざまな教材を WebP 形式に変換する必要があります。同社はシャープベースの画像フォーマット変換APIを構築することで、アップロードされたすべてのファイルの自動処理を実現している。新しいファイルがアップロードされるたびに、API はその形式を自動的に検出し、変換のためにシャープの関連機能を呼び出します。プロセス全体は完全に透過的であり、ユーザーは特定の変換の詳細を気にする必要はなく、コンテンツ自体に集中するだけで済みます。統計によると、API の開始以来、企業 Web サイトの平均読み込み速度は 25% 向上し、ユーザーの満足度も大幅に向上しました。これは技術の進歩の現れであるだけでなく、ユーザー エクスペリエンス最適化のベスト プラクティスでもあります。

5. まとめ

シャープモジュールの徹底的な調査を通じて、画像処理の分野でその優れたパフォーマンスを目撃しただけでなく、次のような一連の実用的な機能を通じて、開発効率とユーザーエクスペリエンスがどのように大幅に向上しているかを確認しました。 JPEG、PNG、WebP、AVIF 形式の変換、画像のサイズ変更とトリミング、回転と反転。統計データによると、シャープが処理する写真の平均ファイル サイズは約 60% 削減され、ピーク時にはシャープをベースにしたサービスで 1 分間に 1,000 枚以上の写真を処理できます。これらの成果は、パフォーマンス最適化におけるシャープの強い強みを反映するだけでなく、さまざまなアプリケーションシナリオに対する確かな技術サポートも提供します。新興電子商取引プラットフォームの画像圧縮とアップロードのニーズであっても、ソーシャルメディアプラットフォームの動的画像処理サービスであっても、シャープはそれらにうまく対応し、期待を上回ることができます。今後、より多くの開発者がシャープの高度な機能を使いこなすことで、シャープはより多くの分野で無限の可能性を発揮し、ビジュアルコンテンツの制作を新たな高みへと押し上げると私たちは確信しています。

Leapcell: Web ホスティング、非同期タスク、Redis のための次世代サーバーレス プラットフォーム

Sharp.js: The Best Node.js Image Framework Ever

最後に、Node.js サービスのデプロイに最適なプラットフォームである Leapcell をお勧めします。

Leapcell は、分散アプリケーション用に設計された最新のクラウド コンピューティング プラットフォームです。アイドルコストのない従量課金制モデルを採用しており、使用したリソースに対してのみお支払いいただけます。

1. 多言語サポート

  • JavaScript、Python、Go、または Rust で開発します。

2. 無制限のプロジェクトを無料でデプロイ

  • 使用料金のみお支払いください。リクエストや料金はかかりません。

3. 比類のないコスト効率

  • アイドル料金なしの従量課金制です。
  • 例: $25 は、平均応答時間 60 ミリ秒で 694 万のリクエストをサポートします。

4. 合理化された開発者エクスペリエンス

  • 直感的な UI でセットアップが簡単です。
  • 完全に自動化された CI/CD パイプラインと GitOps の統合。
  • 実用的な洞察を得るリアルタイムのメトリクスとログ。

5. 容易な拡張性と高性能

  • 自動スケーリングにより、高い同時実行性を簡単に処理できます。
  • 運用上のオーバーヘッドがゼロ - 構築だけに集中できます。

Sharp.js: The Best Node.js Image Framework Ever

ドキュメントでさらに詳しく見てみましょう!

Leapcell Twitter: https://x.com/LeapcellHQ

以上がSharp.js: 史上最高の Node.js 画像フレームワークの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
JavaScriptの文字列文字を交換しますJavaScriptの文字列文字を交換しますMar 11, 2025 am 12:07 AM

JavaScript文字列置換法とFAQの詳細な説明 この記事では、javaScriptの文字列文字を置き換える2つの方法について説明します:内部JavaScriptコードとWebページの内部HTML。 JavaScriptコード内の文字列を交換します 最も直接的な方法は、置換()メソッドを使用することです。 str = str.replace( "find"、 "置換"); この方法は、最初の一致のみを置き換えます。すべての一致を置き換えるには、正規表現を使用して、グローバルフラグGを追加します。 str = str.replace(/fi

独自のAjax Webアプリケーションを構築します独自のAjax Webアプリケーションを構築しますMar 09, 2025 am 12:11 AM

それで、あなたはここで、Ajaxと呼ばれるこのことについてすべてを学ぶ準備ができています。しかし、それは正確には何ですか? Ajaxという用語は、動的でインタラクティブなWebコンテンツを作成するために使用されるテクノロジーのゆるいグループ化を指します。 Ajaxという用語は、もともとJesse Jによって造られました

独自のJavaScriptライブラリを作成および公開するにはどうすればよいですか?独自のJavaScriptライブラリを作成および公開するにはどうすればよいですか?Mar 18, 2025 pm 03:12 PM

記事では、JavaScriptライブラリの作成、公開、および維持について説明し、計画、開発、テスト、ドキュメント、およびプロモーション戦略に焦点を当てています。

ブラウザでのパフォーマンスのためにJavaScriptコードを最適化するにはどうすればよいですか?ブラウザでのパフォーマンスのためにJavaScriptコードを最適化するにはどうすればよいですか?Mar 18, 2025 pm 03:14 PM

この記事では、ブラウザでJavaScriptのパフォーマンスを最適化するための戦略について説明し、実行時間の短縮、ページの負荷速度への影響を最小限に抑えることに焦点を当てています。

jQueryマトリックス効果jQueryマトリックス効果Mar 10, 2025 am 12:52 AM

マトリックスの映画効果をあなたのページにもたらしましょう!これは、有名な映画「The Matrix」に基づいたクールなJQueryプラグインです。プラグインは、映画の古典的な緑色のキャラクター効果をシミュレートし、画像を選択するだけで、プラグインはそれを数値文字で満たされたマトリックススタイルの画像に変換します。来て、それを試してみてください、それはとても面白いです! それがどのように機能するか プラグインは画像をキャンバスにロードし、ピクセルと色の値を読み取ります。 data = ctx.getimagedata(x、y、settings.greasize、settings.greasize).data プラグインは、写真の長方形の領域を巧みに読み取り、jQueryを使用して各領域の平均色を計算します。次に、使用します

ブラウザ開発者ツールを使用してJavaScriptコードを効果的にデバッグするにはどうすればよいですか?ブラウザ開発者ツールを使用してJavaScriptコードを効果的にデバッグするにはどうすればよいですか?Mar 18, 2025 pm 03:16 PM

この記事では、ブラウザ開発者ツールを使用した効果的なJavaScriptデバッグについて説明し、ブレークポイントの設定、コンソールの使用、パフォーマンスの分析に焦点を当てています。

シンプルなjQueryスライダーを構築する方法シンプルなjQueryスライダーを構築する方法Mar 11, 2025 am 12:19 AM

この記事では、jQueryライブラリを使用してシンプルな画像カルーセルを作成するように導きます。 jQuery上に構築されたBXSLiderライブラリを使用し、カルーセルをセットアップするために多くの構成オプションを提供します。 今日、絵のカルーセルはウェブサイトで必須の機能になっています - 1つの写真は千の言葉よりも優れています! 画像カルーセルを使用することを決定した後、次の質問はそれを作成する方法です。まず、高品質の高解像度の写真を収集する必要があります。 次に、HTMLとJavaScriptコードを使用して画像カルーセルを作成する必要があります。ウェブ上には、さまざまな方法でカルーセルを作成するのに役立つ多くのライブラリがあります。オープンソースBXSLiderライブラリを使用します。 BXSLiderライブラリはレスポンシブデザインをサポートしているため、このライブラリで構築されたカルーセルは任意のものに適合させることができます

Angularを使用してCSVファイルをアップロードおよびダウンロードする方法Angularを使用してCSVファイルをアップロードおよびダウンロードする方法Mar 10, 2025 am 01:01 AM

データセットは、APIモデルとさまざまなビジネスプロセスの構築に非常に不可欠です。これが、CSVのインポートとエクスポートが頻繁に必要な機能である理由です。このチュートリアルでは、Angular内でCSVファイルをダウンロードおよびインポートする方法を学びます

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境