forked from: forked from: forked from: ozmap test
forked from forked from: forked from: ozmap test (diff: 151)
[SWF(backgroundColor=0, width=465, height=465)]
ActionScript3 source code
/**
* Copyright tepe ( http://wonderfl.net/user/tepe )
* MIT License ( http://www.opensource.org/licenses/mit-license.php )
* Downloaded from: http://wonderfl.net/c/d9LP
*/
// forked from tepe's forked from: forked from: ozmap test
// forked from tepe's forked from: ozmap test
// forked from tepe's ozmap test
// forked from tepe's flash on 2011-3-19
package {
import flash.events.*;
import flash.display.*;
import flash.text.*;
import flash.net.*;
import flash.system.*;
//[SWF(backgroundColor=0, width=465, height=465)]
public class FlashTest extends Sprite {//==================================
private var node1:ozmap = new ozmap();
private var text1:TextField = new TextField();
private var tf1:TextField = new TextField();
public function FlashTest() {//----------------------------------------
addChild(node1);
var s:Sprite = new Sprite();
s.graphics.lineStyle(1,0x000000);
s.graphics.drawCircle(100,100,20);
node1.map.addChild(s);
/*
Security.loadPolicyFile('http://www.ozworks.dip.jp/crossdomain.xml');
var loader:Loader;
loader = new Loader();
const req:String = "http://www.ozworks.dip.jp/img/01/1426006.png";
loader.load(new URLRequest(req));//youtubeプレイヤー読み込み
node1.map.addChild(loader);
loader.x = 200;
//loader.scaleX = loader.scaleY = 0.2;
*/
addChild(tf1);
tf1.border = true;
tf1.type = "input";
tf1.height = 30;
tf1.y = 400;
tf1.width = 400;
tf1.addEventListener(KeyboardEvent.KEY_DOWN,onKey);
}
private var getWeb:URLLoader2;
private function test(url:String):void{
getWeb = new URLLoader2();
getWeb.loader.addEventListener(Event.COMPLETE,onComplete);
getWeb.load(url);
}
private function onComplete(e:Event):void{
var tf:TextField = new TextField();
tf.text = getWeb.loader.data;
addChild(tf);
tf.type = "input";
tf.width= 300;
tf.height = 200;
tf1.text = "onComplete";
}
private function onKey(e:KeyboardEvent):void{
/* if(e.keyCode == 13){
var url2:String = "http://wonderfl.net/c/oTEF";
var url:String = "http://ja.wikipedia.org/wiki/%E3%83%A1%E3%82%A4%E3%83%B3%E3%83%9A%E3%83%BC%E3%82%B8"
test(url2);
}*/
if(e.keyCode == 13){
var url2:String = "http://wonderfl.net/c/oTEF";
var url3:String = "http://192.168.11.7/getHtml.php";
//var url:String = "http://ja.wikipedia.org/wiki/%E3%83%A1%E3%82%A4%E3%83%B3%E3%83%9A%E3%83%BC%E3%82%B8"
var url:String = tf1.text;
//var url:String = "http://swf.wonderfl.net/swf/usercode/8/8e/8ee2/8ee286728102a724f2e014e4fa101e1ad2e39806.swf";
//パラメータ
var param:URLVariables = new URLVariables();
param.url = url;
var req:URLRequest = new URLRequest(url3);
req.method = URLRequestMethod.POST;//ポストメソッド
req.data = param;
//var loader:Loader = new Loader();
var urlLoad:URLLoader = new URLLoader();
urlLoad.addEventListener(Event.COMPLETE,function(e:Event):void{
var tf:TextField = new TextField();
tf.text = urlLoad.data;
//tf.width = tf.textWidth;
//tf.height = tf.textHeight;
//node1.map.addChild(tf);
addChild(tf);
tf.type = "input";
tf.width= 300;
tf.height = 200;
tf.border = true;
tf1.text = "onComplete";
});
urlLoad.load(req);
//loader.load(req);
//node1.map.addChild(loader);
//loader.x = 400;//node1.scrX;
//loader.y = -100;//node1.scrY;
tf1.text = "";
}//*/
}
}
}
import flash.net.*;
class URLLoader2{
public var loader:URLLoader;
public function URLLoader2(){
}
public function load(url:String):void{
var param:URLVariables = new URLVariables();
param.url = url;
const url2:String = "http://192.168.11.7/getHtml.php";
var req:URLRequest = new URLRequest(url2);
req.method = URLRequestMethod.POST;//ポストメソッド
req.data = param;
loader = new URLLoader();
//loader.addEventListener(Event.COMPLETE,onComplete);
loader.load(req);
}
}
//------ ozmap ------------------------------------------------------------------------
import flash.geom.Point;
import caurina.transitions.Tweener;
import flash.display.*;
import flash.text.*;
import flash.events.*;
import flash.ui.*;
import flash.utils.*;
class ozmap extends Sprite{//======================================================
private var scale:Number = 1;
public var wheel:int;//ホイール回転量
private var zoom:Number = 1.0;//拡大率
private var objStack:Array = new Array();
private var mapFocusX:Number=0;
private var mapFocusY:Number=0;
private var scrFocusX:int=0;
private var scrFocusY:int=0;
public var map:Sprite = new Sprite();//フィールド
private var scalingPanel:Sprite = new Sprite();//ズーム、回転中心
private var base:Sprite = new Sprite();//
private var dragPanel:Sprite = new Sprite();//フィールドドラッグ用。マップへのマウス操作を受け取る
private var mapscale:int=0;
//ozmap状態フラグ
private const testMode:Boolean = false;//テスト表示
private var mapBrowseMode:Boolean;//マップ移動操作
private var mapDragMode:Boolean;//マップドラッグ中はtrue
private var mapRotationMode:Boolean;//マップ回転操作
private var endZoomOut:int = 20;
private var endZoomIn:int = -20;
//コンストラクタ
public function ozmap():void{//-----------------------------
if(testMode == true){
//drawTestLine();
}
addChild(scalingPanel);
scalingPanel.addChild(base);
map.addChild(dragPanel);
base.addChildAt(map,0);
dragPanel.doubleClickEnabled = true;
browseOn();
update();
}
private function drawTestLine():void{
var t1:TextField = new TextField();
t1.textColor = 0x00ff00;
t1.selectable = false;
t1.y = -20;
t1.text = "scalingPanel";
scalingPanel.addChild(t1);
scalingPanel.graphics.lineStyle(1,0x00ff00,0.7);
scalingPanel.graphics.moveTo(-100,0);
scalingPanel.graphics.lineTo(100,0);
scalingPanel.graphics.moveTo(0,-100);
scalingPanel.graphics.lineTo(0,100);
var t2:TextField = new TextField();
t2.textColor = 0xff0000;
t2.selectable = false;
t2.y = -20;
t2.text = "base";
base.addChild(t2);
base.graphics.lineStyle(1,0xff0000,0.7);
base.graphics.moveTo(-100,0);
base.graphics.lineTo(100,0);
base.graphics.moveTo(0,-100);
base.graphics.lineTo(0,100);
var t3:TextField = new TextField();
t3.textColor = 0x0000ff;
t3.selectable = false;
t3.y = -20;
t3.text = "map 0,0";
map.addChild(t3);
map.graphics.lineStyle(1,0x0000ff,0.7);
map.graphics.moveTo(-100,0);
map.graphics.lineTo(100,0);
map.graphics.moveTo(0,-100);
map.graphics.lineTo(0,100);
var t4:TextField = new TextField();
t4.textColor = 0xff00ff;
t4.selectable = false;
t4.y = -40;
t4.text = "dragPanel 0,0";
dragPanel.addChild(t4);
var line:Shape = new Shape();
line.graphics.lineStyle(1,0xff00ff,0.5);
line.graphics.moveTo(-100,0);
line.graphics.lineTo(100,0);
line.graphics.moveTo(0,-100);
line.graphics.lineTo(0,100);
dragPanel.addChild(line);
}
public function get scrX():Number{
return map.mouseX;
}
public function get scrY():Number{
return map.mouseY;
}
public function get scaleSize():int{//-----------------------------
return mapscale;
}
//マップ移動操作状態
public function get IsBrowseMode():Boolean{//-----------------------------
return mapBrowseMode;
}
//マップドラッグスクロール状態
public function get IsDragMode():Boolean{//-----------------------------
return mapDragMode;
}
//マップ回転操作状態
public function get IsRotationMode():Boolean{//-----------------------------
return mapRotationMode;
}
//
public function returnHome():void{//-----------------------------
map.x = 0;
map.y = 0;
map.scaleX = map.scaleY = 1.0;
mapscale = 0;
update();
}
//画面移動操作の受付 ON・OFF切り替え
public function browseOn():void{//-----------------------------
mapBrowseMode = true;
//Mouse.hide();
map.addEventListener(MouseEvent.MOUSE_DOWN,down1);
map.addEventListener(MouseEvent.MOUSE_UP,up1);
dragPanel.addEventListener(MouseEvent.DOUBLE_CLICK,onDouble);
this.addEventListener(MouseEvent.MOUSE_WHEEL,on_wheel,true);//ホイール操作
this.addEventListener(MouseEvent.MOUSE_MOVE,onMove)
map.addChild(dragPanel);
}
public function browseOff():void{//-----------------------------
wheel = 0;
mapBrowseMode = false;
//Mouse.show();
map.removeEventListener(MouseEvent.MOUSE_DOWN,down1);
map.removeEventListener(MouseEvent.MOUSE_UP,up1);
dragPanel.removeEventListener(MouseEvent.DOUBLE_CLICK,onDouble);
this.removeEventListener(MouseEvent.MOUSE_WHEEL,on_wheel,true);//ホイール操作
map.removeChild(dragPanel);
}
//ダブルクリックでマップブラウズモード解除 ⇒ オブジェクト操作モードに移行
private function onDouble(e:MouseEvent):void{//-----------------------------
browseOff();
//ホイール操作でブラウズモードに移行
stage.addEventListener(MouseEvent.MOUSE_WHEEL,function():void{
browseOn();
});
}
//マップドラッグ
private function down1(e:MouseEvent):void{//-----------------------------
wheel=0;//ズーム操作ストップ
e.currentTarget.startDrag();
addEventListener(MouseEvent.MOUSE_MOVE,onMove);
stage.removeEventListener(Event.ENTER_FRAME,onFrame);
e.stopPropagation();//イベントの伝播を止める
}
private function up1(event:MouseEvent):void{//-----------------------------
event.currentTarget.stopDrag();
removeEventListener(MouseEvent.MOUSE_MOVE,onMove);
event.stopPropagation();//イベントの伝播を止める
}
//マップドラッグ中
private function onMove(e:MouseEvent):void{//-----------------------------
update();
}
//ホイール操作
private function on_wheel(event:MouseEvent):void{//-----------------------------
wheel += event.delta;
if(wheel != 0)addEventListener(Event.ENTER_FRAME,onFrame);
//else removeEventListener(Event.ENTER_FRAME,onFrame);
}
private function onFrame(e:Event):void {//-----------------------------
//from on_wheel1
if(wheel==0)removeEventListener(Event.ENTER_FRAME,onFrame);
on_zoom(1+(0.005*wheel));
}
//マップ表示位置を更新
private function update(z:Number=1, x:Number=0, y:Number=0, a:Number=0):void{//-----------------------------
var mX:int,mY:int;//ズーム中心位置
if(1<=z){//ズームイン
mX = mouseX;
mY = mouseY;//カーソル位置
}
else{//ズームアウト
mX = this.root.loaderInfo.width/2;
mY = this.root.loaderInfo.height/2;//カーソル位置
}
//ズーム中心更新
scalingPanel.x = mX;
scalingPanel.y = mY;
//マップ位置更新
base.x -= (mX-scrFocusX)/zoom;
base.y -= (mY-scrFocusY)/zoom;
//フォーカス位置更新
scrFocusX = mX;
scrFocusY = mY;
//フィールドドラッグ用
dragPanel.graphics.clear();
dragPanel.graphics.beginFill(0x00ffff,0);
var x1:Number = (map.x+map.parent.x)/map.scaleX;
//var x2:Number = (map.x+map.parent.x)/zoom;
var y1:Number = (map.y+map.parent.y)/map.scaleY;
//var r1:Number = 600/map.scaleX;
var r2:Number = 300/(zoom*map.scaleX);
dragPanel.graphics.drawCircle(-x1,-y1,r2);
dragPanel.graphics.endFill();
//グリッドライン
if(testMode == true){
var i:int;
var c:uint = 0x00aa00;
const j:int = 32;
for(i= -20-(map.y/j);i<20-(map.y/j);i++){
if(Math.abs(i)%2 == 1)dragPanel.graphics.lineStyle(0,c,(zoom*0.5)-0.5);
else dragPanel.graphics.lineStyle(0,c,0.5);
dragPanel.graphics.moveTo((-600-map.x)/map.scaleX , i*j/map.scaleX);
dragPanel.graphics.lineTo((1600-map.x)/map.scaleX , i*j/map.scaleX);
}
for(i=-20-(map.x/j);i<20-(map.x/j);i++){
if(Math.abs(i)%2 == 1)dragPanel.graphics.lineStyle(0,c,(zoom*0.5)-0.5);
else dragPanel.graphics.lineStyle(0,c,0.5);
dragPanel.graphics.moveTo(i*j/map.scaleX, (-600-map.y)/map.scaleX);
dragPanel.graphics.lineTo(i*j/map.scaleX, (1600-map.y)/map.scaleX);
}
}
}
private function movObj1(obj:Sprite):void{
//zoomとの差を計算
//zoom
var n1:Number = zoom;
//縮尺補正
map.scaleX = map.scaleY;
zoom;
//座標補正
map.x;
map.y;
}
private function on_zoom(z:Number=0):void{//-----------------------------
if(z==0)return;
update(z);//基準点更新
//ズーム範囲を超えたスケーリング停止
if(z>1 && endZoomIn > mapscale) wheel = 0;
else if(z<1 && endZoomOut < mapscale) wheel = 0;
else zoom *= z;//ズーム
//オブジェクトの座標、サイズ、角度を補正
if(8 < zoom){
map.scaleX *= 2;
map.scaleY *= 2;
zoom /= 2;
map.x += map.x+base.x;
map.y += map.y+base.y;
mapscale--;
map.scaleX *= 2;
map.scaleY *= 2;
zoom /= 2;
map.x += map.x+base.x;
map.y += map.y+base.y;
mapscale--;
map.scaleX *= 2;
map.scaleY *= 2;
zoom /= 2;
map.x += map.x+base.x;
map.y += map.y+base.y;
mapscale--;
}
else if(zoom < 0.25){
map.x -= (map.x+base.x)/2;
map.y -= (map.y+base.y)/2;
zoom *= 2;
map.scaleX /= 2;
map.scaleY /= 2;
mapscale++;
map.x -= (map.x+base.x)/2;
map.y -= (map.y+base.y)/2;
zoom *= 2;
map.scaleX /= 2;
map.scaleY /= 2;
mapscale++;
map.x -= (map.x+base.x)/2;
map.y -= (map.y+base.y)/2;
zoom *= 2;
map.scaleX /= 2;
map.scaleY /= 2;
mapscale++;
}
scalingPanel.scaleX = zoom;
scalingPanel.scaleY = zoom;
}
}
//------------------------------------------------------