I am trying to change background color on start of app.
Here is the method called from onCreate()
:
private void setBackground() {
String[] rColors = getRandomColors();
int rColor = new Random().nextInt(rColors.length);
ConstraintLayout constraintLayout = (ConstraintLayout) findViewById(R.id.mainLayout);
constraintLayout.setBackgroundColor(Color.parseColor(rColors[rColor]));
}
This method crashes the app when trying to start it. Is there another better way to change background color in code?
getRandonColors()
returns a String[]
with names of some colors I defined in colors.xml
EDIT:
String[] rColors = getRandomColors();
int rColor = new Random().nextInt(rColors.length);
ConstraintLayout constraintLayout = (ConstraintLayout) findViewById(R.id.mainLayout);
int i = MainActivityNew.this.getResources().getIdentifier(rColors[rColor],"color",MainActivityNew.this.getPackageName());
constraintLayout.setBackgroundColor(i);
EDIT2:
FATAL EXCEPTION: main
Process: com.asus.wetr, PID: 12941
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.asus.wetr/com.asus.wetr.activities.MainActivityNew}: java.lang.IllegalArgumentException: Unknown color
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2416)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)
at android.app.ActivityThread.-wrap11(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
Caused by: java.lang.IllegalArgumentException: Unknown color
at android.graphics.Color.parseColor(Color.java:235)
at com.asus.wetr.activities.MainActivityNew.setBackground(MainActivityNew.java:214)
at com.asus.wetr.activities.MainActivityNew.setUpUIComponents(MainActivityNew.java:143)
at com.asus.wetr.activities.MainActivityNew.onCreate(MainActivityNew.java:111)
at android.app.Activity.performCreate(Activity.java:6237)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)
at android.app.ActivityThread.-wrap11(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)