【移動應用開發(fā)技術】Android中怎么自定義一個密碼輸入框_第1頁
【移動應用開發(fā)技術】Android中怎么自定義一個密碼輸入框_第2頁
【移動應用開發(fā)技術】Android中怎么自定義一個密碼輸入框_第3頁
【移動應用開發(fā)技術】Android中怎么自定義一個密碼輸入框_第4頁
【移動應用開發(fā)技術】Android中怎么自定義一個密碼輸入框_第5頁
已閱讀5頁,還剩5頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

【移動應用開發(fā)技術】Android中怎么自定義一個密碼輸入框

這篇文章給大家介紹Android中怎么自定義一個密碼輸入框,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。思路1.自定義EditText。2.背景為一個外圓環(huán)加內實心圓。3.edittext的長度變化時候重新繪制背景或者紅色環(huán)位置。關鍵代碼代碼其實也很簡單,順手拿資源的請到文末。1.畫背景/**

*

繪制背景外圓

*/

private

void

drawOutRing(Canvas

canvas)

{

mPaint.setColor(mBgColor);

//

設置畫筆為空心

mPaint.setStyle(Paint.Style.STROKE);

mPaint.setStrokeWidth(mBgSize);

RectF

rectF

=

new

RectF(mBgSize,

mBgSize,

getWidth()

-

mBgSize,

getHeight()

-

mBgSize);

//

畫圓

for

(int

i

=

0;

i

<

mPasswordNumber;

i++)

{

int

cx

=

i

*

mDivisionLineSize

+

i

*

mPasswordItemWidth

+

mPasswordItemWidth

/

2

+

mBgSize;

canvas.drawCircle(cx,

getHeight()

/

2,

mOutRadius,

mPaint);

}

}2.畫實心內圓背景/**

*

繪制背景內圓

*/

private

void

drawInRing(Canvas

canvas)

{

mPaint.setColor(mDivisionLineColor);

//

設置畫筆為實心

mPaint.setStyle(Paint.Style.FILL);

//

畫圈圈

for

(int

i

=

0;

i

<

mPasswordNumber;

i++)

{

int

cx

=

i

*

mDivisionLineSize

+

i

*

mPasswordItemWidth

+

mPasswordItemWidth

/

2

+

mBgSize;

canvas.drawCircle(cx,

getHeight()

/

2,

mPasswordRadius,

mPaint);

}

}

}3.繪制輸入密碼的變化動作/**

*

繪制隱藏的密碼

*/

private

void

drawHidePassword(Canvas

canvas)

{

int

passwordLength

=

getText().length();

if

(passwordLength

>

6)

passwordLength

=

6;

mPaint.setColor(mPasswordColor);

//

畫實心內圓

mPaint.setStyle(Paint.Style.FILL);

for

(int

i

=

0;

i

<

passwordLength;

i++)

{

int

cx

=

i

*

mDivisionLineSize

+

i

*

mPasswordItemWidth

+

mPasswordItemWidth

/

2

+

mBgSize;

canvas.drawCircle(cx,

getHeight()

/

2,

mPasswordRadius,

mPaint);

}

//外圓顏色

mPaint.setColor(mPasswordColor);

//

設置畫筆為空心

mPaint.setStyle(Paint.Style.STROKE);

mPaint.setStrokeWidth(mBgSize);

RectF

rectF

=

new

RectF(mBgSize,

mBgSize,

getWidth()

-

mBgSize,

getHeight()

-

mBgSize);

//

畫空心外圓

for

(int

i

=

0;

i

<

passwordLength;

i++)

{

int

cx

=

i

*

mDivisionLineSize

+

i

*

mPasswordItemWidth

+

mPasswordItemWidth

/

2

+

mBgSize;

canvas.drawCircle(cx,

getHeight()

/

2,

mOutRadius,

mPaint);

}

}4.重寫onDrawint

passwordWidth

=

getWidth()

-

(mPasswordNumber

-

1)

*

mDivisionLineSize;

mPasswordItemWidth

=

passwordWidth

/

mPasswordNumber;

//

繪制背景外圓

drawOutRing(canvas);

//

繪制背景內圓

drawInRing(canvas);

//

繪制密碼

drawHidePassword(canvas);5.xml引用<com***.PasswordView

android:id="@+id/password"

android:layout_width="240dp"

android:layout_height="wrap_content"

android:layout_gravity="center"

android:layout_marginTop="10dp"

android:background="@null">

</com***.PasswordView>6.還可以設置些屬性在sytle中設置,通過xml中的app:xxx引用。<com.*.PasswordView

android:id="@+id/password"

android:layout_width="240dp"

android:layout_height="wrap_content"

android:layout_gravity="center"

android:layout_marginTop="10dp"

xmlns:app="/apk/res-auto"

app:bgColor="#ffffff"

android:background="@null">

</com.*.PasswordView>完整代碼一些樣式,我設置了,結果直接沒用上<declare-styleable

name="PasswordView">

<!--

密碼的個數(shù)

-->

<attr

name="passwordNumber"

format="integer"/>

<!--

密碼圓點的半徑

-->

<attr

name="passwordRadius"

format="dimension"/>

<!--

密碼圓點的顏色

-->

<attr

name="passwordColor"

format="color"/>

<!--

外圈顏色

-->

<attr

name="outRingColor"

format="color"/>

<!--

外圓線條大小

-->

<attr

name="outRingLineSize"

format="color"/>

<!--

背景邊框的顏色

-->

<attr

name="bgColor"

format="color"/>

<!--

背景邊框的大小

-->

<attr

name="bgSize"

format="dimension"/>

<!--

背景邊框的圓角大小

-->

<attr

name="bgCorner"

format="dimension"/>

</declare-styleable>自定義Edittextimport

android.content.Context;

import

android.content.res.TypedArray;

import

android.graphics.Canvas;

import

android.graphics.Color;

import

android.graphics.Paint;

import

android.graphics.RectF;

import

android.util.AttributeSet;

import

android.util.TypedValue;

import

android.view.inputmethod.EditorInfo;

import

android.widget.EditText;

/**

*自定義密碼輸入框

*/

public

class

PasswordView

extends

EditText

{

//

畫筆

private

Paint

mPaint;

//

一個密碼所占的寬度

private

int

mPasswordItemWidth;

//

密碼的個數(shù)默認為6位數(shù)

private

int

mPasswordNumber

=

6;

//

背景圓顏色

private

int

mBgColor

=

Color.parseColor("#d1d2d6");

//

背景大小

private

int

mBgSize

=

1;

//

背景邊框圓角大小

private

int

mBgCorner

=

0;

//

外圓的顏色

private

int

outRingLineColor

=

mBgColor;

//

外圓線條的大小

private

int

outRingLineSize

=

1;

//

密碼輸入的顏色

private

int

mPasswordColor

=

Color.parseColor("#cb3435");

//

密碼圓點的半徑大小

private

int

mPasswordRadius

=

6;

//

外圓半徑大小

private

int

mOutRadius

=

25;

public

PasswordView(Context

context)

{

this(context,

null);

}

public

PasswordView(Context

context,

AttributeSet

attrs)

{

super(context,

attrs);

initPaint();

initAttributeSet(context,

attrs);

//

設置輸入模式是密碼

setInputType(EditorInfo.TYPE_TEXT_VARIATION_PASSWORD);

//

不顯示光標

setCursorVisible(false);

}

/**

*

初始化屬性

*/

private

void

initAttributeSet(Context

context,

AttributeSet

attrs)

{

TypedArray

array

=

context.obtainStyledAttributes(attrs,

R.styleable.PasswordView);

//

獲取大小

outRingLineSize

=

(int)

array.getDimension(R.styleable.PasswordView_outRingLineSize,

dip2px(outRingLineSize));

mPasswordRadius

=

(int)

array.getDimension(R.styleable.PasswordView_passwordRadius,

dip2px(mPasswordRadius));

mBgSize

=

(int)

array.getDimension(R.styleable.PasswordView_bgSize,

dip2px(mBgSize));

mBgCorner

=

(int)

array.getDimension(R.styleable.PasswordView_bgCorner,

0);

//

獲取顏色

mBgColor

=

array.getColor(R.styleable.PasswordView_bgColor,

mBgColor);

outRingLineColor

=

array.getColor(R.styleable.PasswordView_outRingColor,

outRingLineColor);

mPasswordColor

=

array.getColor(R.styleable.PasswordView_passwordColor,

mPasswordColor);

array.recycle();

}

/**

*

初始化畫筆

*/

private

void

initPaint()

{

mPaint

=

new

Paint();

mPaint.setAntiAlias(true);

mPaint.setDither(true);

}

/**

*

dip

px

*/

private

int

dip2px(int

dip)

{

return

(int)

TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP,

dip,

getResources().getDisplayMetrics());

}

@Override

protected

void

onDraw(Canvas

canvas)

{

int

passwordWidth

=

getWidth()

-

(mPasswordNumber

-

1)

*

outRingLineSize;

mPasswordItemWidth

=

passwordWidth

/

mPasswordNumber;

//

繪制背景外圓

drawOutRing(canvas);

//

繪制背景內圓

drawInRing(canvas);

//

繪制密碼

drawHidePassword(canvas);

}

@Override

public

void

setText(CharSequence

text,

BufferType

type)

{

super.setText(text,

type);

}

/**

*

繪制背景外圓

*/

private

void

drawOutRing(Canvas

canvas)

{

mPaint.setColor(mBgColor);

//

設置畫筆為空心

mPaint.setStyle(Paint.Style.STROKE);

mPaint.setStrokeWidth(mBgSize);

RectF

rectF

=

new

RectF(mBgSize,

mBgSize,

getWidth()

-

mBgSize,

getHeight()

-

mBgSize);

//

畫圓

for

(int

i

=

0;

i

<

mPasswordNumber;

i++)

{

int

cx

=

i

*

outRingLineSize

+

i

*

mPasswordItemWidth

+

mPasswordItemWidth

/

2

+

mBgSize;

canvas.drawCircle(cx,

getHeight()

/

2,

mOutRadius,

mPaint);

}

}

/**

*

繪制隱藏的密碼

*/

private

void

drawHidePassword(Canvas

canvas)

{

int

passwordLength

=

getText().length();

if

(passwordLength

>

6)

passwordLength

=

6;

mPaint.setColor(mPasswordColor);

//

設置畫筆為實心

mPaint.setStyle(Paint.Style.FILL);

for

(int

i

=

0;

i

<

passwordLength;

i++)

{

int

cx

=

i

*

outRingLineSize

+

i

*

mPasswordItemWidth

+

mPasswordItemWidth

/

2

+

mBgSize;

canvas.drawCircle(cx,

getHeight()

/

2,

mPasswordRadius,

mPaint);

}

//外圓

mPaint.setColor(mPasswordColor);

//

設置畫筆為空心

mPaint.setStyle(Paint.Style.STROKE);

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論