Android — использовать пользовательский класс представления в моей деятельности

#android #xml #android-layout #view #android-custom-view

#Android #xml #android-макет #Вид #android-пользовательский вид

Вопрос:

Я очень новичок в разработке Android и пытаюсь реализовать свой собственный пользовательский вид, который позволит мне использовать операции рисования на холсте. Мой пользовательский вид должен нарисовать прямоугольник на экране в функции onDraw (), однако, похоже, он не работает, прямоугольник не нарисован.

Самое основное основное действие, с которым я пытаюсь использовать пользовательский вид:

 package com.example.testcanvas;

import android.support.v7.app.ActionBarActivity;
import android.support.v7.app.ActionBar;
import android.support.v4.app.Fragment;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.os.Build;

public class MainActivity extends ActionBarActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);


}


@Override
public boolean onCreateOptionsMenu(Menu menu) {

    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();
    if (id == R.id.action_settings) {
        return true;
    }
    return super.onOptionsItemSelected(item);


  }

}
  

XML-файлы для действия, к которому я пытался добавить пользовательский вид:

фрагмент main.xml

 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.testcanvas.MainActivity$PlaceholderFragment" >




</RelativeLayout>
  

активность main.xml

 <RelativeLayout 
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@ id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.testcanvas.MainActivity"
tools:ignore="MergeRootFrame" >

<com.example.testcanvas.CustomView
            android:layout_width="match_parent"
            android:layout_height="200dp"
            android:id="@ id/custom_view" />

 </RelativeLayout>
  

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

 package com.example.testcanvas;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
import android.view.View;

public class CustomView extends SurfaceView implements SurfaceHolder.Callback {

public CustomView (Context context) {
    super(context);
}

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

@Override
public void onDraw (Canvas canvas) {
    int dCenter = 40;     //Distance from center in px, NOT in dp
    int centerX = (int)(getWidth()/2);
    int centerY = (int)(getHeight()/2);

    Paint paint = new Paint();
    paint.setColor(Color.BLUE);  //The square will draw in the color blue now


    Rect rect = new Rect(centerX-dCenter, centerY-dCenter, centerX dCenter, centerY dCenter);
    canvas.drawRect(rect, paint);
}

@Override
public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {}

@Override
public void surfaceCreated(SurfaceHolder holder) {
    setWillNotDraw(false);   //Allows us to use invalidate() to call onDraw()
    postInvalidate();
}

@Override
public void surfaceDestroyed(SurfaceHolder holder) {}

}
  

Может ли кто-нибудь указать, где я ошибся? Спасибо.

Комментарии:

1. setContentView(R.layout.activity_main); activity_main не содержит вашего пользовательского представления в этом фрагменте main.xml делает

2. Привет, JRowan, спасибо за вашу помощь, я переместил пользовательский вид в activity main, однако теперь экран, который я вижу, разделен на две части, половина сверху черная, а нижняя белая, синий прямоугольник по-прежнему не нарисован, есть какие-либо советы?

3. на самом деле я не уверен, что я никогда не расширял surfaceview, но я зайду в свое eclipse и попробую, посмотрю, что случилось, и свяжусь с вами

4. Большое спасибо! Я думаю, что представление теперь работает после вашего совета, однако функция onDraw, похоже, все еще не работает.

5. Исправлено! Добавлен getHolder().addCallback(this); в конструкторы CustomView