错误:源路径不存在:resources\android\icon\drawable-hdpi-icon.png
Posted
技术标签:
【中文标题】错误:源路径不存在:resources\\android\\icon\\drawable-hdpi-icon.png【英文标题】:Error: Source path does not exist: resources\android\icon\drawable-hdpi-icon.png错误:源路径不存在:resources\android\icon\drawable-hdpi-icon.png 【发布时间】:2016-09-26 14:27:36 【问题描述】:我正在尝试在 Mac 上使用“cordova build --release android
”命令从 Ionic 项目中获取 APK 文件,但由于出现此错误,它无法正常工作
“错误:源路径不存在: 资源\android\icon\drawable-hdpi-icon.png"
。 有谁知道它可能来自哪里?
这是 config.xml 文件的副本:
<?xml version='1.0' encoding='utf-8'?>
<widget id="com.ionicframework.rise268787" version="1.0.0" xmlns="http://www.w3.org/ns/widgets" xmlns:cdv="http://cordova.apache.org/ns/1.0">
<name>RISE</name>
<description>
Discover music as you go
</description>
<author email="infos@olivierlam.fr" href="http://olivierlam.fr/">
Olivier Lam
</author>
<content src="index.html" />
<access origin="*" />
<preference name="webviewbounce" value="false" />
<preference name="UIWebViewBounce" value="false" />
<preference name="DisallowOverscroll" value="true" />
<preference name="SplashScreen" value="screen" />
<preference name="orientation" value="portrait" />
<preference name="SplashScreenDelay" value="1000" />
<preference name="android-minSdkVersion" value="16" />
<preference name="BackupWebStorage" value="none" />
<preference name="SplashScreen" value="screen" />
<preference name="SplashScreenDelay" value="1000" />
<feature name="StatusBar">
<param name="ios-package" onload="true" value="CDVStatusBar" />
</feature>
<platform name="android">
<preference name="android-minSdkVersion" value="23" />
<preference name="android-targetSdkVersion" value="23" />
<icon density="ldpi" src="resources\android\icon\drawable-ldpi-icon.png" />
<icon density="mdpi" src="resources\android\icon\drawable-mdpi-icon.png" />
<icon density="hdpi" src="resources\android\icon\drawable-hdpi-icon.png" />
<icon density="xhdpi" src="resources\android\icon\drawable-xhdpi-icon.png" />
<icon density="xxhdpi" src="resources\android\icon\drawable-xxhdpi-icon.png" />
<icon density="xxxhdpi" src="resources\android\icon\drawable-xxxhdpi-icon.png" />
<splash density="port-ldpi" src="resources\android\splash\drawable-port-ldpi-screen.png" />
<splash density="port-mdpi" src="resources\android\splash\drawable-port-mdpi-screen.png" />
<splash density="port-hdpi" src="resources\android\splash\drawable-port-hdpi-screen.png" />
<splash density="port-xhdpi" src="resources\android\splash\drawable-port-xhdpi-screen.png" />
<splash density="port-xxhdpi" src="resources\android\splash\drawable-port-xxhdpi-screen.png" />
<splash density="port-xxxhdpi" src="resources\android\splash\drawable-port-xxxhdpi-screen.png" />
</platform>
<platform name="ios">
<icon src="resources/ios/icon/icon.png" />
<icon src="resources/ios/icon/icon@2x.png" />
<icon src="resources/ios/icon/icon-40.png" />
<icon src="resources/ios/icon/icon-40@2x.png" />
<icon src="resources/ios/icon/icon-40@3x.png" />
<icon src="resources/ios/icon/icon-50.png" />
<icon src="resources/ios/icon/icon-50@2x.png" />
<icon src="resources/ios/icon/icon-60.png" />
<icon src="resources/ios/icon/icon-60@2x.png" />
<icon src="resources/ios/icon/icon-60@3x.png" />
<icon src="resources/ios/icon/icon-72.png" />
<icon src="resources/ios/icon/icon-72@2x.png" />
<icon src="resources/ios/icon/icon-76.png" />
<icon src="resources/ios/icon/icon-76@2x.png" />
<icon src="resources/ios/icon/icon-83.5@2x.png" />
<icon src="resources/ios/icon/icon-small.png" />
<icon src="resources/ios/icon/icon-small@2x.png" />
<icon src="resources/ios/icon/icon-small@3x.png" />
<splash src="resources/ios/splash/Default-568h@2x~iphone.png" />
<splash src="resources/ios/splash/Default-667h.png" />
<splash src="resources/ios/splash/Default-736h.png" />
<splash src="resources/ios/splash/Default-Portrait@2x~ipad.png" />
<splash src="resources/ios/splash/Default-Portrait~ipad.png" />
<splash src="resources/ios/splash/Default@2x~iphone.png" />
<splash src="resources/ios/splash/Default~iphone.png" />
</platform>
<icon src="resources/ios/icon/icon-small@3x.png" />
<plugin name="cordova-plugin-facebook4" spec="~1.7.1">
<variable name="APP_ID" value="XXXXXXX" />
<variable name="APP_NAME" value="Rise" />
</plugin>
<allow-intent href="mailto:*" />
<allow-navigation href="*.youtube.com" />
<plugin name="cordova-plugin-whitelist" spec="~1.2.2" />
感谢您的帮助。
【问题讨论】:
您能否验证该文件是否在您的项目文件夹中。签入 www 文件夹外的资源文件夹。 是的,它在 ressources\android\icon 文件夹中。 验证名为 drawable-hdpi-icon.png 的文件是否在您的资源文件夹中,如路径:resources\android\icon\drawable-hdpi-icon.png
是的,它在里面。
你能添加一份你的项目的config.xml文件吗?
【参考方案1】:
我有同样的错误,运行后
离子资源
或者
离子科尔多瓦资源
(基于您的应用程序的离子版本)
它消失了。
问题是我在图标的路径中有 Windows 样式的斜杠(反斜杠),即我遇到的错误是这样的:
错误:源路径不存在: 资源\android\icon\drawable-hdpi-icon.png
因此,将反斜杠转换为斜杠为我解决了这个问题。
希望这对您和其他寻找相同问题的人有所帮助。这一切都是因为使用不同的机器[mac和windows]来开发像mac和windows这样的项目。
【讨论】:
我有同样的错误,但帮助在此链接github.com/ionic-team/ionic-cli/issues/2355 PeterWahba 的回答于 5 月 30 日发表评论ionic resources
为我解决了这个问题。此命令将为项目中的每个平台设置生成图标和启动屏幕图像。文档:ionicframework.com/docs/cli/cordova/resources
Ionic 3 中的命令已更新为 ionic cordova resources
需要登录才能执行ionic cordova资源。在构建服务器上,您需要先运行 ionic login USERNAME PASSWORD
这对我也有用(离子科尔多瓦资源)【参考方案2】:
您可以通过运行再次添加资源:
ionic integrations enable cordova --add
【讨论】:
【参考方案3】:问题是因为你有:
<preference name="Orientation" value="portrait" />
在您的config.xml
中,当您运行ionic cordova resources
时,它只会生成纵向资源。
【讨论】:
【参考方案4】:不要忘记在resources
文件夹中添加文件。
理想情况下,图标的源图像应至少为 1024×1024px,并位于 resources/icon.png
。初始屏幕的源图像理想情况下应至少为 2732×2732px,并位于resources/splash.png
。如果你使用了 ionic start,resources/ 目录下应该已经有默认的 Ionic 资源,你可以覆盖它。
您需要使用以下格式:.png
、.psd
或 .ai
。
您可以使用https://code.ionicframework.com/resources/splash.psd 作为初始屏幕模板,使用https://code.ionicframework.com/resources/icon.psd 作为图标。
【讨论】:
【参考方案5】:在config.xml中,我把resources/android/icon/drawable-hdpi.png改成了resources resources\android\icon\drawable-hdpi.png
注意斜线的变化。
【讨论】:
【参考方案6】:从 config.xml 中删除所有资源标签并运行 ionic cordova resources -f
。它将自动生成所有必要的资源和标签。您应该能够构建应用程序。
【讨论】:
【参考方案7】:我使用类似于Fakan的方式解决了错误。您只需将平台标签外带有 src="resources\android\icon\drawable-hdpi.png" 的图标标签更改为 "resources\icon.png" 即可解决此错误
【讨论】:
【参考方案8】:尝试在 Ionic 结构中找到该资源的路径。 有时,或在某些版本中,这条路径可能是这样的:
您的资源:
resources/android/icon/drawable-hdpi.png
试试这个:
res/android/icon/drawable-hdpi.png
【讨论】:
【参考方案9】:检查您的图标是否实际保存为“.png”。不像“.PNG”。右键单击它并点击属性。
如果不是,请编辑您的图标并将其保存为文件扩展名“.png”。
【讨论】:
【参考方案10】:只需删除 config.xml 文件中的 <preference name="Orientation" value="portrait" />
并运行 ionic cordova 资源。
问题是当您运行 ionic cordova 资源时,它只会生成纵向资源。
【讨论】:
【参考方案11】:只需编辑您的 config.xml 文件。我的看起来像这样:
<platform name="android">
<splash density="hdpi" src="res/screen/android/screen-hdpi-landscape.png" />
<splash density="port-hdpi" src="res/screen/android/screen-hdpi-portrait.png" />
<splash density="ldpi" src="res/screen/android/screen-ldpi-landscape.png" />
<splash density="port-ldpi" src="res/screen/android/screen-ldpi-portrait.png" />
<splash density="mdpi" src="res/screen/android/screen-mdpi-landscape.png" />
<splash density="port-mdpi" src="res/screen/android/screen-mdpi-portrait.png" />
<splash density="xhdpi" src="res/screen/android/screen-xhdpi-landscape.png" />
<splash density="port-xhdpi" src="res/screen/android/screen-xhdpi-portrait.png" />
</platform>
注意 res/ 是相对于项目根目录的。最后的文件名可能不同。
【讨论】:
【参考方案12】:一个快速的替代答案:
Error: Source path does not exist: resources\android\icon\drawable-hdpi-icon.png
是一样的
Error: Source path does not exist: resources\android\icon\foreground-hdpi-icon.png
或
Error: Source path does not exist: resources\android\icon\background-hdpi-icon.png
以及该类别中的任何其他人
该命令查找基本文件,即 icon-drawable.png | icon-foreground.png | icon-background.png
在 android/resources 位置,所以最好将这些图像包含在 android/resources 中,然后重新运行 cordova build --release android
或 ionic cordova resources android
进行检查 p>
【讨论】:
【参考方案13】:我解决这个问题的方法奏效了,但有点奇怪。
我创建了以下文件并将它们放在“资源”目录中:
icon.png、icon.jpg、icon.jpeg、splash.png、splash.jpg、splash.jpeg。
如果您使用 --verbose,它会告诉您每个文件必须具有的维度。例如,icon.png 必须有 512x512 像素。并且 splash.png 必须有 1920x1920 像素。
【讨论】:
【参考方案14】:在config.xml中,我把resources\android\icon\drawable-hdpi.png改成了resources\android\icon\drawable-hdpi.png
【讨论】:
这两条路径完全相同 这些是一样的以上是关于错误:源路径不存在:resources\android\icon\drawable-hdpi-icon.png的主要内容,如果未能解决你的问题,请参考以下文章
ColdFusion CFFILE 重命名属性验证错误,属性源的值无效,即使文件存在且路径正确
Flask“错误:提供的文件/路径似乎不存在”,尽管该文件确实存在