Androidはテーブルレイアウトを使って登録画面を設計します。
12147 ワード
Androidではテーブルレイアウトを使って登録画面を設計します。参考にしてください。具体的な内容は以下の通りです。
登録ページには、ユーザ名、パスワード、確認パスワード、認証コードが含まれています。検証コードはパッケージされたツールクラスを使って生成され、直接使用できます。効果図は以下の通りです。イベントハンドリングをしていません。簡単なテーブルレイアウトを作っただけです。
XMLレイアウトのコードは以下の通りです。
登録ページには、ユーザ名、パスワード、確認パスワード、認証コードが含まれています。検証コードはパッケージされたツールクラスを使って生成され、直接使用できます。効果図は以下の通りです。イベントハンドリングをしていません。簡単なテーブルレイアウトを作っただけです。
XMLレイアウトのコードは以下の通りです。
<?xml version="1.0" encoding="utf-8"?>
<TableLayout 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:stretchColumns="1"
tools:context="com.example.nuist__njupt.register.MainActivity">
<TextView
android:id="@+id/register_title"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:text=" "
android:textSize="20dp"
android:gravity="center_horizontal"
android:textColor="@android:color/black"
android:layout_marginTop="5dp"
/>
<TableRow>
<TextView
android:id="@+id/user_name"
android:text=" "
android:textSize="15dp"
android:layout_marginLeft="5dp"
android:layout_marginTop="20dp"
android:textColor="@android:color/black"
/>
<EditText
android:layout_width="match_parent"
android:id="@+id/input_name"
android:hint=" "
android:textSize="15dp"
android:layout_marginTop="20dp"
android:selectAllOnFocus="true"
android:layout_span="2"
/>
</TableRow>
<TableRow>
<TextView
android:id="@+id/user_password"
android:text=" "
android:textSize="15dp"
android:layout_marginLeft="5dp"
android:textColor="@android:color/black"
/>
<EditText
android:layout_width="match_parent"
android:id="@+id/input_password"
android:hint=" "
android:textSize="15dp"
android:inputType="textPassword"
android:layout_span="2"
/>
</TableRow>
<TableRow>
<TextView
android:id="@+id/confirm_password"
android:text=" "
android:textSize="15dp"
android:layout_marginLeft="5dp"
android:textColor="@android:color/black"
/>
<EditText
android:layout_width="match_parent"
android:id="@+id/input_confirm"
android:hint=" "
android:textSize="15dp"
android:inputType="textPassword"
android:layout_span="2" />
</TableRow>
<TableRow>
<TextView
android:id="@+id/test_password"
android:text=" "
android:textSize="15dp"
android:layout_marginLeft="5dp"
android:textColor="@android:color/black"
/>
<EditText
android:layout_width="match_parent"
android:id="@+id/input_test"
android:hint=" "
android:textSize="15dp"
android:layout_toLeftOf ="@+id/image"
/>
<ImageView
android:id="@+id/image"
android:layout_width="100dp"
android:layout_height="40dp"/>
</TableRow>
<Button
android:id="@+id/register"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:text=" "
android:textColor="@android:color/black"
android:textSize="15dp"
android:gravity="center_horizontal"
/>
<Button
android:id="@+id/cancel"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:text=" "
android:textColor="@android:color/black"
android:textSize="15dp"
android:gravity="center_horizontal"
/>
</TableLayout>
javaコードは以下の通りです
public class MainActivity extends AppCompatActivity {
private Bitmap bitmap;
private String code;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final ImageView image = (ImageView) findViewById(R.id.image); // ImageView
bitmap = CodeUtils.getInstance().createBitmap(); //
code = CodeUtils.getInstance().getCode(); //
image.setImageBitmap(bitmap);
image.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
bitmap = CodeUtils.getInstance().createBitmap();
code = CodeUtils.getInstance().getCode();
image.setImageBitmap(bitmap);
Toast.makeText(MainActivity.this, code, Toast.LENGTH_SHORT).show(); //
}
});
}
}
ツールクラスのCodeUtilsのコードは以下の通りです。
/**
* Created by nuist__NJUPT on 2021/4/16.
*/
public class CodeUtils {
//
private static final char[] CHARS = {
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm',
'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M',
'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'
};
private static CodeUtils mCodeUtils;
private int mPaddingLeft, mPaddingTop;
private StringBuilder mBuilder = new StringBuilder();
private Random mRandom = new Random();
//Default Settings
private static final int DEFAULT_CODE_LENGTH = 4;// 4
private static final int DEFAULT_FONT_SIZE = 60;//
private static final int DEFAULT_LINE_NUMBER = 3;//
private static final int BASE_PADDING_LEFT = 20; //
private static final int RANGE_PADDING_LEFT = 30;//
private static final int BASE_PADDING_TOP = 70;//
private static final int RANGE_PADDING_TOP = 15;//
private static final int DEFAULT_WIDTH = 200;// .
private static final int DEFAULT_HEIGHT = 100;// .
private static final int DEFAULT_COLOR = Color.rgb(0xee, 0xee, 0xee);//
private String code;
public static CodeUtils getInstance() {
if (mCodeUtils == null) {
mCodeUtils = new CodeUtils();
}
return mCodeUtils;
}
//
public Bitmap createBitmap() {
mPaddingLeft = 0; //
mPaddingTop = 0;
Bitmap bitmap = Bitmap.createBitmap(DEFAULT_WIDTH, DEFAULT_HEIGHT, Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
code = createCode();
canvas.drawARGB(0, 0, 0, 0);
canvas.drawColor(DEFAULT_COLOR);
Paint paint = new Paint();
paint.setTextSize(DEFAULT_FONT_SIZE);
for (int i = 0; i < code.length(); i++) {
randomTextStyle(paint);
randomPadding();
canvas.drawText(code.charAt(i) + "", mPaddingLeft, mPaddingTop, paint);
}
//
for (int i = 0; i < DEFAULT_LINE_NUMBER; i++) {
drawLine(canvas, paint);
}
canvas.save();//
canvas.restore();
return bitmap;
}
/**
*
*
* @return
*/
public String getCode() {
return code;
}
//
public String createCode() {
mBuilder.delete(0, mBuilder.length()); //
for (int i = 0; i < DEFAULT_CODE_LENGTH; i++) {
mBuilder.append(CHARS[mRandom.nextInt(CHARS.length)]);
}
return mBuilder.toString();
}
//
private void drawLine(Canvas canvas, Paint paint) {
int color = randomColor();
int startX = mRandom.nextInt(DEFAULT_WIDTH);
int startY = mRandom.nextInt(DEFAULT_HEIGHT);
int stopX = mRandom.nextInt(DEFAULT_WIDTH);
int stopY = mRandom.nextInt(DEFAULT_HEIGHT);
paint.setStrokeWidth(1);
paint.setColor(color);
canvas.drawLine(startX, startY, stopX, stopY, paint);
}
//
private int randomColor() {
mBuilder.delete(0, mBuilder.length()); //
String haxString;
for (int i = 0; i < 3; i++) {
haxString = Integer.toHexString(mRandom.nextInt(0xEE));
if (haxString.length() == 1) {
haxString = "0" + haxString;
}
mBuilder.append(haxString);
}
return Color.parseColor("#" + mBuilder.toString());
}
//
private void randomTextStyle(Paint paint) {
int color = randomColor();
paint.setColor(color);
paint.setFakeBoldText(mRandom.nextBoolean()); //true ,false
float skewX = mRandom.nextInt(11) / 10;
skewX = mRandom.nextBoolean() ? skewX : -skewX;
paint.setTextSkewX(skewX); //float , ,
paint.setUnderlineText(mRandom.nextBoolean()); //true ,false
paint.setStrikeThruText(mRandom.nextBoolean()); //true ,false
}
//
private void randomPadding() {
mPaddingLeft += BASE_PADDING_LEFT + mRandom.nextInt(RANGE_PADDING_LEFT);
mPaddingTop = BASE_PADDING_TOP + mRandom.nextInt(RANGE_PADDING_TOP);
}
}
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。