js描画放物線コード共有
この記事では主に放物線を描画するための JS コードを紹介します。具体的な方法とともにコードを見てみましょう。
レンダリング:
<!DOCTYPE HTML><html><head> <meta charset="utf-8"> <title>抛物线运动效果</title> <style type="text/css"> body { overflow: hidden; } .boll { width: 50px; height: 50px; position: absolute; top: 55%; left: 55%; background: url("redpack_show.jpg"); background-size: contain; } .red-bag { position: absolute; left: 50%; top:50%; width: 200px; height: 200px; border-radius: 50%; background: url("red_bag.png") no-repeat; background-size: contain; z-index:10; } </style> <script type="text/javascript" src="jquery-2.1.4.js"></script> <script type="text/javascript" src="parabola.js"></script></head><body><p class="btns" style="margin-top:20px"> <a href="http://www.css88.com/archives/5355" target="_blank">回到JavaScript实现的抛物线运动效果</a></p><p class="btns" style="margin-top:20px"> <a href="#" class="btnA btn-danger" id="run" rel="popover" title="A Title" >run</a></p><p class="red-bag"></p><p id="target" class="target"></p><!--<p class="boll boll1"></p>--><script type="text/javascript"> for(let i=1;i<80;i++){ $("body").append(`<p class='boll boll${i}'></p>`); let bool = "bool"+i; createSingle(bool,i); // console.log(i) } function createSingle(bool,i) { let left = i%2 == 0 ? (-getRandom(500,600)):(getRandom(500,600)); let top = i%2 == 0? (getRandom(200,250)):(getRandom(200,250)); // console.log(getRandom(0.005,0.01)); bool = new Parabola({ el: ".boll"+i, offset: [left, top], curvature: 0.005, duration: 3000, callback:function(){ // alert("完成后回调") }, stepCallback:function(x,y){ // console.log(x,y); // $("<p>").appendTo("body").css({ // "position": "absolute", // "top": this.elOriginalTop + y, // "left":this.elOriginalLeft + x, // "background-color":"rgba(244,21,50,.5)", // "width":"2px", // "height":"2px", // "border-radius": "2px" // }); } }); $("#run").click(function (event) { event.preventDefault(); bool.start(); }); } function getRandom(min,max) { return Math.random()*(max-min)+min; } // $("#reset").click(function (event) { // event.preventDefault(); // bool.reset() // }); // $("#run").click(function (event) { // event.preventDefault(); // bool.start(); // }); // $("#stop").click(function (event) { // event.preventDefault(); // bool.stop(); // }); // $("#setOptions").click(function (event) { // event.preventDefault(); // bool.setOptions({ // targetEl: $("#target"), // curvature: 0.001, // duration: 1000 // }); // });</script></body></html>
(function () { var _$ = function (_this) { return _this.constructor == jQuery ? _this : $(_this); };// 获取当前时间 function now() { return +new Date(); }// 转化为整数 function toInteger(text) { text = parseInt(text); return isFinite(text) ? text : 0; } var Parabola = function (options) { this.initialize(options); }; Parabola.prototype = { constructor: Parabola, /** * 初始化 * @classDescription 初始化 * @param {Object} options 插件配置 . */ initialize: function (options) { this.options = this.options || this.getOptions(options); var ops = this.options; if (!this.options.el) { return; } this.$el = _$(ops.el); this.timerId = null; this.elOriginalLeft = toInteger(this.$el.css("left")); this.elOriginalTop = toInteger(this.$el.css("top")); // this.driftX X轴的偏移总量 //this.driftY Y轴的偏移总量 if (ops.targetEl) { this.driftX = toInteger(_$(ops.targetEl).css("left")) - this.elOriginalLeft; this.driftY = toInteger(_$(ops.targetEl).css("top")) - this.elOriginalTop; } else { this.driftX = ops.offset[0]; this.driftY = ops.offset[1]; } this.duration = ops.duration; // 处理公式常量 this.curvature = ops.curvature; // 根据两点坐标以及曲率确定运动曲线函数(也就是确定a, b的值) //a=this.curvature /* 公式: y = a*x*x + b*x + c; */ /* * 因为经过(0, 0), 因此c = 0 * 于是: * y = a * x*x + b*x; * y1 = a * x1*x1 + b*x1; * y2 = a * x2*x2 + b*x2; * 利用第二个坐标: * b = (y2+ a*x2*x2) / x2 */ // 于是 this.b = ( this.driftY - this.curvature * this.driftX * this.driftX ) / this.driftX; //自动开始 if (ops.autostart) { this.start(); } }, /** * 初始化 配置参数 返回参数MAP * @param {Object} options 插件配置 . * @return {Object} 配置参数 */ getOptions: function (options) { if (typeof options !== "object") { options = {}; } options = $.extend({}, defaultSetting, _$(options.el).data(), (this.options || {}), options); return options; }, /** * 定位 * @param {Number} x x坐标 . * @param {Object} y y坐标 . * @return {Object} this */ domove: function (x, y) { this.$el.css({ position: "absolute", left: this.elOriginalLeft + x, top: this.elOriginalTop + y }); return this; }, /** * 每一步执行 * @param {Data} now 当前时间 . * @return {Object} this */ step: function (now) { var ops = this.options; var x, y; if (now > this.end) { // 运行结束 x = this.driftX; y = this.driftY; this.domove(x, y); this.stop(); if (typeof ops.callback === 'function') { ops.callback.call(this); } } else { //x 每一步的X轴的位置 x = this.driftX * ((now - this.begin) / this.duration); //每一步的Y轴的位置y = a*x*x + b*x + c; c==0; y = this.curvature * x * x + this.b * x; this.domove(x, y); if (typeof ops.stepCallback === 'function') { ops.stepCallback.call(this,x,y); } } return this; }, /** * 设置options * @param {Object} options 当前时间 . */ setOptions: function (options) { this.reset(); if (typeof options !== "object") { options = {}; } this.options = $.extend(this.options,options); this.initialize(this.options); return this; }, /** * 开始 */ start: function () { var self = this; // 设置起止时间 this.begin = now(); this.end = this.begin + this.duration; if (this.driftX === 0 && this.driftY === 0) { // 原地踏步就别浪费性能了 return; } /*timers.push(this); Timer.start();*/ if (!!this.timerId) { clearInterval(this.timerId); this.stop(); } this.timerId = setInterval(function () { var t = now(); self.step(t); }, 13); return this; }, /** * 重置 */ reset: function (x, y) { this.stop(); x = x ? x : 0; y = y ? y : 0; this.domove(x, y); return this; }, /** * 停止 */ stop: function () { if (!!this.timerId) { clearInterval(this.timerId); } return this; } }; var defaultSetting = { el: null, //偏移位置 offset: [0, 0], //终点元素,这时就会自动获取该元素的left、top,设置了这个参数,offset将失效 targetEl: null, //运动的时间,默认500毫秒 duration: 500, //抛物线曲率,就是弯曲的程度,越接近于0越像直线,默认0.001 curvature: 0.001, //运动后执行的回调函数 callback: null, // 是否自动开始,默认为false autostart: false, //运动过程中执行的回调函数 stepCallback: null }; window.Parabola = Parabola; })();
関連する推奨事項:
放物線を実装し、ショッピング カートの効果を追加するための parabola.js
放物線を実装するための 2 つの JSの軌跡小さなボール 運動方法
以上がjs描画放物線コード共有の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

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

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Quark Netdisk と Baidu Netdisk は非常に便利なストレージ ツールですが、多くのユーザーはこれら 2 つのソフトウェアが相互運用可能かどうかを疑問に思っています。 Quark NetdiskをBaidu Netdiskに共有するにはどうすればよいですか?このサイトでは、QuarkネットワークディスクファイルをBaiduネットワークディスクに保存する方法をユーザーに詳しく紹介します。 Quark Network Disk から Baidu Network Disk にファイルを保存する方法 方法 1. Quark Network Disk から Baidu Network Disk にファイルを転送する方法を知りたい場合は、まず Quark Network Disk に保存する必要があるファイルをダウンロードして、次に開きますBaidu Network Disk クライアントを起動し、圧縮ファイルを保存するフォルダーを選択し、ダブルクリックしてフォルダーを開きます。 2. フォルダーを開いたら、ウィンドウ左上の「アップロード」をクリックします。 3. コンピュータ上でアップロードする必要がある圧縮ファイルを見つけ、クリックして選択します。

1. まず、NetEase Cloud Music に入り、ソフトウェアのホームページ インターフェイスをクリックして、曲の再生インターフェイスに入ります。 2. 次に、曲の再生インターフェイスで、下の図の赤いボックスに示すように、右上隅にある共有機能ボタンを見つけて、クリックして共有チャンネルを選択し、共有チャンネルで「共有先」オプションをクリックします。下部にある [WeChat Moments] を選択すると、コンテンツを WeChat Moments に共有できます。

WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 はじめに: 技術の継続的な発展により、音声認識技術は人工知能の分野の重要な部分になりました。 WebSocket と JavaScript をベースとしたオンライン音声認識システムは、低遅延、リアルタイム、クロスプラットフォームという特徴があり、広く使用されるソリューションとなっています。この記事では、WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法を紹介します。

最近、Baidu Netdisk Android クライアントの新しいバージョン 8.0.0 がリリースされ、このバージョンには多くの変更が加えられただけでなく、多くの実用的な機能も追加されました。その中でも最も目を引くのがフォルダー共有機能の強化だ。ユーザーは簡単に友人を招待して仕事や生活で重要なファイルを共有できるようになり、より便利なコラボレーションと共有が実現します。では、友達と共有する必要があるファイルをどのように共有すればよいでしょうか? 以下では、このサイトの編集者が詳しく説明します。 1) Baidu Cloud APP を開き、まずホームページ上の関連フォルダーをクリックして選択し、次にインターフェイスの右上隅にある [...] アイコンをクリックします (以下を参照) 2) 次に、[+] をクリックします。 「共有メンバー」欄】を選択し、最後に全てにチェックを入れます

WebSocketとJavaScript:リアルタイム監視システムを実現するためのキーテクノロジー はじめに: インターネット技術の急速な発展に伴い、リアルタイム監視システムは様々な分野で広く利用されています。リアルタイム監視を実現するための重要なテクノロジーの 1 つは、WebSocket と JavaScript の組み合わせです。この記事では、リアルタイム監視システムにおける WebSocket と JavaScript のアプリケーションを紹介し、コード例を示し、その実装原理を詳しく説明します。 1.WebSocketテクノロジー

Mango TV には、さまざまな種類の映画、テレビシリーズ、バラエティ番組などのリソースがあり、ユーザーはそれらを自由に選択して視聴できます。 Mango TV 会員はすべての VIP ドラマを視聴できるだけでなく、ユーザーが楽しくドラマを視聴できるように最高解像度の画質を設定することもできます。以下では、編集者がユーザーが使用できる無料の Mango TV 会員アカウントをいくつか紹介します。急いで見てください。見てください。 Mango TV 最新のメンバー アカウント無料共有 2023: 注: これらは収集された最新のメンバー アカウントです。直接ログインして使用できます。パスワードを自由に変更しないでください。口座番号: 13842025699 パスワード: qds373 口座番号: 15804882888 パスワード: evr6982 口座番号: 13330925667 パスワード: jgqae 口座番号: 1703

HP プリンターは多くのオフィスで欠かせない印刷機器であり、コンピューターにプリンター ドライバーをインストールすると、プリンターが接続できないなどの問題を完全に解決できます。では、HP プリンター ドライバーをインストールするにはどうすればよいでしょうか?以下のエディターでは、2 つの HP プリンター ドライバーのインストール方法を紹介します。 1 つ目の方法: 公式 Web サイトからドライバーをダウンロードする 1. 検索エンジンで HP 中国公式 Web サイトを検索し、サポート欄で [ソフトウェアとドライバー] を選択します。 2. [プリンター] カテゴリを選択し、検索ボックスにプリンターのモデルを入力し、[送信] をクリックしてプリンター ドライバーを見つけます。 3. お使いのコンピューター システムに応じて対応するプリンターを選択します (win10 の場合は、win10 システム用のドライバーを選択します)。 4. ダウンロードが成功したら、フォルダー内でそれを見つけます

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 はじめに: 今日、天気予報の精度は日常生活と意思決定にとって非常に重要です。テクノロジーの発展に伴い、リアルタイムで気象データを取得することで、より正確で信頼性の高い天気予報を提供できるようになりました。この記事では、JavaScript と WebSocket テクノロジを使用して効率的なリアルタイム天気予報システムを構築する方法を学びます。この記事では、具体的なコード例を通じて実装プロセスを説明します。私たちは
