我试图通过" 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" />
感谢您的帮助。
答案 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 android
或ionic 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
。它将自动生成所有必要的资源和标签。您应该能够构建应用。