ホームページ バックエンド開発 PHPチュートリアル VML描画タブレット②スクリプト - VMLgraph.js、XMLtool.js_PHPチュートリアル

VML描画タブレット②スクリプト - VMLgraph.js、XMLtool.js_PHPチュートリアル

Jul 21, 2016 pm 04:11 PM
d var VML 脚本


脚本
*************
* VMLgraph.js
*************
var xo=0;
var yo=0;
var ox= 80;
var oy=20;
var dx=0;
var dy=0;
vardrawKey = false;
var itemID = 0;
var ShapeItemNum = 0;
var ShapeItemX = 0;
var ShapeItemY = 0;
var CurveItemNum = 0;
var NodeDelete = false;
var ToolBarNum = 2; // 設置可能なツール编号
var gradientX = -1;

functioncursor(k) {
xo =event.clientX - ox;
yo =event.clientY - oy;
if(k && xo>=0 && yo>=0)
oxy.innerHTML = xo+","+yo;
else
oxy.innerHTML = "";
if(drawKey) {
paint();
view.innerHTML =tree(canvas.documentElement,0 );
}
}

function setOverColor(v) {
if(! NodeDelete) return;
v.myColor = v.ストロークカラー;
if(v.ストロークカラー == "赤")
v.ストロークカラー='# 000000';
else
v.drawingcolor='#ff0000';
}
function setOutColor(v) {
if(! NodeDelete) return;
v.drawingcolor = v.myColor;
view.innerHTML =tree(canvas. documentElement,0);
}
function deleteNode(v) {
if(! NodeDelete) return;
var id = v.id;
for(i=0;i var node = Canvas.selectNodes("/*//*")[i];
if(node.getAttribute("id") == id) {
canvas.documentElement.childNodes[ 0].removeChild(node);
view.innerHTML =tree(canvas.documentElement,0);
return;
}
}
}

function setElement(node) {
node.setAttribute("id") = itemID ;
node.setAttribute("myColor") = "#";
node.setAttribute("onMouseOver") = "setOverColor(this)";
node.setAttribute("onMouseOut") = "setOutColor(this)";
node.setAttribute("onClick") = "deleteNode(this)" ;

var subobjField = Canvas.createElement("v:ストローク");
subobjField.setAttribute("color") = color1.fillcolor;
subobjField.setAttribute("dashstyle") = crashstyle.dashstyle;
node.appendChild( subobjField);
if(textbox.style.visibility == "visible" && txt.value.length) {
var subobjField = Canvas.createElement("v:path");
subobjField.setAttribute("textpathok") = " true";
node.appendChild(subobjField);
var subobjField = Canvas.createElement("v:textpath");
subobjField.setAttribute("on") = "true";
subobjField.setAttribute("string") = txt.value;
subobjField.setAttribute("style") = "font:normalnormalnormal16pt 'Arial Black'";
node.appendChild(subobjField);
}
canvas.documentElement.childNodes[0].appendChild(node );
}

function Mouse_down() {
drawKey = true;
dx = xo;
dy = yo;
itemID++;
if(ToolBarNum != 7) ShapeItemNum = 0;
switch(ToolBarNum) {
ケース 3 :
var objField = Canvas.createElement("v:line");
objField.setAttribute("from") = xo+","+yo;
objField.setAttribute("to") = xo+","+yo;
return setElement(objField);
case 4:
if(CurveItemNum == 0) {
CurveItemNum = 1;
var objField = Canvas.createElement("v:curve");
objField.setAttribute("from") = xo+","+yo;
objField.setAttribute("to") = xo+","+yo;
objField.setAttribute("control1") = xo+","+yo;
objField.setAttribute("control2") = xo+","+yo;
var subobjField = Canvas.createElement("v:fill");
subobjField.setAttribute("opacity") = 0;
objField.appendChild(subobjField);
setElement (objフィールド);
}
return;
case 9:
var objField = Canvas.createElement("v:polyline");
objField.setAttribute("points") = xo+","+yo+" "+xo+","+yo;
var subobjField = Canvas.createElement("v:fill");
subobjField.setAttribute("opacity") = 0;
objField.appendChild(subobjField);
return setElement(objField);
case 7:
if(ShapeItemNum == 0) {
var objField = Canvas.createElement("v:shape");
objField.setAttribute("style") = "width:500; height:309";
objField.setAttribute("path") = "m "+xo+","+yo+" l "+xo+","+yo;
ShapeItemX = xo;
ShapeItemY = yo;
}else {
objField = Canvas.documentElement.childNodes[0].lastChild;
objフィールド。 setAttribute("path") = objField.getAttribute("path") + " "+xo+","+yo;
return;
}
ShapeItemNum++;
break;
case 5:
var objField = Canvas.createElement(" v:rect");
break;
ケース 6:
var objField = Canvas.createElement("v:roundrect");
objField.setAttribute("arcsize") = 0.2;
break;
ケース 8:
var objField = Canvas.createElement("v:oval");
break;
case 10:
s = "";
s =tree(canvas.documentElement,1);
view.innerHTML = s;
return;
default:
drawKey = false;
return;
}
if(objField) {
if(ToolBarNum != 7)
objField.setAttribute("style") = "左: "+xo+"; "+yo+"; 幅:0; 高さ:0;";
var subobjField = Canvas.createElement("v:fill");
subobjField.setAttribute("opacity") = gradientBar.opacity;
subobjField.setAttribute(" angle") = gradientBar.angle;
subobjField.setAttribute("type") = gradientBar.type;
subobjField.setAttribute("color") = gradientBar.color.value;
subobjField.setAttribute("color2") = gradientBar。 color2.value;
subobjField.setAttribute("colors") = gradientBar.colors.value;
subobjField.setAttribute("focusposition") = gradientBar.focusposition;
objField.appendChild(subobjField);
return setElement(objField);
}
return;
}

function Mouse_up() {
drawKey = false;
if(CurveItemNum > 0) CurveItemNum++;
if(CurveItemNum > 3) CurveItemNum = 0;
if(ToolBarNum == 7) {
if(Math.abs(xo - ShapeItemX) ShapeItemNum = 0;
Element = Canvas.documentElement.childNodes[0].lastChild;
var regerp = / [0-9]+,[0-9]+$/
var str = Element.getAttribute( "path");
Element.setAttribute("path") = str.replace(regerp," x e");
view.innerHTML =tree(canvas.documentElement,0);
}
}
}

function pattern() {
Element = Canvas.documentElement.childNodes[0].lastChild;
var x0,y0,x1,y1;
x0 = Math.min(dx,xo);
y0 = Math.min( dy,yo);
x1 = Math.max(dx,xo);
y1 = Math.max(dy,yo);
var box = "左:"+x0+"; 上:"+y0+"; 幅: "+(x1-x0)+"; 高さ:"+(y1-y0)+";";
switch(ToolBarNum) {
case 4:
if(CurveItemNum ==2) {
Element.setAttribute("control1 ")= xo+"、 "+yo; ")= xo+"、 "+yo; -9]+,[0-9]+$/
var str = Element.getAttribute("path");
Element.setAttribute("path") = str.replace(regerp,xo+","+yo);
ブレーク;
ケース5:
ケース6:
ケース8:
var regerp = /left.+height:1height:++ /
var str = element.getattribute( "style"); ("style") = str.replace(regerp,box);
break;
case 9:
var regerp = / [0-9]+,[0-9]+$/
var str = Element.getAttribute( "points");
Element.setAttribute("points") = str+" "+xo+","+yo;
break;
defaule:
break;
}

}

function init() {
tool_box_refresh ( );  // ツール栏初始
view.innerHTML =tree(canvas.documentElement);  // 绘图区初始
color.innerHTML =tree(tools.selectNodes("*/colorbar")[0]);  // 颜色选择初始
linebox.innerHTML =tree(tools.selectNodes("*/linebox")[0]);  // 線型选择初期
gradientBox.innerHTML =tree(tools.selectNodes("*/gradient")[0]);  // 充填选择初
}

// 绘制ツール栏
function tool_box_refresh() {
varbuffer = "";
var i;
for(i=0;i var node = tools.selectNodes("*/toolbar")[i];
var id = node.getAttribute("id");
node.childNodes[0].setAttribute("onClick" ) = "tool_box_select("+id+",this.title)";
var node1 = node.selectNodes("*/v:rect")[0];
if(id == ToolBarNum) {
node1.setAttribute( "fillcolor") = "#ffcccc"
node1.setAttribute("ストロークカラー") = "#ff0000"
}else {
node1.setAttribute("fillcolor") = "#ffffff"
node1.setAttribute("ストロークカラー") = "#000000"
}
buffer +=tree(node.childNodes[0]);
}
toolbox.innerHTML =buffer;
}

// ツール选择
function tool_box_select(v,t) {
var key = ToolBarNum;
ToolBarNum = v;
tool_box_refresh();
hooke();
if(v == 7) {
if(key == 7 && ShapeItemNum > 0) {
Element = Canvas.documentElement.childNodes[ 0].lastChild;
var str = Element.getAttribute("path");
Element.setAttribute("path") = str + " x e";
view.innerHTML =tree(canvas.documentElement,0);
ShapeItemNum = 0;
}
}
if(v == 10)
if(textbox.style.visibility == "hidden")
textbox.style.visibility = "visible";
else
textbox.style.visibility = "hidden";
NodeDelete = false ;
if(v == 1) {
NodeDelete = true;
view.innerHTML =tree(canvas.documentElement,0);
}
}

// 颜色选择
//var setcolorkey = color1;
function setcolor (c) {
var setcolorkey = color1;
setcolorkey.fillcolor = c;
}

function gradientColor(v) {
v.fillcolor = color1.fillcolor;
gradientRefresh();
return;
var m = tools. documentElement.selectNodes("/*/gradient//v:shape").length;
var node = tools.documentElement.selectNodes("/*/gradient//v:shape");
for(i=0;i< ;m;i++) {
if(node[i].getAttribute("id") == v.id)
node[i].setAttribute("fillcolor") = color1.fillcolor;
}
gradientRefresh();
}
function gradientPoint(v) {
if(gradientX gradientX = xo - 508 - parseInt(v.style.left);
n = xo - 508 - gradientX;
if(n if(n > 108) n = 108;
v.style.left = n;
gradientRefresh();
}
function anglePoint(v) {
angle.style.left = Math.floor( (xo-516)/25)*25+8;
gradientRefresh();
}
function opacityPoint(v) {
opacity.style.left = Math.floor((xo-516)/25)*25+8 ;
gradientRefresh();
}
function settype(v) {
if(v.style.borderColor == "black")
v.style.borderColor = "red";
else
v.style.borderColor = " black";
gradientRefresh();
}
function setGradientX() {
gradientX = -1;
}

function gradientRefresh() {
var m = (parseInt(gradient4.style.left)-parseInt(gradient1.style) .left));
var n1 = (parseInt(gradient2.style.left)-parseInt(gradient1.style.left))/m*100;
var n2 = (parseInt(gradient3.style.left)-parseInt(gradient1) .style.left))/m*100;
gradientBar.color.value = gradient1.fillcolor;
gradientBar.color2.value = gradient4.fillcolor;
if(type3.style.borderColor == "black")
gradientBar。 Colors.value = ",";
else
gradientBar.colors.value = n1 + "% " + gradient2.fillcolor + "," + n2 + "% " + gradient3.fillcolor;
if(type1.style.borderColor = = "黒")
gradientBar.type = "ソリッド";
else
gradientBar.type = "グラデーション";
if(type2.style.borderColor == "赤")
gradientBar.type = "グラデーションラジアル";
n1 = (parseInt(focus1.style.left)-8)/m*100;
n2 = (parseInt(focus2.style.left)-8)/m*100;
gradientBar.focusposition.value = n1 + "%, " + n2 + "%";
gradientBar.angle = (parseInt(angle.style.left)-8) * 3.6;
gradientBar.opacity = (parseInt(opacity.style.left)-8)/m
}

*************
* XMLtool.js
*************

//XML文档を服务器に送信
function saveXML()
{
var xmlHTTP = new ActiveXObject("Microsoft.XMLHTTP");
xmlHTTP.open("POST","server.php",false); // ASP 使用時用server.asp
xmlHTTP.setRequestHeader("Contrn-type","text/xml");
xmlHTTP.setRequestHeader("Contrn-charset","gb2312");

xmlHTTP.send(tree (canvas.documentElement));
var s = xmlHTTP.responseText;
minview.innerHTML = s.replace(/WIDTH:500;HEIGHT:300/,"WIDTH:120;HEIGHT:72")
if(xmlHTTP.responseText .indexOf("Error:")!=-1) {
alert(xmlHTTP.responseText);
}
}

// 遍历xml对象解析,xml的核心関数数集
function Tree(Element,debug) {
varbuffer = "";
var node = "";
if(Element.nodeType != 3) {
node = Element;
buffer += onElement(Element,debug);
}
if(Element.nodeType == 3)
buffer += onData(Element);
if(Element.hasChildNodes) {
for(var i=0;i buffer +=tree(Element.childNodes(i) 、デバッグ);
}
}
if(node)
バッファ += endElement(node,debug);
return バッファ;
}

/***** 以下の 3 つの関数を必要に応じて変更してください *****/
// XML オブジェクトのトラバース -- ノード開始
関数 onElement(Element,debug) {
varbuffer = (debug ? "<" : "<") + Element.nodeName;
n = Element.attributes.length
if(n>0) { // ノードにパラメータがある場合
for(var i=0;i バッファ += ' ' + Element.attributes(i).name + '="' + Element.attributes(i).value + '"';
}
バッファ += debug ? ">" : ">";
returnbuffer;
}

// XML オブジェクトを走査します -- ノード end
function endElement(Element,debug) {
return (debug ? "
" : ">");
}

// XML オブジェクトのトラバース -- ノード データ
function onData(Element) {
Element.nodeValue を返す
}

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/314076.html技術記事スクリプト*************** * VMLgraph.js ************ var xo=0; var ox=80; oy=20; var dx=0; vardrawKey = 0; var ShapeItemNum = 0;
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

5分ごとに実行されるPythonスクリプト 5分ごとに実行されるPythonスクリプト Sep 10, 2023 pm 03:33 PM

自動化とタスクのスケジューリングは、ソフトウェア開発における反復的なタスクを合理化する上で重要な役割を果たします。 API からのデータの取得、データ処理の実行、定期的な更新の送信など、5 分ごとに実行する必要がある Python スクリプトがあると想像してください。スクリプトを手動で頻繁に実行すると、時間がかかり、エラーが発生しやすくなります。ここでタスクのスケジュール設定が役に立ちます。このブログ投稿では、Python スクリプトを 5 分ごとに実行するようにスケジュールし、手動介入なしで自動的に実行されるようにする方法を説明します。この目標を達成するために使用でき、タスクを効率的に自動化できるさまざまな方法とライブラリについて説明します。 time.sleep() 関数を使用して Python スクリプトを 5 分ごとに実行する簡単な方法は、tim を利用することです。

編集用のスクリプトを作成するにはどうすればよいですか?編集によるスクリプトの作成方法のチュートリアル 編集用のスクリプトを作成するにはどうすればよいですか?編集によるスクリプトの作成方法のチュートリアル Mar 13, 2024 pm 12:46 PM

Cutting は、包括的な編集機能、可変速度のサポート、さまざまなフィルターや美容効果、豊富な音楽ライブラリ リソースを備えたビデオ編集ツールです。このソフトでは動画を直接編集したり、編集スクリプトを作成したりすることができますが、どのように行うのですか?このチュートリアルでは、エディターがスクリプトを編集および作成する方法を紹介します。作成方法: 1. コンピュータ上で編集ソフトウェアをクリックして開き、「作成スクリプト」オプションを見つけてクリックして開きます。 2. 作成台本ページで「台本タイトル」を入力し、概要に撮影内容の簡単な紹介文を入力します。 3. アウトラインに「ストーリーボードの説明」オプションを表示するにはどうすればよいですか?

コンピューターをシャットダウンするための Python スクリプト コンピューターをシャットダウンするための Python スクリプト Aug 29, 2023 am 08:01 AM

今日のペースの速いデジタル世界では、コンピューターのタスクを自動化できることで、生産性と利便性が大幅に向上します。タスクの 1 つはコンピュータのシャットダウンですが、これを手動で行うと非常に時間がかかる可能性があります。ありがたいことに、Python はシステムと対話し、そのようなタスクを自動化するための強力なツールのセットを提供します。このブログ投稿では、コンピューターを簡単にシャットダウンするための Python スクリプトの作成方法を検討します。自動シャットダウンをスケジュールする場合でも、リモートでシャットダウンを開始する場合でも、手動シャットダウンを回避して単に時間を節約する場合でも、このスクリプトは役に立ちます。必要なモジュールのインポート スクリプトの作成を開始する前に、システムと対話してシャットダウン コマンドを実行するために必要なモジュールをインポートする必要があります。このセクションでは、os モジュール (

Linuxシステムで.shファイルを実行するにはどうすればよいですか? Linuxシステムで.shファイルを実行するにはどうすればよいですか? Mar 14, 2024 pm 06:42 PM

Linuxシステムで.shファイルを実行するにはどうすればよいですか? Linux システムでは、.sh ファイルはシェル スクリプトと呼ばれるファイルであり、一連のコマンドを実行するために使用されます。 .sh ファイルの実行は非常に一般的な操作です。この記事では、Linux システムで .sh ファイルを実行する方法と具体的なコード例を紹介します。方法 1: 絶対パスを使用して .sh ファイルを実行する Linux システムで .sh ファイルを実行するには、絶対パスを使用してファイルの場所を指定できます。具体的な手順は次のとおりです。 ターミナルを開きます。

Python スクリプトのパッケージ化 exe、auto-py-to-exe が役に立ちます。 Python スクリプトのパッケージ化 exe、auto-py-to-exe が役に立ちます。 Apr 13, 2023 pm 04:49 PM

1. auto-py-to-exe とはauto-py-to-exe は、Python プログラムを実行可能ファイルにパッケージ化するために使用されるグラフィカル ツールです。この記事では主にauto-py-to-exeを使用してPythonプログラムのパッケージ化を完了する方法を紹介します。 auto-py-to-exe は pyinstaller に基づいています。pyinstaller と比較して、GUI インターフェイスがあり、よりシンプルで使いやすいです。2. auto-py-to-exe をインストールするには、まず Python 環境を確認する必要があります。は 2.7 以上です。次に、cmd に「pip install」と入力します。

コンピューターを再起動するための Python スクリプト コンピューターを再起動するための Python スクリプト Sep 08, 2023 pm 05:21 PM

コンピューターの再起動は、問題のトラブルシューティング、更新プログラムのインストール、システム変更の適用などのために頻繁に実行される一般的なタスクです。コンピューターを再起動する方法はたくさんありますが、Python スクリプトを使用すると自動化され便利です。この記事では、簡単な実行でコンピュータを再起動できる Python スクリプトの作成方法を説明します。まず、コンピュータを再起動することの重要性と、それがもたらす利点について説明します。次に、Python スクリプトの実装の詳細を詳しく調べ、必要なモジュールと関連する機能について説明します。この記事では、明確な理解を確実にするために、詳細な説明とコード スニペットを提供します。コンピュータを再起動することの重要性 コンピュータを再起動することは、次のことを可能にする基本的なトラブルシューティング手順です。

初心者向けの Windows PowerShell スクリプト チュートリアル 初心者向けの Windows PowerShell スクリプト チュートリアル Mar 13, 2024 pm 10:55 PM

この Windows PowerShell スクリプト チュートリアルは、テクノロジ愛好家でも、スクリプト スキルの向上を目指す専門家でも、初心者向けに設計されています。 PowerShell スクリプトに関する予備知識がない場合は、この記事は基本から始めて、あなたに合わせてカスタマイズしてください。 PowerShell 環境のインストール手順をマスターし、PowerShell スクリプトの主な概念と機能を説明します。 PowerShell スクリプトについてさらに学ぶ準備ができている場合は、このエキサイティングな学習の旅に一緒に乗り出しましょう。 WindowsPowerShell とは何ですか? PowerShell は、Microsoft によって開発されたハイブリッド コマンド システムです。

便利で使いやすい 5 つの Python 自動化スクリプト 便利で使いやすい 5 つの Python 自動化スクリプト Apr 11, 2023 pm 07:31 PM

自動化された生産ラインや自動化されたオフィスなどの言葉を聞いたことがある人に比べて、機械は人間の手を介さずにさまざまな作業を自動的に実行できるため、作業効率が大幅に向上します。プログラミングの世界には、さまざまなタスクを完了するためのさまざまな自動化スクリプトがあります。特に、Python は構文が簡潔で理解しやすく、豊富なサードパーティ ツール ライブラリがあるため、自動スクリプトの作成に非常に適しています。今回は、Python を使用して、業務で使用できるいくつかの自動化シナリオを実装します。 1. Web ニュースを自動的に読み上げます。このスクリプトは、Web ページからテキストをキャプチャし、それを自動的に音声で読み上げることができます。ニュースを聞きたい場合に適しています。コードは 2 つの部分に分かれており、1 つはクローラーを通じて Web ページのテキストをクロールする部分、もう 1 つは読み取りツールを通じてテキストを読み取る部分です。

See all articles