私はちょっと立ち往生しています。Android - カスタム描画、正しく描画されない
テーブルのようなカスタムビューを作成しようとしました!しかし、onDrawメソッドは最初のセル/矩形だけを描画しています。
これが私の見解です:
public class CustomView extends View {
private static int ROWS = 8;
private static int COLS = 8;
final Paint p = new Paint();
public CustomView(Context context) {
super(context);
p.setColor(Color.GREEN);
}
@Override
public void onDraw(Canvas canvas) {
canvas.drawColor(Color.RED);
float width = getWidth();
float height = getHeight();
float cellWidth = width/COLS;
float cellHeight = height/ROWS;
for(float row = 0; row<ROWS; row++) {
for(float col = 0; col<COLS; col++) {
RectF cell = new RectF((cellWidth*col), (cellHeight*row), cellWidth, cellHeight);
canvas.drawRect(cell, p);
}
}
}
}
マイXML:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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:id="@+id/mainLayout"
android:orientation="vertical"
android:background="#000000"
tools:context="com.biegertfunk.qlocktwo.Act_Main">
<RelativeLayout
android:id="@+id/centerView"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
マイアクティビティ:
public class Act_Main extends AppCompatActivity {
//views
public CustomView mainView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.act_main);
int size = getSize();
RelativeLayout.LayoutParams layoutParams = new RelativeLayout.LayoutParams(size, size);
layoutParams.addRule(RelativeLayout.CENTER_IN_PARENT);
RelativeLayout mainLayout = (RelativeLayout) findViewById(R.id.centerView);
mainView = new CustomView(this);
mainLayout.addView(mainView, layoutParams);
}
private int getSize() {
Display display = getWindowManager().getDefaultDisplay();
Point size = new Point();
display.getSize(size);
int width = size.x;
int height = size.y;
if(width>height) {
return height;
} else {
return width;
}
}
}
しかし、結果は一つだけの四角形を示しています。
を210
あなたのXMLを投稿する –
さらに詳しい情報を追加しました。 – Flo