日期:2014-05-16  浏览次数:20378 次

关于vml的问题
function   test(mx,my)   {
var   cp   =   {
x:   mx,
y:   my
}
var   obj   =   document.all[ "map "];
var   drawObj   =   document.createElement( "div ");
drawObj.style.position   =   "absolute ";
drawObj.style.top   =   0;//obj.offsetTop;
drawObj.style.left   =   0;//obj.offsetLeft;
drawObj.style.width   =   obj.offsetWidth;
drawObj.style.height   =   obj.offsetHeight;
drawObj.style.backgroundColor   =   "transparent ";
drawObj.style.border   =   0;
drawObj.innerHTML   =   drawRound(cp,100,200,300, "red ");//drawRound实现画3个同心圆的功能
//alert(drawObj.innerHTML);
obj.appendChild(drawObj);
}

function   drawRound(centerPoint,   r1,   r2,   r3,   color)   {
var   sHtml   =   " ";
var   round   =   {
left:   0,
top:   0,
dia:   0
};

var   p   =   geo2screen(drawRound.container,drawRound.bound,centerPoint);
round.left   =   p.x   -   r1;
round.top   =   p.y   -   r1;
round.dia   =   2*r1;
sHtml   +=   ' <v:oval   filled=false   style= "position:absolute;top: '   +   round.top   +   ';left: '   +   round.left   +   ';width: '   +   round.dia   +   ';height: '   +   round.dia   +   ';z-index:7; "   strokeColor= '   +   color   +   '   /> '   +   "\n ";
round.left   =   p.x   -   r2;
round.top   =   p.y   -   r2;
round.dia   =   2*r2;
sHtml   +=   ' <v:oval   filled=false   style= "position:absolute;top: '   +   round.top   +   ';left: '   +   round.left   +   ';width: '   +   round.dia   +   ';height: '   +   round.dia   +   ';z-index:7; "   strokeColor= '   +   color   +   '   /> '   +   "\n ";
round.left   =   p.x   -   r3;
round.top   =   p.y   -   r3;
round.dia   =   2*r3;
sHtml   +=   ' <v:oval   filled=false   style= "position:absolute;top: '   +   round.top   +   ';left: '   +   round.left   +   ';width: '   +   round.dia   +   ';height: '   +   round.dia   +   ';z-index:7; "   strokeColor= '   +   color   +   '   /> '   +   "\n ";

return   sHtml;
}

function   geo2screen(container,bound,coord)   {
var   p   =   {
x:   0,
y:   0
};
p.x   =   (coord.x   -   bound.getMinX())*container.width/bound.getWidth();
p.y   =   (bound.getMaxY()   -   coord.y)*container.height/bound.getHeight();

return   p;
}

这样什么都不显示,如果是:
document.body.appendChild(drawObj);
则可以显示,为什么会这样?如果要将圆画在任意对象上应该怎么做?


------解决方案--------------------
全部都是function,总要有个调用才能画啊