Ошибка при добавлении моего собственного пользовательского представления в макет xml

У меня есть пользовательский вид в моем приложении:

public class DrawView extends View {
    Paint paint = new Paint();

    public DrawView(Context context) {
        super(context);            
    }
    public DrawView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public DrawView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }

и я хочу добавить это представление в XML-макет моей активности следующим образом:

 <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">
   <FrameLayout
    android:id="@+id/camera_preview"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"/>
     <test.example.myfirstapp.DrawView
        android:id="@+id/mostatil"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBottom="@+id/button_capture"
        android:layout_alignParentRight="true"/>
     <Button
      android:id="@+id/button_capture"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_alignParentBottom="true"
      android:layout_centerHorizontal="true"
      android:layout_marginBottom="16dp"
      android:onClick="capture"
      android:text="@string/capture_button" />
       </RelativeLayout>

но когда я пытаюсь запустить это действие, возникают такие ошибки:

01-06 14:26:00.897: E/AndroidRuntime(1933): FATAL EXCEPTION: main
01-06 14:26:00.897: E/AndroidRuntime(1933): java.lang.RuntimeException: Unable to start activity ComponentInfo{test.example.myfirstapp/test.example.myfirstapp.CameraActivity}: android.view.InflateException: Binary XML file line #13: Error inflating class test.example.myfirstapp.DrawView

имя пакета моей программы - test.example.myfirstapp, а файл xml - для действия с именем "CameraActivity"

РЕДАКТИРОВАТЬ: Вот несколько дополнительных строк logCat:

01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.app.ActivityThread.access$600(ActivityThread.java:141)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.os.Handler.dispatchMessage(Handler.java:99)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.os.Looper.loop(Looper.java:137)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.app.ActivityThread.main(ActivityThread.java:5039)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at java.lang.reflect.Method.invokeNative(Native Method)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at java.lang.reflect.Method.invoke(Method.java:511)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at dalvik.system.NativeStart.main(Native Method)
01-06 14:16:20.708: E/AndroidRuntime(1849): Caused by: android.view.InflateException: Binary XML file line #13: Error inflating class test.example.myfirstapp
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:698)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.view.LayoutInflater.rInflate(LayoutInflater.java:746)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.view.LayoutInflater.inflate(LayoutInflater.java:489)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:270)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.app.Activity.setContentView(Activity.java:1881)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at test.example.myfirstapp.CameraActivity.onCreate(CameraActivity.java:77)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.app.Activity.performCreate(Activity.java:5104)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
01-06 14:16:20.708: E/AndroidRuntime(1849):     ... 11 more
01-06 14:16:20.708: E/AndroidRuntime(1849): Caused by: java.lang.ClassNotFoundException: Didn't find class "test.example.myfirstapp" on path: /data/app/test.example.myfirstapp-1.apk
01-06 14:16:20.708: E/AndroidRuntime(1849):     at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:65)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.view.LayoutInflater.createView(LayoutInflater.java:552)
01-06 14:16:20.708: E/AndroidRuntime(1849):     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:687)

когда я открываю свой XML-макет в режиме «Графический макет», в графическом макете появляется эта ошибка:

   The following classes could not be instantiated:
    - test.example.myfirstapp.CameraActivity.DrawView (Open Class, Show Error Log)
    See the Error Log (Window > Show View) for more details.
    Tip: Use View.isInEditMode() in your custom views to skip code when shown in Eclipse

person Navid777    schedule 06.01.2013    source источник
comment
Я рекомендую вам вставить больше вашего logcat, так как фактическая трассировка стека будет ниже этого java.lang.RuntimeException.   -  person Tom Leese    schedule 06.01.2013


Ответы (5)


При надувании пользовательского представления в вашем xml в первую очередь не забудьте добавить его в свой основной контейнер представления.

xmlns:app="http://schemas.android.com/apk/res/my.package.name" .

Во-вторых, просто посмотрите, заполняете ли вы свое представление правильным именем пакета перед его именем, и проверьте правильность написания. Если все правильно.

Просто скопируйте и вставьте весь код вашего xml-файла и укажите, какой именно пакет является вашим представлением.

И убедитесь, что вы переопределили свой метод onDraw(Canvas canvas) в своем представлении.

ИЗМЕНИТЬ

Как я вижу, ваш xml выглядит так:

<test.example.myfirstapp
    android:id="@+id/mostatil"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/button_capture"
    android:layout_alignParentRight="true"/>

но здесь вы не используете свой собственный вид, он должен выглядеть так:

<test.example.myfirstapp.DrawView
        android:id="@+id/mostatil"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBottom="@+id/button_capture"
        android:layout_alignParentRight="true"/>
person hardartcore    schedule 06.01.2013
comment
Помните, что xmlns:app не требуется, если ваш View не имеет пользовательских атрибутов, загружаемых через XML. - person Tom Leese; 06.01.2013
comment
Это была опечатка, мой xml-файл на самом деле тоже содержит DrawView - person Navid777; 06.01.2013
comment
кроме того, даже не нужно переопределять onDraw() - person Vladimir Mironov; 06.01.2013
comment
поэтому, если вы все еще получаете ту же ошибку, покажите, что у вас есть в строке № 13 файла xml. - person hardartcore; 06.01.2013
comment
строка №13 — это строка ‹test.example.myfirstapp.DrawView - person Navid777; 06.01.2013
comment
Хорошо, так что еще, ваше представление объявлено в вашей деятельности как частный класс или оно находится в другом пакете или что-то в этом роде? - person hardartcore; 06.01.2013
comment
да, но в вашем журнале все еще написано test.example.myfirstapp, попробуйте еще раз и обновите logcat. - person hardartcore; 06.01.2013
comment
давайте продолжим это обсуждение в чате - person hardartcore; 06.01.2013
comment
как я читал в нескольких местах, сначала попробуйте перезапустить затмение и снова запустить проект - person hardartcore; 06.01.2013

Сделайте очистку в eclipse и удалите приложение с устройства/эмулятора, затем повторите попытку. Похоже, ваши ресурсы иссякли.

person nmw    schedule 06.01.2013
comment
Как я могу сделать очистку в eclipse? - person Navid777; 07.01.2013
comment
Через настройки на устройстве/эмуляторе. - person nmw; 07.01.2013

Краска должна быть создана в конструкторе

person Navid777    schedule 10.08.2013

Эти шаги работали для меня:

в вашем .xml:

<view class="test.example.myfirstapp.DrawViewd"
android:id="@+id/mostatil"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/button_capture"
android:layout_alignParentRight="true"/>
person Delano    schedule 27.10.2013

Попробуйте поместить класс в класс java для себя, а не в подкласс. Не забудьте обновить тег XML.

person Han    schedule 10.07.2017