#android
#Android
Вопрос:
Я новичок в разработке Java для Android. Я читаю книгу под названием «Разработка приложений для Android для чайников». В главе 5 книги приведен следующий фрагмент кода, который не работает.
Может кто-нибудь, пожалуйста, помочь мне узнать, что я делаю неправильно в коде? Любая помощь приветствуется.
package helloandroid.android.dummies.com.silentmodetoggle;
import android.support.v7.app.AppCompatActivity;
import android.graphics.drawable.Drawable;
import android.media.AudioManager;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
public class MainActivity extends AppCompatActivity {
private AudioManager mAudioManager;
private boolean mPhoneIsSilent;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
setButtonClickListener();
mAudioManager = (AudioManager) getSystemService(AUDIO_SERVICE);
checkIfPhoneIsSilent();
setButtonClickListener();
}
private void setButtonClickListener() {
Button toggleButton = (Button) findViewById(R.id.toggleButton);
toggleButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
if (mPhoneIsSilent) {
//Change back to silent mode
mAudioManager
.setRingerMode(AudioManager.RINGER_MODE_NORMAL);
mPhoneIsSilent = false;
} else {
// Change to silent mode
mAudioManager
.setRingerMode(AudioManager.RINGER_MODE_SILENT);
mPhoneIsSilent = true;
}
// Now toggle the UI again
toggleUI();
}
});
}
/**
* Checks to see if the phone is currently in silent mode
*/
private void checkIfPhoneIsSilent() {
int ringerMode = mAudioManager.getRingerMode();
if (ringerMode == AudioManager.RINGER_MODE_SILENT) {
mPhoneIsSilent = true;
} else {
mPhoneIsSilent = false;
}
}
/**
* Toggles the UI images from silent to normal and vice versa
*/
private void toggleUI() {
ImageView imageView = (ImageView) findViewById(R.id.phone_icon);
Drawable newPhoneImage;
if (mPhoneIsSilent) {
newPhoneImage = getResources(drawable.phone_silent
}
else {
newPhoneImage =
getResources(drawable.phone_on);
}
imageView.setImageDrawable(newPhoneImage);
}
@Override
protected void onResume() {
super.onResume();
checkIfPhoneIsSilent();
toggleUI();
}
}
Некоторые любезно предлагают помочь.
Спасибо.
UPDATE
10-12 13:53:28.672 2965-2965/? D/dalvikvm: Not late-enabling CheckJNI (already on)
10-12 13:53:28.692
2965-2965/helloandroid.android.dummies.com.silentmodetoggle E/Trace: error
opening trace file: No such file or directory (2)
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle I/dalvikvm:
Could not
find method android.app.Application.registerOnProvideAssistDataListener,
referenced from method
com.android.tools.fd.runtime.BootstrapApplication.registerOnProvideAssistDataListener
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/dalvikvm: VFY:
unable to resolve virtual method 231: Landroid/app
/Application;.registerOnProvideAssistDataListener (Landroid/app
/Application$OnProvideAssistDataListener;)
10-12 13:53:28.703 2965-2965/helloandroid.android.dummies.com.silentmodetoggle D/dalvikvm: VFY:
replacing opcode 0x6e at 0x0002
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle I/dalvikvm: Could
not find method
android.app.Application.unregisterOnProvideAssistDataListener, referenced
from method
com.android.tools.fd.runtime.BootstrapApplication.unregisterOnProvideAssistDataLis
tener
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/dalvikvm: VFY:
unable to resolve virtual method 234: Landroid/app
/Application;.unregisterOnProvideAssistDataListener (Landroid/app
/Application$OnProvideAssistDataListener;)V
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle D/dalvikvm: VFY:
replacing opcode 0x6e at 0x0002
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle I/InstantRun:
Instant Run Runtime started. Android package is
helloandroid.android.dummies.com.silentmodetoggle, real application class is
null.
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/InstantRun: No
instant run dex files added to classpath
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle E/dalvikvm: Could
not find class 'android.util.ArrayMap', referenced from method
com.android.tools.fd.runtime.MonkeyPatcher.monkeyPatchExistingResources
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/dalvikvm: VFY:
unable to resolve check-cast 1884 (Landroid/util/ArrayMap;) in Lcom/android
/tools/fd/runtime/MonkeyPatcher;
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle D/dalvikvm: VFY:
replacing opcode 0x1f at 0x025e
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle E/dalvikvm: Could
not find class 'android.util.ArrayMap', referenced from method
com.android.tools.fd.runtime.MonkeyPatcher.pruneResourceCache
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/dalvikvm: VFY:
unable to resolve const-class 1884 (Landroid/util/ArrayMap;) in Lcom/android
/tools/fd/runtime/MonkeyPatcher;
10-12 13:53:28.703
2965-2965/helloandroid.android.dummies.com.silentmodetoggle D/dalvikvm: VFY:
replacing opcode 0x1c at 0x0060
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle I/dalvikvm: Could
not find method android.view.Window$Callback.onProvideKeyboardShortcuts,
referenced from method
android.support.v7.view.WindowCallbackWrapper.onProvideKeyboardShortcuts
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/dalvikvm: VFY:
unable to resolve interface method 15983: Landroid/view
/Window$Callback;.onProvideKeyboardShortcuts (Ljava/util/List;Landroid
/view/Menu;I)V
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle D/dalvikvm: VFY:
replacing opcode 0x72 at 0x0002
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/dalvikvm: VFY:
unable to find class referenced in signature (Landroid/view/SearchEvent;)
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle I/dalvikvm: Could
not find method android.view.Window$Callback.onSearchRequested, referenced
from method android.support.v7.view.WindowCallbackWrapper.onSearchRequested
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/dalvikvm: VFY:
unable to resolve interface method 15985: Landroid/view
/Window$Callback;.onSearchRequested (Landroid/view/SearchEvent;)Z
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle D/dalvikvm: VFY:
replacing opcode 0x72 at 0x0002
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle I/dalvikvm: Could
not find method android.view.Window$Callback.onWindowStartingActionMode,
referenced from method
android.support.v7.view.WindowCallbackWrapper.onWindowStartingActionMode
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/dalvikvm: VFY:
unable to resolve interface method 15989: Landroid/view
/Window$Callback;.onWindowStartingActionMode (Landroid/view
/ActionMode$Callback;I)Landroid/view/ActionMode;
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle D/dalvikvm: VFY:
replacing opcode 0x72 at 0x0002
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle I/dalvikvm: Could
not find method android.content.res.TypedArray.getChangingConfigurations,
referenced from method
android.support.v7.widget.TintTypedArray.getChangingConfigurations
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/dalvikvm: VFY:
unable to resolve virtual method 669: Landroid/content
/res/TypedArray;.getChangingConfigurations ()I
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle D/dalvikvm: VFY:
replacing opcode 0x6e at 0x0002
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle I/dalvikvm: Could
not find method android.content.res.TypedArray.getType, referenced from
method android.support.v7.widget.TintTypedArray.getType
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/dalvikvm: VFY:
unable to resolve virtual method 691: Landroid/content
/res/TypedArray;.getType (I)I
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle D/dalvikvm: VFY:
replacing opcode 0x6e at 0x0008
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle
E/VdcInflateDelegate: Exception while inflating <vector
org.xmlpull.v1.XmlPullParserException: Binary XML file line #17<vector>
tag requires viewportHeight > 0
at
android.support.graphics.drawable.VectorDrawableCompat.updateStateFromTypedArray(
VectorDrawableCompat.java:544)
at
android.support.graphics.drawable.VectorDrawableCompat.inflate
(VectorDrawableCompat.java:478)
at
android.support.graphics.drawable.VectorDrawableCompat.createFromXmlInner
(VectorDrawableCompat.java:441)
at android.support.v7.widget.AppCompatDrawableManager$VdcInflateDelegate.createFromXmlInner(AppCompatDrawableManager.java:742)
at android.support.v7.widget.AppCompatDrawableManager.loadDrawableFromDelegates(AppCompatDrawableManager.java:362)
at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:192)
at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:185)
at android.support.v7.widget.AppCompatDrawableManager.checkVectorDrawableSetup(AppCompatDrawableManager.java:720)
at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:190)
at android.support.v7.widget.TintTypedArray.getDrawableIfKnown(TintTypedArray.java:77)
at
android.support.v7.app.AppCompatDelegateImplBase.<init>(AppCompatDelegateImplBase.java:127)
at android.support.v7.app.AppCompatDelegateImplV9.<init
(AppCompatDelegateImplV9.java:147)
at android.support.v7.app.AppCompatDelegateImplV11.<init>
(AppCompatDelegateImplV11.java:27)
at android.support.v7.app.AppCompatDelegateImplV14.<init>
(AppCompatDelegateImplV14.java:50)
at
android.support.v7.app.AppCompatDelegate.create(AppCompatDelegate.java:201)
at
android.support.v7.app.AppCompatDelegate.create(AppCompatDelegate.java:181)
at
android.support.v7.app.AppCompatActivity.getDelegate(AppCompatActivity.java:521)
at
android.support.v7.app.AppCompatActivity.onCreate(AppCompatActivity.java:71)
at
helloandroid.android.dummies.com.silentmodetoggle.MainActivity.onCreate(MainActivity.java:18)
at android.app.Activity.performCreate(Activity.java:5008)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
at
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2023)
at
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084)
at
android.app.ActivityThread.access$600(ActivityThread.java:130)
at
android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4745)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Metho
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle
D/AndroidRuntime: Shutting down VM
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle W/dalvikvm:
threadid=1: thread exiting with uncaught exception (group=0xb2e51288)
10-12 13:53:28.732
2965-2965/helloandroid.android.dummies.com.silentmodetoggle
E/AndroidRuntime:
FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to start activity
ComponentInfo{helloandroid.android.dummies.com.silentmodetoggle/helloandroid.andro
id.dummies.com.silentmodetoggle.MainActivity}:
android.content.res.Resources$NotFoundException: File res/drawable
/abc_vector_test.xml from drawable resource ID #0x7f02005
at
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2059
at
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084)
at
android.app.ActivityThread.access$600(ActivityThread.java:13
at
android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4745)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)
Caused by: android.content.res.Resources$NotFoundException: File res/drawable
/abc_vector_test.xml from drawable resource ID #0x7f020052
at android.content.res.Resources.loadDrawable(Resources.java:1918)
at android.content.res.Resources.getDrawable(Resources.java:659)
at
android.support.v4.content.ContextCompat.getDrawable(ContextCompat.java:346)
at
android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:197)
в android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java: 185)
в android.support.v7.widget.AppCompatDrawableManager.checkVectorDrawableSetup(AppCompatDrawableManager.java: 720)
в android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java: 190)
в android.support.v7.widget.TintTypedArray.getDrawableIfKnown(TintTypedArray.java:77)
в android.support.v7.app.AppCompatDelegateImplBase. (AppCompatDelegateImplBase.java:127)
в android.support.v7.app.AppCompatDelegateImplV9.(AppCompatDelegateImplV9.java: 147)
в android.support.v7.app.AppCompatDelegateImplV11.(AppCompatDelegateImplV11.java: 27)
на android.support.v7.app.AppCompatDelegateImplV14.(AppCompatDelegateImplV14.java: 50)
в
android.support.v7.app.AppCompatDelegate.create(AppCompatDelegate.java:201)
at
android.support.v7.app.AppCompatDelegate.create(AppCompatDelegate.java:181)
at android.support.v7.app.AppCompatActivity.getDelegate(AppCompatActivity.java:521)
at android.support.v7.app.AppCompatActivity.onCreate(AppCompatActivity.java:71)
at helloandroid.android.dummies.com.silentmodetoggle.MainActivity.onCreate(MainActivity.java:18)
at android.app.Activity.performCreate(Activity.java:5008)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2023)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084)
at android.app.ActivityThread.access$600(ActivityThread.java:130)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4745)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)
Caused by: org.xmlpull.v1.XmlPullParserException: Binary XML file line #17: invalid drawable tag vector
at android.graphics.drawable.Drawable.createFromXmlInner(Drawable.java:877)
at android.graphics.drawable.Drawable.createFromXml(Drawable.java:818)
at android.content.res.Resources.loadDrawable(Resources.java:1915)
at android.content.res.Resources.getDrawable(Resources.java:659)
at android.support.v4.content.ContextCompat.getDrawable(ContextCompat.java:346)
at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:197)
at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:185)
at android.support.v7.widget.AppCompatDrawableManager.checkVectorDrawableSetup(AppCompatDrawableManager.java:720)
at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:190)
at android.support.v7.widget.TintTypedArray.getDrawableIfKnown(TintTypedArray.java:77)
at android.support.v7.app.AppCompatDelegateImplBase.<init>(AppCompatDelegateImplBase.java:127)
at android.support.v7.app.AppCompatDelegateImplV9.<init>(AppCompatDelegateImplV9.java:147)
at android.support.v7.app.AppCompatDelegateImplV11.<init>(AppCompatDelegateImplV11.java:27)
at android.support.v7.app.AppCompatDelegateImplV14.<init>(AppCompatDelegateImplV14.java:50)
at android.support.v7.app.AppCompatDelegate.create(AppCompatDelegate.java:201)
at android.support.v7.app.AppCompatDelegate.create(AppCompatDelegate.java:181)
at android.support.v7.app.AppCompatActivity.getDelegate(AppCompatActivity.java:521)
at android.support.v7.app.AppCompatActivity.onCreate(AppCompatActivity.java:71)
at helloandroid.android.dummies.com.silentmodetoggle.MainActivity.onCreate(MainActivity.java:18)
at android.app.Activity.performCreate(Activity.java:5008)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2023)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084)
at android.app.ActivityThread.access$600(ActivityThread.java:130)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4745)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)
10-12 13:53:28.752
2965-2969/helloandroid.android.dummies.com.silentmodetoggle D/dalvikvm:
GC_CONCURRENT freed 305K, 7% free 6071K/6471K, paused 16ms 1ms, total 18ms
10-12 13:53:31.472 2965-2965/? I/Process: Sending signal. PID: 2965 SIG: 9
Приведенное выше исключение Logcat, которое мне было очень сложно вставить
Однако каким-то образом я справился.
Ваш обновленный и отредактированный ответ выдает ошибку в блоке «else».
Ответ №1:
Сделайте что-то вроде этого
private void toggleUI() {
ImageView imageView = (ImageView) findViewById(R.id.phone_icon);
if (imageView != null) {
int imageResId = mPhoneIsSilent ? R.drawable.phone_silent : R.drawable.phone_on;
imageView.setImageResource(imageResId);
} else {
Log.e("ERR", "ImageView is null");
}
}
Комментарии:
1. Привет, Ришабх, спасибо за быстрый ответ. Как бы то ни было, я прикрепил снимок экрана с ошибкой в коде. На экране не удается найти phone_silent.png и phone_on.png.
2. Что теперь делать, чтобы продолжить? Спасибо.
3.
phone_silent.png
иphone_on.png
должен быть помещен вapp > src > main > res > drawable
папку. Если у вас больше вырезов, поместите их вdrawable-hdpi, mdpi, xhdpi, xxhdpi
соответствии с их разрешением / плотностью. И я не смог увидеть ваш скриншот.4. phone_silent.png и phone_on.png помещаются в папку drawable-mdpi, но снова и снова появляется одна и та же ошибка, сообщающая мне, что она не может найти изображения. Во-вторых, мне не разрешено прикреплять скриншоты здесь, поскольку я новичок в форумах Stack Overflow. Есть ли другой способ, которым я могу отправить вам снимок экрана? Спасибо за помощь.
5. При импорте убедитесь, что вы используете
your_package_name.R
вместоandroid.R
этого .