Reputation: 587
I'm basically making a comic style app in which a user can add multiple speech bubbles to their images. I'm a newbie at this and I have no idea why my app crashes. I followed a few tutorials from here and there and this is what I have done so far.
I can create a new textview with text, that has a background of my 9patch speech bubble, on runtime. I can select that textview and drag it. But as soon as I drop it, the textview sticks there and the app crashes. Plus, when I drop it the original stays there.
I am adding the code as well as the images.
private RelativeLayout mLayout;
private EditText mEditText;
private Button mButton;
private android.widget.RelativeLayout.LayoutParams layoutParams;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mLayout = (RelativeLayout) findViewById(R.id.lay);
mEditText = (EditText) findViewById(R.id.editTxt);
mButton = (Button) findViewById(R.id.btnAddNew);
mButton.setOnClickListener(onClick());
TextView textView = new TextView(this);
textView.setText("New text");
findViewById(R.id.lay).setOnDragListener(dragListener);
}
//This creates the new textview
private OnClickListener onClick() {
return new OnClickListener() {
@Override
public void onClick(View v) {
mLayout.addView(createNewTextView(mEditText.getText().toString()));
}
};
}
OnLongClickListener longListener = new OnLongClickListener()
{
@Override
public boolean onLongClick(View v)
{
TextView txtView = (TextView) v;
View.DragShadowBuilder myShadowBuilder = new DragShadowBuilder(txtView);
ClipData data = ClipData.newPlainText("", "");
v.startDrag(data, myShadowBuilder, txtView, 0);
return true;
}
};
OnDragListener dragListener = new OnDragListener()
{
@Override
public boolean onDrag(View v, DragEvent event)
{
int dragEvent = event.getAction();
switch(dragEvent)
{
case DragEvent.ACTION_DRAG_ENTERED:
//dropText.setTextColor(Color.GREEN);
break;
case DragEvent.ACTION_DRAG_STARTED:
//dropText.setTextColor(Color.GREEN);
layoutParams = (RelativeLayout.LayoutParams)
v.getLayoutParams();
break;
case DragEvent.ACTION_DRAG_EXITED:
break;
case DragEvent.ACTION_DROP:
layoutParams.leftMargin = (int)event.getX();
layoutParams.topMargin = (int)event.getY();
v.setLayoutParams(layoutParams);
break;
}
return true;
}
};
private TextView createNewTextView(String text) {
final LayoutParams lparams = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
final TextView textView = new TextView(this);
textView.setLayoutParams(lparams);
textView.setText("New text: " + text);
textView.setBackgroundResource(R.drawable.ss);
textView.setWidth(100);
ViewGroup.LayoutParams params = textView.getLayoutParams();
params.height = ViewGroup.LayoutParams.WRAP_CONTENT;
textView.setLayoutParams(params);
textView.setOnLongClickListener(longListener);
return textView;
}
Log Cat Error:
12-01 08:30:04.695: E/AndroidRuntime(5339): FATAL EXCEPTION: main
12-01 08:30:04.695: E/AndroidRuntime(5339): java.lang.NullPointerException
12-01 08:30:04.695: E/AndroidRuntime(5339): at com.example.adddragtry.MainActivity$2.onDrag(MainActivity.java:115)
12-01 08:30:04.695: E/AndroidRuntime(5339): at android.view.View.dispatchDragEvent(View.java:16371)
12-01 08:30:04.695: E/AndroidRuntime(5339): at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1251)
12-01 08:30:04.695: E/AndroidRuntime(5339): at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1237)
12-01 08:30:04.695: E/AndroidRuntime(5339): at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1237)
12-01 08:30:04.695: E/AndroidRuntime(5339): at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1237)
12-01 08:30:04.695: E/AndroidRuntime(5339): at android.view.ViewRootImpl.handleDragEvent(ViewRootImpl.java:3838)
12-01 08:30:04.695: E/AndroidRuntime(5339): at android.view.ViewRootImpl.access$600(ViewRootImpl.java:95)
12-01 08:30:04.695: E/AndroidRuntime(5339): at android.view.ViewRootImpl$ViewRootHandler.handleMessage(ViewRootImpl.java:2999)
12-01 08:30:04.695: E/AndroidRuntime(5339): at android.os.Handler.dispatchMessage(Handler.java:99)
12-01 08:30:04.695: E/AndroidRuntime(5339): at android.os.Looper.loop(Looper.java:137)
12-01 08:30:04.695: E/AndroidRuntime(5339): at android.app.ActivityThread.main(ActivityThread.java:5041)
12-01 08:30:04.695: E/AndroidRuntime(5339): at java.lang.reflect.Method.invokeNative(Native Method)
12-01 08:30:04.695: E/AndroidRuntime(5339): at java.lang.reflect.Method.invoke(Method.java:511)
12-01 08:30:04.695: E/AndroidRuntime(5339): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
12-01 08:30:04.695: E/AndroidRuntime(5339): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
12-01 08:30:04.695: E/AndroidRuntime(5339): at dalvik.system.NativeStart.main(Native Method)
New Logcat after inittializing layoutparam
12-01 10:08:57.116: E/AndroidRuntime(749): FATAL EXCEPTION: main
12-01 10:08:57.116: E/AndroidRuntime(749): java.lang.ClassCastException: android.widget.FrameLayout$LayoutParams cannot be cast to android.widget.RelativeLayout$LayoutParams
12-01 10:08:57.116: E/AndroidRuntime(749): at com.example.adddragtry.MainActivity$2.onDrag(MainActivity.java:89)
12-01 10:08:57.116: E/AndroidRuntime(749): at android.view.View.dispatchDragEvent(View.java:16371)
12-01 10:08:57.116: E/AndroidRuntime(749): at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1251)
12-01 10:08:57.116: E/AndroidRuntime(749): at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1188)
12-01 10:08:57.116: E/AndroidRuntime(749): at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1200)
12-01 10:08:57.116: E/AndroidRuntime(749): at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1200)
12-01 10:08:57.116: E/AndroidRuntime(749): at android.view.ViewRootImpl.handleDragEvent(ViewRootImpl.java:3838)
12-01 10:08:57.116: E/AndroidRuntime(749): at android.view.ViewRootImpl.access$600(ViewRootImpl.java:95)
12-01 10:08:57.116: E/AndroidRuntime(749): at android.view.ViewRootImpl$ViewRootHandler.handleMessage(ViewRootImpl.java:2999)
12-01 10:08:57.116: E/AndroidRuntime(749): at android.os.Handler.dispatchMessage(Handler.java:99)
12-01 10:08:57.116: E/AndroidRuntime(749): at android.os.Looper.loop(Looper.java:137)
12-01 10:08:57.116: E/AndroidRuntime(749): at android.app.ActivityThread.main(ActivityThread.java:5041)
12-01 10:08:57.116: E/AndroidRuntime(749): at java.lang.reflect.Method.invokeNative(Native Method)
12-01 10:08:57.116: E/AndroidRuntime(749): at java.lang.reflect.Method.invoke(Method.java:511)
12-01 10:08:57.116: E/AndroidRuntime(749): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
12-01 10:08:57.116: E/AndroidRuntime(749): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
12-01 10:08:57.116: E/AndroidRuntime(749): at dalvik.system.NativeStart.main(Native Method)
Upvotes: 0
Views: 844
Reputation: 20500
layoutParams
is never initalized so it will always be null.
So when you're trying to execute this line layoutParams.leftMargin = (int)event.getX();
you will get a NPE because layoutParams
is null. If you want to use the layout paramters of the view try using:
layoutParams = v.getLayoutParams();
before you try changing it's values.
Upvotes: 1