var*_*ran 5 javascript flash google-chrome params
我使用下面的函数创建一个显示flash对象的代码.原始闪存大小为320x240,但我想将其显示为200x150,因此我使用params宽度为200,高度为150的函数.所有浏览器都能正常工作,但chrome不能.它显示为200x151(检查代码显示200x151大小).为什么?
function getFlashCode(params)
{
debug('getFlashCode');
var defaultParams = {movie: '', flashvars: {}, width:'', height: ''};
for (var key in defaultParams)
{
if (params[key] === undefined)
params[key] = defaultParams[key];
}
var flashvars = '';
for (var key in params.flashvars)
flashvars += encodeURIComponent(key) + '=' + encodeURIComponent(params.flashvars[key]) + '&';
var id = "fl" + Math.random();
var code="";
code += " <object classid=\"clsid:d27cdb6e-ae6d-11cf-96b8-444553540000\" width=\"" + params.width + "\" height=\"" + params.height + "\" align=\"middle\" id=\"" + id + "\">";
code += " <param name=\"movie\" value=\"" + params.movie + "\" \/>";
code += " <param name=\"quality\" value=\"high\" \/>";
code += " <param name=\"play\" value=\"true\" \/>";
code += " <param name=\"loop\" value=\"true\" \/>";
code += " <param name=\"wmode\" value=\"transparent\" \/>";
code += " <param name=\"scale\" value=\"showall\" \/>";
code += " <param name=\"menu\" value=\"true\" \/>";
code += " <param name=\"devicefont\" value=\"false\" \/>";
code += " <param name=\"salign\" value=\"\" \/>";
code += " <param name=\"allowScriptAccess\" value=\"always\" \/>";
code += " <param name=\"flashvars\" value=\"" + flashvars + "\" \/>";
code += " <!--[if !IE]>-->";
code += " <object type=\"application\/x-shockwave-flash\" flashvars=\""+ flashvars + "\" data=\"" + params.movie + "\" width=\"" + params.width + "\" height=\"" + params.height + "\">";
code += " <param name=\"movie\" value=\"" + params.movie + "\" \/>";
code += " <param name=\"quality\" value=\"high\" \/>";
code += " <param name=\"play\" value=\"true\" \/>";
code += " <param name=\"loop\" value=\"true\" \/>";
code += " <param name=\"wmode\" value=\"transparent\" \/>";
code += " <param name=\"scale\" value=\"showall\" \/>";
code += " <param name=\"menu\" value=\"true\" \/>";
code += " <param name=\"devicefont\" value=\"false\" \/>";
code += " <param name=\"salign\" value=\"\" \/>";
code += " <param name=\"allowScriptAccess\" value=\"always\" \/>";
code += " <param name=\"flashvars\" value=\"" + flashvars + "\" \/>";
code += " <\/object>";
code += " <!--<![endif]-->";
code += " <\/object>";
return code;
}
Run Code Online (Sandbox Code Playgroud)
首先,该代码相当难以阅读,并且您会遇到一些问题。就像 Kos 所说,我强烈建议您使用swfobject来嵌入 Flash 文件,因为它可以处理所有浏览器的怪异问题。此外,大多数参数都不需要,因为它们的默认值已经是指定的。这是我推荐的方法:
<script type="text/javascript" src="swfobject.js"></script>
<script type="text/javascript">
var flashvars = {};
var params = {};
var attributes = {};
swfobject.embedSWF("filename.swf", "div-id-here", "200", "150", "9.0.0","expressInstall.swf", flashvars, params, attributes);
</script>
Run Code Online (Sandbox Code Playgroud)
然后,您只需添加带有您在 javascript 代码中指定和设置的 id 的 div 元素即可。我还必须提到我立即看到的一个问题:300/240 的宽度/高度比是 1.25,200/150 的宽度/高度比是 1.333,这意味着除非闪光灯进行缩放并根据周围的情况更改元素在大小方面,您的 Flash 影片将有边框,以保持其应有的比例,除非您更改缩放模式(这showall不是潜在的选项之一)。
我不知道闪存是如何编程的,也不知道您到底想做什么,但我将让您自行尝试并阅读Adobe 网站上的参数文档。