最後の質問の続き http://bbs.csdn.net/topics/390962881?page=1#post-398737904
液状化の式 U は解けましたが、実際に使用すると予想外の変形が見られますのでよくわかりません。リンクにエラーがあります。ガイドしてください
以下は私のコードです:
var r, alpha, angle, sourcePosition, destPosition, rmax, M, C, X; for (y = -radius; y < radius; ++y) { //取得圆范围 for (x = -radius; x < radius; ++x) { if (x * x + y * y <= radius * radius) { destPosition = (y + centerY) * width + x + centerX; //移动後圆内1点(此为pixel位置,非座标) destPosition *= 4; var rmax = radius; //圆半径 C = {x:centerX+80,y:centerY};//移动前原点C (假设右往左移动80 pixel) M = {x:centerX,y:centerY}; //移动後原点M X = {x:(x + centerX) , y: (y+ centerY)};//移动後圆内1点座标 var U = Liquify(M,X,C,rmax); //液化运算得到 U 座标 sourcePosition = ((Math.ceil(U.y))*width)+Math.ceil(U.x); //粗略取整数 U 座标(尚未用线性插值法) 并转换为pixel位置 sourcePosition *= 4; //用U取代原X像素 dstPixels[destPosition + 0] = srcPixels[sourcePosition + 0]; dstPixels[destPosition + 1] = srcPixels[sourcePosition + 1]; dstPixels[destPosition + 2] = srcPixels[sourcePosition + 2]; dstPixels[destPosition + 3] = srcPixels[sourcePosition + 3]; } } } drawPixels(canvasId, destImgData); //绘图开始
実行後の画像結果:
ディスカッションに返信 (解決策)
Canvas を使用するプロセスへ?
dstPixel と srcPixel はそれぞれ何ですか?値を割り当てる方法は?
アルゴリズムを見ると、srcPixels は getImageData メソッドで取得した画像データになるはずです
では、dstPixels はどのように割り当てられるのでしょうか。四角形の内接円部分を変更しただけなので
js配列は参照渡しです
コード内にdstPixels = srcPixelsがある場合、dstPixelsへの変更はsrcPixelsに影響します
なのでsrcPixels[sourcePosition + 0]が可能です先ほど変更した dstPixels[destPosition + 0]
これは間違っています
すべての変形データが生成されてからのみ書き戻すことができます
ご返信ありがとうございます、申し訳ありませんが、不足しているコードを埋めておきます
1. はい、キャンバスが使用されています
2. コードがありません:
var sourceImgData = originalImageData; //原始图片image data var destImgData = createCompatibleImageData(canvasId,sourceImgData); //将image 写入Canvas var srcPixels = sourceImgData.data; //取得image data var dstPixels = destImgData.data; //取得Canvas内image data
私の具体的な考えは、円内のピクセルを置き換えるだけです。すべての置換後のキャンバス、U の計算値は正しいと確信しています。何か誤解がありますか?私の置き換えの論理が正しいかどうかは現時点ではわかりません、私の資格が浅すぎて困っています。不足しているコードを入力します
1. はい、はい Canvas を使用します
2. コードを完成させます:
var sourceImgData = originalImageData; //原始图片image data var destImgData = createCompatibleImageData(canvasId,sourceImgData); //将image 写入Canvas var srcPixels = sourceImgData.data; //取得image data var dstPixels = destImgData.data; //取得Canvas内image data width = sourceImgData.width; height = sourceImgData.height; centerX = Math.floor(width / 2); centerY = Math.floor(height / 2); radius = 100; copyImageData(srcPixels, dstPixels, width, height); drawPixels(canvasId, destImgData); //绘出整张原图 var r, alpha, angle, sourcePosition, destPosition, rmax, M, C, X; for (y = -radius; y < radius; ++y) { //取得圆范围 for (x = -radius; x < radius; ++x) { if (x * x + y * y <= radius * radius) { destPosition = (y + centerY) * width + x + centerX; //移动後圆内1点(此为pixel位置,非座标) destPosition *= 4; var rmax = radius; //圆半径 C = {x:centerX+80,y:centerY};//移动前原点C (假设右往左移动80 pixel) M = {x:centerX,y:centerY}; //移动後原点M X = {x:(x + centerX) , y: (y+ centerY)};//移动後圆内1点座标 var U = Liquify(M,X,C,rmax); //液化运算得到 U 座标 sourcePosition = ((Math.ceil(U.y))*width)+Math.ceil(U.x); //粗略取整数 U 座标(尚未用线性插值法) 并转换为pixel位置 sourcePosition *= 4; //用U取代原X像素 dstPixels[destPosition + 0] = srcPixels[sourcePosition + 0]; dstPixels[destPosition + 1] = srcPixels[sourcePosition + 1]; dstPixels[destPosition + 2] = srcPixels[sourcePosition + 2]; dstPixels[destPosition + 3] = srcPixels[sourcePosition + 3]; } } } drawPixels(canvasId, destImgData); //绘出圆形部分
私の具体的な考えは、現時点では、ピクセルを置き換えるだけであるということです。全ての置換が終わってからキャンバスに書き戻すのは本当ですし、計算された値は正しいです。何か間違っていますか?置換のロジックが正しいかどうかは、現時点ではわかりません。その式を理解できません。また、資格が浅すぎて問題がありません。あなたが遭遇した状況
function createCompatibleImageData(canvasId, imgData) { "use strict"; var context2d = getContext2d(canvasId); return context2d.createImageData(imgData.width, imgData.height);}
は、canvas context2d を定義するだけなので、pixwel を置き換えるという私の考えは間違っていますか?何をすべきでしょうか?
処理は大まかにこんな感じ
var c=document.getElementById("myCanvas"); //获取 Canvas 控件var ctx=c.getContext("2d"); var img=new Image()img.src = '/photo.jpg';img.onload = function() { //加载图片 source = ctx.getImageData( x, y, w, h) //读取一个矩形区域 //在这里进行处理,注意事项在下面 ctx.putImageData(source, x, y) //写回去}
処理時
srcPixels = source.data.concat([]); //これによりコピーが生成される(非参照) dstPixels はsource.data
ではないどのような参照を指しているのかわかりますが、それはどういう意味ですか? (2つは同時に変更されます)
私のコード部分は参照(または引用)ではなく、一時的なコピーである必要があります
私が見ていた問題について考えましたが、アクションの範囲に問題がある可能性がありますか?
私の唯一の方法は、期待される画像の歪みを取得することですか?
完全なテスト例を書きましたので、参考にしてください (もちろん間違いもたくさんありますが、意味はあります)
画像上でマウスボタンを押してマウスをドラッグすると、効果が表示されます
すごいですね。 ..ありがとうマスターxuzuning、とても強力です! !
退屈して、ボード上の質問に答えてさまよっていました。とても楽しかったです〜
これで目的は達成できますが、減量には現実的ではないかもしれません。
xuzuning、私がその公式を使用する方法について議論の余地があると思いますか?それとも諦めて別の道を探すべきでしょうか?
マウスを端から中心に移動すると、確かにいわゆる「ボディ」効果が生じます (パラメーターを変更してみてください)
ただし、この式は彼の説明どおりではないようです (逆になっているようです) )
もちろんそれも可能です プログラムが間違って書かれていた 集中的な記述方法を試しましたが、ほとんどが期待した結果を達成できませんでした。前回の PHP バージョンのみが最も明白な効果を持っています
もう一度見てみることができます
私はあなたが提供したコードで遊んでいますが、確かに減量を達成できますが、ユーザーが期待した結果を達成できない可能性があると思います(Meitu Xiuxiuのような結果を達成するには)。 。現時点では、同様の機能を実装している人はインターネット上に見つかりません。これは本当に難しいと思います。xuzuning さんの熱心なサポートに感謝します。もう少し時間をかけて調査してみます。xuzuning が新しいアイデアを見つけたら、ぜひ議論して私と共有してください。
また、PHP 掲示板では投稿を編集できないのは普通のことでしょうか? 他の人の質問に回答するときにタイプミスをしたのに、投稿者であるにも関わらず修正できませんでした。この記事では、自分の投稿を編集できませんでした。
投稿は公開後数分以内にのみ投稿者によって変更できます
それ以外の時間に投稿を変更する権限はモデレーターにあります。これが CSDN の規定です
アルゴリズムの問題については、モデレーターと議論されます。それを理解したら、プライベートメールを送ってください
投稿は公開後数分以内にのみ投稿者によって変更できます
それ以外の場合に変更する権限はモデレーターにあります。 . これは CSDN の規定です
アルゴリズムの問題については、理解した後で話し合います メールでお送りください
わかりました、ありがとうございます。

まだ人気があるのは、使いやすさ、柔軟性、強力なエコシステムです。 1)使いやすさとシンプルな構文により、初心者にとって最初の選択肢になります。 2)Web開発、HTTP要求とデータベースとの優れた相互作用と密接に統合されています。 3)巨大なエコシステムは、豊富なツールとライブラリを提供します。 4)アクティブなコミュニティとオープンソースの性質は、それらを新しいニーズとテクノロジーの傾向に適応させます。

PHPとPythonはどちらも、Web開発、データ処理、自動化タスクで広く使用されている高レベルのプログラミング言語です。 1.PHPは、ダイナミックウェブサイトとコンテンツ管理システムの構築によく使用されますが、PythonはWebフレームワークとデータサイエンスの構築に使用されることがよくあります。 2.PHPはエコーを使用してコンテンツを出力し、Pythonは印刷を使用します。 3.両方ともオブジェクト指向プログラミングをサポートしますが、構文とキーワードは異なります。 4。PHPは弱いタイプの変換をサポートしますが、Pythonはより厳しくなります。 5. PHPパフォーマンスの最適化には、Opcacheおよび非同期プログラミングの使用が含まれますが、PythonはCprofileおよび非同期プログラミングを使用します。

PHPは主に手順プログラミングですが、オブジェクト指向プログラミング(OOP)もサポートしています。 Pythonは、OOP、機能、手続き上のプログラミングなど、さまざまなパラダイムをサポートしています。 PHPはWeb開発に適しており、Pythonはデータ分析や機械学習などのさまざまなアプリケーションに適しています。

PHPは1994年に発信され、Rasmuslerdorfによって開発されました。もともとはウェブサイトの訪問者を追跡するために使用され、サーバー側のスクリプト言語に徐々に進化し、Web開発で広く使用されていました。 Pythonは、1980年代後半にGuidovan Rossumによって開発され、1991年に最初にリリースされました。コードの読みやすさとシンプルさを強調し、科学的コンピューティング、データ分析、その他の分野に適しています。

PHPはWeb開発と迅速なプロトタイピングに適しており、Pythonはデータサイエンスと機械学習に適しています。 1.PHPは、単純な構文と迅速な開発に適した動的なWeb開発に使用されます。 2。Pythonには簡潔な構文があり、複数のフィールドに適しており、強力なライブラリエコシステムがあります。

PHPは、多数のWebサイトとアプリケーションをサポートし、フレームワークを通じて開発ニーズに適応するため、近代化プロセスで依然として重要です。 1.PHP7はパフォーマンスを向上させ、新機能を紹介します。 2。Laravel、Symfony、Codeigniterなどの最新のフレームワークは、開発を簡素化し、コードの品質を向上させます。 3.パフォーマンスの最適化とベストプラクティスは、アプリケーションの効率をさらに改善します。

phphassiblasifly-impactedwebdevevermentandsbeyondit.1)itpowersmajorplatformslikewordpratsandexcelsindatabase interactions.2)php'sadaptableability allowsitale forlargeapplicationsusingframeworkslikelavel.3)

PHPタイプは、コードの品質と読みやすさを向上させるためのプロンプトがあります。 1)スカラータイプのヒント:php7.0であるため、基本データ型は、int、floatなどの関数パラメーターで指定できます。 3)ユニオンタイプのプロンプト:PHP8.0であるため、関数パラメーターまたは戻り値で複数のタイプを指定することができます。 4)Nullable Typeプロンプト:null値を含めることができ、null値を返す可能性のある機能を処理できます。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

SublimeText3 中国語版
中国語版、とても使いやすい

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

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境
