Java LibGDX安卓应用程序可以找到除我的XML级文件以外的任何文件

Java LibGDX安卓应用程序可以找到除我的XML级文件以外的任何文件,java,android,xml,filenotfoundexception,libgdx,Java,Android,Xml,Filenotfoundexception,Libgdx,基本上,我有一个libgdx用户界面,它链接到从XML解释器构建的级别文件。在桌面上,应用程序运行良好。但是当我在手机上运行它时,它找不到level.xml文件。是的,它们在资产文件夹中,UI和音乐也在其中。UI和音乐都工作得很好,但是当点击按钮开始关卡时,我得到了空指针,它崩溃了,因为它因为一些奇怪的原因找不到文件 下面是我指定文件路径的代码。Gdx.files.internal引用资产文件夹。在XML解释器的构造函数中,实际设置文件路径的位置。下面的代码正是我指定XML解释器对象的地方 pu

基本上,我有一个libgdx用户界面,它链接到从XML解释器构建的级别文件。在桌面上,应用程序运行良好。但是当我在手机上运行它时,它找不到level.xml文件。是的,它们在资产文件夹中,UI和音乐也在其中。UI和音乐都工作得很好,但是当点击按钮开始关卡时,我得到了空指针,它崩溃了,因为它因为一些奇怪的原因找不到文件

下面是我指定文件路径的代码。Gdx.files.internal引用资产文件夹。在XML解释器的构造函数中,实际设置文件路径的位置。下面的代码正是我指定XML解释器对象的地方

public class Level1 extends Level
{
public Level1(Game game) 
{
    super(game);
}

ObjectCreator oc;
int startX;
int startY;

@Override
protected void createWorld(World world) 
{
    super.setLevelNum(1);
    oc = new ObjectCreator(world);
    XMLInterpreter xml = new XMLInterpreter("data/xmlLevels/level 01.xml");
    try
    {
        xml.buildDocument();
    } 
    catch (ParserConfigurationException e)
    {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    catch (SAXException e) 
    {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }

    List<Line_xml> lines = xml.iterateLines();
    for(Line_xml line : lines){
        ObjectType ot = xml.getType(line.type);
        oc.createLine(ot, line.x1, line.y1, line.x2, line.y2, line.restitution);
    }

    List<Square_xml> squares = xml.iterateSquares();
    for(Square_xml square : squares)
    {
        ObjectType ot = xml.getType(square.type);
        oc.createBox(ot, square.height, square.width, square.pos_x, square.pos_y, 0);
    }

    List<Circle_xml> circles = xml.iterateCircles();
    for(Circle_xml circle : circles)
    {
        ObjectType ot = xml.getType(circle.type);
        startX = (int) circle.x;
        startY = (int) circle.y;
        oc.createCircle(ot, circle.radius, circle.x, circle.y, circle.friction, circle.restitution, circle.density);
    }
}
所有级别的xml文件都存储在filepath assets/data/xmlLevels中。我相信指定的文件路径是正确的,但logCat仍会打印以下内容:

08-04 12:22:43.401: WARN/System.err(7980): java.io.FileNotFoundException: /data/xmlFiles/level 01.xml (No such file or directory)
08-04 12:22:43.411: WARN/System.err(7980):     at org.apache.harmony.luni.platform.OSFileSystem.open(Native Method)
08-04 12:22:43.411: WARN/System.err(7980):     at dalvik.system.BlockGuard$WrappedFileSystem.open(BlockGuard.java:232)
08-04 12:22:43.411: WARN/System.err(7980):     at java.io.FileInputStream.<init>(FileInputStream.java:80)
08-04 12:22:43.411: WARN/System.err(7980):     at org.apache.harmony.luni.internal.net.www.protocol.file.FileURLConnection.connect(FileURLConnection.java:82)
08-04 12:22:43.411: WARN/System.err(7980):     at org.apache.harmony.xml.parsers.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:120)
08-04 12:22:43.411: WARN/System.err(7980):     at javax.xml.parsers.DocumentBuilder.parse(DocumentBuilder.java:183)
08-04 12:22:43.411: WARN/System.err(7980):     at edu.uab.cis.SMART.Wahball.xml.XMLInterpreter.buildDocument(XMLInterpreter.java:92)
08-04 12:22:43.411: WARN/System.err(7980):     at edu.uab.cis.SMART.Wahball.levels.Level1.createWorld(Level1.java:41)
08-04 12:22:43.411: WARN/System.err(7980):     at edu.uab.cis.SMART.Wahball.Level.create(Level.java:124)
08-04 12:22:43.411: WARN/System.err(7980):     at edu.uab.cis.SMART.Wahball.levels.Level1.render(Level1.java:135)
08-04 12:22:43.421: WARN/System.err(7980):     at com.badlogic.gdx.Game.render(Game.java:43)
08-04 12:22:43.421: WARN/System.err(7980):     at com.badlogic.gdx.backends.android.AndroidGraphics.onDrawFrame(AndroidGraphics.java:411)
08-04 12:22:43.421: WARN/System.err(7980):     at android.opengl.GLSurfaceView$GLThread.guardedRun(GLSurfaceView.java:1363)
08-04 12:22:43.421: WARN/System.err(7980):     at android.opengl.GLSurfaceView$GLThread.run(GLSurfaceView.java:1118)
08-04 12:22:43.431: WARN/dalvikvm(7980): threadid=9: thread exiting with uncaught exception (group=0x4001d5a0)

08-04 12:22:43.441: ERROR/AndroidRuntime(7980): FATAL EXCEPTION: GLThread 14
08-04 12:22:43.441: ERROR/AndroidRuntime(7980): java.lang.NullPointerException
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at edu.uab.cis.SMART.Wahball.xml.XMLInterpreter.iterateLines(XMLInterpreter.java:176)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at edu.uab.cis.SMART.Wahball.levels.Level1.createWorld(Level1.java:54)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at edu.uab.cis.SMART.Wahball.Level.create(Level.java:124)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at edu.uab.cis.SMART.Wahball.levels.Level1.render(Level1.java:135)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at com.badlogic.gdx.Game.render(Game.java:43)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at com.badlogic.gdx.backends.android.AndroidGraphics.onDrawFrame(AndroidGraphics.java:411)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at android.opengl.GLSurfaceView$GLThread.guardedRun(GLSurfaceView.java:1363)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at android.opengl.GLSurfaceView$GLThread.run(GLSurfaceView.java:1118)
08-04 12:22:43.401:WARN/System.err(7980):java.io.FileNotFoundException:/data/xmlFiles/level 01.xml(没有这样的文件或目录)
08-04 12:22:43.411:WARN/System.err(7980):位于org.apache.harmony.luni.platform.OSFileSystem.open(本机方法)
08-04 12:22:43.411:WARN/System.err(7980):位于dalvik.System.BlockGuard$WrappedFileSystem.open(BlockGuard.java:232)
08-04 12:22:43.411:WARN/System.err(7980):位于java.io.FileInputStream。(FileInputStream.java:80)
08-04 12:22:43.411:WARN/System.err(7980):位于org.apache.harmony.luni.internal.net.www.protocol.file.FileURLConnection.connect(FileURLConnection.java:82)
08-04 12:22:43.411:WARN/System.err(7980):位于org.apache.harmony.xml.parsers.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:120)
08-04 12:22:43.411:WARN/System.err(7980):位于javax.xml.parsers.DocumentBuilder.parse(DocumentBuilder.java:183)
08-04 12:22:43.411:WARN/System.err(7980):位于edu.uab.cis.SMART.Wahball.xml.XMLInterpreter.buildDocument(XMLInterpreter.java:92)
08-04 12:22:43.411:WARN/System.err(7980):位于edu.uab.cis.SMART.Wahball.levels.Level1.createWorld(Level1.java:41)
08-04 12:22:43.411:WARN/System.err(7980):位于edu.uab.cis.SMART.Wahball.Level.create(Level.java:124)
08-04 12:22:43.411:WARN/System.err(7980):位于edu.uab.cis.SMART.Wahball.levels.Level1.render(Level1.java:135)
08-04 12:22:43.421:WARN/System.err(7980):位于com.badlogic.gdx.Game.render(Game.java:43)
08-04 12:22:43.421:WARN/System.err(7980):位于com.badlogic.gdx.backends.android.AndroidGraphics.onDrawFrame(AndroidGraphics.java:411)
08-04 12:22:43.421:WARN/System.err(7980):位于android.opengl.GLSurfaceView$GLThread.guarderun(GLSurfaceView.java:1363)
08-04 12:22:43.421:WARN/System.err(7980):位于android.opengl.GLSurfaceView$GLThread.run(GLSurfaceView.java:1118)
08-04 12:22:43.431:WARN/dalvikvm(7980):threadid=9:线程退出时出现未捕获异常(组=0x4001d5a0)
08-04 12:22:43.441:错误/AndroidRuntime(7980):致命异常:GL14
08-04 12:22:43.441:错误/AndroidRuntime(7980):java.lang.NullPointerException
08-04 12:22:43.441:ERROR/AndroidRuntime(7980):位于edu.uab.cis.SMART.Wahball.xml.xmlprogrator.iterateLines(xmlprogrator.java:176)
08-04 12:22:43.441:ERROR/AndroidRuntime(7980):位于edu.uab.cis.SMART.Wahball.levels.Level1.createWorld(Level1.java:54)
08-04 12:22:43.441:ERROR/AndroidRuntime(7980):位于edu.uab.cis.SMART.Wahball.Level.create(Level.java:124)
08-04 12:22:43.441:ERROR/AndroidRuntime(7980):位于edu.uab.cis.SMART.Wahball.levels.Level1.render(Level1.java:135)
08-04 12:22:43.441:ERROR/AndroidRuntime(7980):位于com.badlogic.gdx.Game.render(Game.java:43)
08-04 12:22:43.441:ERROR/AndroidRuntime(7980):位于com.badlogic.gdx.backends.android.AndroidGraphics.onDrawFrame(AndroidGraphics.java:411)
08-04 12:22:43.441:ERROR/AndroidRuntime(7980):在android.opengl.GLSurfaceView$GLThread.guarderun(GLSurfaceView.java:1363)
08-04 12:22:43.441:ERROR/AndroidRuntime(7980):位于android.opengl.GLSurfaceView$GLThread.run(GLSurfaceView.java:1118)
关于这个问题,真正让我困惑的是,这个应用程序是访问UI的uiskin.xml!它正好在assets文件夹中,它的访问权限很好。两个xml文件的文件权限设置完全相同

任何与此相关的快速帮助都将不胜感激


如果你需要更多的信息,我很乐意为你效劳

尝试刷新资产文件夹。如果这没有帮助,请尝试清理项目(项目->清理)。有时Eclipse无法正确刷新文件夹中的文件。

您是否在桌面上使用Windows?请检查磁盘上的实际路径是否具有相同的字母大小写


我认为,如果磁盘上的文件夹名称是XmlLevels(大写“X”),您可能会面临同样的问题。

创建一个新项目!即使这段代码是正确的,但是语言本身误解了它

08-04 12:22:43.401: WARN/System.err(7980): java.io.FileNotFoundException: /data/xmlFiles/level 01.xml (No such file or directory)
08-04 12:22:43.411: WARN/System.err(7980):     at org.apache.harmony.luni.platform.OSFileSystem.open(Native Method)
08-04 12:22:43.411: WARN/System.err(7980):     at dalvik.system.BlockGuard$WrappedFileSystem.open(BlockGuard.java:232)
08-04 12:22:43.411: WARN/System.err(7980):     at java.io.FileInputStream.<init>(FileInputStream.java:80)
08-04 12:22:43.411: WARN/System.err(7980):     at org.apache.harmony.luni.internal.net.www.protocol.file.FileURLConnection.connect(FileURLConnection.java:82)
08-04 12:22:43.411: WARN/System.err(7980):     at org.apache.harmony.xml.parsers.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:120)
08-04 12:22:43.411: WARN/System.err(7980):     at javax.xml.parsers.DocumentBuilder.parse(DocumentBuilder.java:183)
08-04 12:22:43.411: WARN/System.err(7980):     at edu.uab.cis.SMART.Wahball.xml.XMLInterpreter.buildDocument(XMLInterpreter.java:92)
08-04 12:22:43.411: WARN/System.err(7980):     at edu.uab.cis.SMART.Wahball.levels.Level1.createWorld(Level1.java:41)
08-04 12:22:43.411: WARN/System.err(7980):     at edu.uab.cis.SMART.Wahball.Level.create(Level.java:124)
08-04 12:22:43.411: WARN/System.err(7980):     at edu.uab.cis.SMART.Wahball.levels.Level1.render(Level1.java:135)
08-04 12:22:43.421: WARN/System.err(7980):     at com.badlogic.gdx.Game.render(Game.java:43)
08-04 12:22:43.421: WARN/System.err(7980):     at com.badlogic.gdx.backends.android.AndroidGraphics.onDrawFrame(AndroidGraphics.java:411)
08-04 12:22:43.421: WARN/System.err(7980):     at android.opengl.GLSurfaceView$GLThread.guardedRun(GLSurfaceView.java:1363)
08-04 12:22:43.421: WARN/System.err(7980):     at android.opengl.GLSurfaceView$GLThread.run(GLSurfaceView.java:1118)
08-04 12:22:43.431: WARN/dalvikvm(7980): threadid=9: thread exiting with uncaught exception (group=0x4001d5a0)

08-04 12:22:43.441: ERROR/AndroidRuntime(7980): FATAL EXCEPTION: GLThread 14
08-04 12:22:43.441: ERROR/AndroidRuntime(7980): java.lang.NullPointerException
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at edu.uab.cis.SMART.Wahball.xml.XMLInterpreter.iterateLines(XMLInterpreter.java:176)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at edu.uab.cis.SMART.Wahball.levels.Level1.createWorld(Level1.java:54)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at edu.uab.cis.SMART.Wahball.Level.create(Level.java:124)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at edu.uab.cis.SMART.Wahball.levels.Level1.render(Level1.java:135)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at com.badlogic.gdx.Game.render(Game.java:43)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at com.badlogic.gdx.backends.android.AndroidGraphics.onDrawFrame(AndroidGraphics.java:411)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at android.opengl.GLSurfaceView$GLThread.guardedRun(GLSurfaceView.java:1363)
08-04 12:22:43.441: ERROR/AndroidRuntime(7980):     at android.opengl.GLSurfaceView$GLThread.run(GLSurfaceView.java:1118)