【问题标题】:Can I load images before java applet loader disappears?我可以在 java 小程序加载器消失之前加载图像吗?
【发布时间】:2013-08-31 04:46:53
【问题描述】:

我在 Java Applet 中创建了一个简单的记忆游戏。我有一个自定义加载程序(在特殊的小程序属性中添加为 gif - docs.oracle.com/.../special_attributes.html)的问题,它消失得太快,留下白屏几秒钟。

index.html

(...)
<body>
    <center>
    <script src="http://www.java.com/js/deployJava.js"></script>
    <script>
        var attributes = {code:'(...).Memo.class', archive:'Memo.jar', width: 1200, height: 900}; 
        var parameters = {image: 'res/loading0.gif', boxbgcolor: 'white', boxborder: 'false', centerimage: 'true'}; 
        deployJava.runApplet(attributes, parameters, '1.6'); 
    </script>
    <noscript>
        (...)
    </noscript>
    <script type="text/javascript" language="JavaScript" src="http://www.oracle.com/ocom/groups/systemobject/@mktg_admin/documents/systemobject/s_code_download.js"></script>
    <script type="text/javascript" language="JavaScript" src="http://www.oracle.com/ocom/groups/systemobject/@mktg_admin/documents/systemobject/s_code.js"></script>
    <script type="text/javascript" language="javascript">var s_code=s.t();if(s_code)document.write(s_code)</script>
    </center>
</body>
(...)

此加载程序在小程序警告消息后立即消失,但我仍需要加载一些图像,这需要一些时间。我该如何解决?

Memo.cs - 加载图片的主类

public class Memo extends JApplet {

    //...   

    public void init() {
        //...   
        try {
            SwingUtilities.invokeAndWait(new Runnable() { @Override public void run() { createGUI(); }});
        } 
        catch(Exception e) {
            e.printStackTrace();
        }
    }

    private void createGUI() {
        final Model model = new Model(...);
        final View view = new View(model);

        getContentPane().add(view, BorderLayout.CENTER);
        setBackground(backgroundColor);
        setPreferredSize(new Dimension(width, height));

        model.setLoading(loadImages(loadingPath, format, 1));
        model.setCardsImages(loadImages(cardImagePath, format, 13));
        //...
        model.setAppState(AppStates.PROCESS);

        model.startNewGame();
        view.repaint();
    }

    private Image[] loadImages(String path1, String path2, int count) {
        Image[] imgs = new Image[count];        
        for(int i = 0; i < count; ++i) {
            imgs[i] = getImage(getCodeBase(), path1 + i + path2);
        }
        return imgs;
    }
}

------- 解决方案-------

媒体跟踪​​器效果不佳,因此我尝试使用 JavaScript。这是我的代码:

index.html 中的新函数(head)

    <script language="javascript" type="text/javascript">
        function setApplet() 
        {
            document.getElementById('loader').innerHTML = "";
        }
    </script>

index.html 中的加载器 div 和小程序 div(正文)

  • loading.gif 是一个动画加载器图标
  • loading0.gif 是一个假加载器图标 - 1x1 图像 - 设置为隐藏默认 java 加载器

小程序在准备好之前也是空白的。

        <div id="loader" style="font-size: 14pt; font-weight: bold;">
            <p>Loading... Please wait</p>
            <img src="res/loading.gif" alt="Loading... Please wait" />
        </div>
        <div id="applet">
            <script src="http://www.java.com/js/deployJava.js"></script>
            <script>
                var attributes = {code:'(...).Memo.class', archive:'Memo.jar', width: 1200, height: 900}; 
                var parameters = {image: 'res/loading0.gif', boxbgcolor: 'white', boxborder: 'false', centerimage: 'true'}; 
                deployJava.runApplet(attributes, parameters, '1.6'); 
            </script>
            (...)
        </div>

Memo.cs 中的新功能

    private void runJs() throws JSException, Exception {
        JSObject setApplet = null;
        setApplet = (JSObject) JSObject.getWindow(this);
        setApplet.call("setApplet", null);
    }

【问题讨论】:

    标签: java html image applet


    【解决方案1】:

    我认为在这里获得成功的最佳机会可以通过级联样式表和 JavaScript 来实现。

    CSS

    将小程序加载到设置了适当大小的元素中,但在页面上不可见的绝对位置。例如。 x = -2000 像素,y = -2000 像素。同时,显示一个固定大小(与小程序相同)div 元素,小程序将出现在其中。屏幕上的元素显示 '正在加载..' 图像。

    JS

    让 JS 轮询 applet 的公共方法,该方法在准备就绪时设置为 true。当该方法返回 true 时,交换小程序的样式(确定位置)和 '正在加载..' 元素。

    【讨论】:

    • 针对这种情况的注意事项:Applet.getImage(..) 方法异步加载图像,因此确定“就绪”可能需要MediaTracker。还有其他方法可以在阻塞的小程序中加载图像(同步)。
    • CSS/JS 的想法很有趣,但有点乱。我喜欢Applet.getImage(..) 方法和MediaTracker 的第二个想法。我要检查一下。谢谢。
    • “CSS/JS 的想法很有趣,但有点乱。” 从“小程序”开始,你已经有了“乱”。相信我。
    • 确实如此,我刚刚想通了。 :) 但是我想结束这个项目,你的建议会很有用。
    猜你喜欢
    • 2013-07-26
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-11-10
    • 2013-09-15
    • 2019-10-28
    • 1970-01-01
    相关资源
    最近更新 更多