错误:源路径不存在:resources \ android \ icon \ drawable-hdpi-icon.png

时间:2016-09-26 14:27:36

标签: android angularjs cordova ionic-framework apk

我试图通过" cordova build --release android"从Ionic项目获取APK文件。 Mac 上的命令,当我收到此错误时它不起作用

  

"错误:源路径不存在:   资源\机器人\图标\抽拉-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 height="57" src="resources/ios/icon/icon.png" width="57" />
    <icon height="114" src="resources/ios/icon/icon@2x.png" width="114" />
    <icon height="40" src="resources/ios/icon/icon-40.png" width="40" />
    <icon height="80" src="resources/ios/icon/icon-40@2x.png" width="80" />
    <icon height="120" src="resources/ios/icon/icon-40@3x.png" width="120" />
    <icon height="50" src="resources/ios/icon/icon-50.png" width="50" />
    <icon height="100" src="resources/ios/icon/icon-50@2x.png" width="100" />
    <icon height="60" src="resources/ios/icon/icon-60.png" width="60" />
    <icon height="120" src="resources/ios/icon/icon-60@2x.png" width="120" />
    <icon height="180" src="resources/ios/icon/icon-60@3x.png" width="180" />
    <icon height="72" src="resources/ios/icon/icon-72.png" width="72" />
    <icon height="144" src="resources/ios/icon/icon-72@2x.png" width="144" />
    <icon height="76" src="resources/ios/icon/icon-76.png" width="76" />
    <icon height="152" src="resources/ios/icon/icon-76@2x.png" width="152" />
    <icon height="167" src="resources/ios/icon/icon-83.5@2x.png" width="167" />
    <icon height="29" src="resources/ios/icon/icon-small.png" width="29" />
    <icon height="58" src="resources/ios/icon/icon-small@2x.png" width="58" />
    <icon height="87" src="resources/ios/icon/icon-small@3x.png" width="87" />
    <splash height="1136" src="resources/ios/splash/Default-568h@2x~iphone.png" width="640" />
    <splash height="1334" src="resources/ios/splash/Default-667h.png" width="750" />
    <splash height="2208" src="resources/ios/splash/Default-736h.png" width="1242" />
    <splash height="2048" src="resources/ios/splash/Default-Portrait@2x~ipad.png" width="1536" />
    <splash height="1024" src="resources/ios/splash/Default-Portrait~ipad.png" width="768" />
    <splash height="960" src="resources/ios/splash/Default@2x~iphone.png" width="640" />
    <splash height="480" src="resources/ios/splash/Default~iphone.png" width="320" />
</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" />

感谢您的帮助。

14 个答案:

答案 0 :(得分:60)

我遇到了同样的错误,在运行

之后
  

离子资源

  

离子科尔多瓦资源

(基于您的应用程序的离子版本)

它消失了。

问题是我在图标的路径中有Windows样式的斜杠(反斜杠),即我遇到的错误是:

  

错误:源路径不存在:   资源\机器人\图标\抽拉-HDPI-的icon.png

因此,将反斜杠转换为斜线可以解决它。

希望这对你和其他寻找同样问题的人有所帮助。这一切都发生在因为使用不同的机器[mac&amp; amp; windows]用于开发像mac和windows这样的项目。

答案 1 :(得分:1)

在config.xml中,我将resources \ android \ icon \ drawable-hdpi.png更改为资源resources \ android \ icon \ drawable-hdpi.png

答案 2 :(得分:1)

在config.xml中,我将resources / android / icon / drawable-hdpi.png更改为资源resources \ android \ icon \ drawable-hdpi.png

请注意斜线更改。

答案 3 :(得分:0)

我使用类似于Fakan的方式解决了错误。你只需要用src =&#34; resources \ android \ icon \ drawable-hdpi.png&#34;更改icon标签。在平台之外标记为&#34; resources \ icon.png&#34;解决此错误

答案 4 :(得分:0)

尝试在Ionic结构中找到此资源的路径。 有时候,或者在某些版本中,这条路径可能是这样的:

您的资源:

resources/android/icon/drawable-hdpi.png

试试这个:

res/android/icon/drawable-hdpi.png

答案 5 :(得分:0)

检查您的图标是否实际保存为“ .png”。不作为“ .PNG”。右键单击它,然后单击“属性”。

如果不是,请编辑图标并使用文件扩展名“ .png”保存。

答案 6 :(得分:0)

不要忘记在resources文件夹中添加文件。

理想情况下,图标的源图像应至少为1024×1024px,并位于resources/icon.png。初始屏幕的源图像理想上应至少为2732×2732px,并位于resources/splash.png。如果您使用了离子启动,则resources /目录中应该已经有默认的离子资源,可以覆盖这些默认资源。

您需要使用以下格式:.png.psd.ai

您可以将https://code.ionicframework.com/resources/splash.psd用作初始屏幕的模板,并将https://code.ionicframework.com/resources/icon.psd用作图标。

答案 7 :(得分:0)

问题是因为您有:

<preference name="Orientation" value="portrait" />

在您的config.xml中,并且当您运行ionic cordova resources时,它只会生成用于纵向显示的资源。

答案 8 :(得分:0)

只需删除config.xml文件中的<preference name="Orientation" value="portrait" />并运行离子科尔多瓦资源。

问题是,当您运行离子cordova资源时,它只会生成用于纵向显示的资源。

答案 9 :(得分:0)

只需编辑您的config.xml文件。我的看起来像这样:

LEFT JOIN

请注意,res /是相对于项目根目录的。文件名在您的结尾可能会有所不同。

答案 10 :(得分:0)

您可以通过运行以下命令再次添加资源:

ionic integrations enable cordova --add

答案 11 :(得分:0)

一个快速的替代答案:

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 androidionic cordova resources android检查

答案 12 :(得分:0)

我解决这个问题的方法有效,但有点奇怪。

我创建了以下文件并将它们放在“资源”目录中:

icon.png、icon.jpg、icon.jpeg、splash.png、splash.jpg、splash.jpeg。

如果您使用--verbose,它会告诉您每个文件必须具有的尺寸。例如,icon.png 必须有 512x512 像素。并且 splash.png 必须有 1920x1920 像素。

答案 13 :(得分:0)

从 config.xml 中删除所有资源标签并运行 ionic cordova resources -f。它将自动生成所有必要的资源和标签。您应该能够构建应用。