Android 맞춤 뷰를 사용하여 모양 그래픽 그리기를 구현하는 방법을 알려드립니다.
이 글에서는 안드로이드의 사용자 정의 보기를 사용하여 도형 그래픽 그리기를 구현하는 방법을 주로 자세히 소개합니다. 관심 있는 친구는
개요
를 참조하세요. 이전에 Android에서 드로어블의 Shape 리소스 사용을 소개하는 기사를 작성한 적이 있습니다. 드로어블에서 셰이프 리소스를 정의하면 직사각형, 타원, 선, 링 등과 같은 간단한 그래픽 효과를 그릴 수 있습니다. 나중에 프로젝트에서 특정 위치에 수직 점선을 표시하라는 요구 사항이 발생했습니다. 위의 리소스 파일을 자신있게 넣었을 때, 그것이 내 요구 사항을 충족하지 않는다는 것을 발견했습니다. 도형을 사용하여 그린 수직 점선은 실제로는 90도 회전된 수평선입니다. 하지만 이것의 단점은 View의 유효영역이 90도 회전 후 원래 위치와 일치하는 영역이므로 마음대로 변경할 수 없다는 점입니다. 그래서 원하는 결과를 그리기 위해 커스텀 뷰를 활용해볼까 생각했습니다.
1. 가로 점선을 그립니다
코드는 다음과 같습니다.
import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.DashPathEffect; import android.graphics.Paint; import android.util.AttributeSet; import android.view.View; public class CustView extends View{ private Paint mPaint; //定义画笔 public CustView(Context context, AttributeSet attrs) { super(context, attrs); //初始化画笔 initPaint(); setLayerType(View.LAYER_TYPE_SOFTWARE, mPaint); //4.0以上关闭硬件加速,否则虚线不显示 } private void initPaint() { mPaint = new Paint(); mPaint.setAntiAlias(true); //设置抗锯齿的效果 mPaint.setStyle(Paint.Style.STROKE); //设置画笔样式为描边 mPaint.setStrokeWidth(3); //设置笔刷的粗细度 mPaint.setColor(Color.RED); //设置画笔的颜色 mPaint.setPathEffect(new DashPathEffect(new float[]{5,5,5,5}, 1)); //设置画笔的路径效果为虚线效果 } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); canvas.drawLine(0, 0, 100, 0, mPaint); } }
레이아웃 파일은 다음과 같이 인용됩니다.
<com.test.CustView android:layout_width="100dp" android:layout_height="10dp" android:layout_marginTop="10dp" />
지침: Custom View의 코드에서 onDraw 메소드에서 실행되는 drawLine 메소드의 전체 이름은 다음과 같습니다.
public void drawLine (float startX, float startY, float stopX , float stopY, 페인트 페인트)
startX: 시작 끝점 x 좌표
startY: 시작 끝점 y 좌표
stopX: 끝점 x 좌표
stopY: 끝점 y 좌표
위 4개의 왼쪽 값은 모두 상대 위치, 즉 왼쪽에 컨트롤이 없는 경우 왼쪽 테두리의 상대 위치로 계산됩니다. 휴대폰 화면이 계산됩니다.
canvas.drawLine(0, 0, 100, 0, mPaint); 왼쪽을 기준으로 x 및 y 좌표가 0인 위치에서 시작하여 오른쪽으로 100px 점선을 그리는 것을 의미합니다.
Button 버튼을 제거한 후 그림과 같이 화면의 왼쪽 테두리를 기준으로 상대 위치가 계산되기 시작합니다.
또 다른 주의할 점은 stopX 및 stopY 값이 xml에 있는 컨트롤의layout_width 및layout_height 값을 초과할 수 없다는 것입니다. 그렇지 않으면 가장 작은 값은 기준으로 사용되며, 초과된 길이는 무효가 됩니다.
2. 수직 점선 그리기
는 위 코드와 일치하며 다음과 같이만 수정하면 됩니다.
canvas.drawLine( 0, 0, 0, 100, mPaint);
3. 단색 원을 그립니다
1). 스타일을 단색으로
mPaint.setStyle(Paint.Style.FILL); //브러시 스타일을 채우기로 설정
2) 캔버스에 원을 그립니다. 🎜> canvas.drawCircle(50, 50, 50, mPaint);X와 Y의 동일한 값은 XML의 컨트롤.
4. 원 그리기또한 코드를 약간 수정하면 됩니다.
@Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); canvas.drawCircle(50, 50, 50, mPaint); //画一个外圆 mPaint.setColor(Color.WHITE); //重新设置画笔颜色 canvas.drawCircle(50, 50, 30, mPaint); //画一个内圆 }
아아아아
위 내용은 Android 맞춤 뷰를 사용하여 모양 그래픽 그리기를 구현하는 방법을 알려드립니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











최근 아이스 유니버스는 삼성의 차기 플래그십 스마트폰으로 널리 알려진 갤럭시 S25 울트라에 대한 세부 정보를 꾸준히 공개해 왔습니다. 무엇보다도 유출자는 삼성이 카메라 업그레이드를 하나만 가져올 계획이라고 주장했습니다.

OnLeaks는 이제 Android Headlines와 제휴하여 X(이전 Twitter) 팔로어로부터 4,000달러 이상의 수익을 창출하려는 시도가 실패한 지 며칠 후 Galaxy S25 Ultra에 대한 첫 번째 모습을 제공합니다. 맥락에 따라 h 아래에 포함된 렌더링 이미지

TCL은 두 가지 새로운 스마트폰을 발표하는 것과 함께 NXTPAPER 14라는 새로운 Android 태블릿도 발표했는데, TCL의 거대한 화면 크기는 판매 포인트 중 하나입니다. NXTPAPER 14는 TCL의 시그니처 브랜드인 무광택 LCD 패널 버전 3.0을 갖추고 있습니다.

Vivo Y300 Pro는 방금 완전히 공개되었으며 대용량 배터리를 갖춘 가장 얇은 중급 Android 휴대폰 중 하나입니다. 정확히 말하면 스마트폰의 두께는 7.69mm에 불과하지만 배터리 용량은 6,500mAh입니다. 최근 출시된 것과 동일한 용량이다.

최근 아이스 유니버스는 삼성의 차기 플래그십 스마트폰으로 널리 알려진 갤럭시 S25 울트라에 대한 세부 정보를 꾸준히 공개해 왔습니다. 무엇보다도 유출자는 삼성이 카메라 업그레이드를 하나만 가져올 계획이라고 주장했습니다.

삼성전자는 팬에디션(FE) 스마트폰 시리즈를 언제 업데이트할지 아직 힌트를 주지 않았다. 현재 상태로 Galaxy S23 FE는 2023년 10월 초에 출시된 회사의 최신 버전으로 남아 있습니다.

모토로라는 올해 셀 수 없이 많은 기기를 출시했지만 그 중 폴더블 기기는 2개뿐이었습니다. 맥락에 따라 전 세계 대부분이 Razr 50 및 Razr 50 Ultra로 쌍을 받았지만 Motorola는 북미에서 Razr 2024 및 Razr 2로 제공합니다.

Redmi Note 14 Pro Plus는 이제 작년 Redmi Note 13 Pro Plus(Amazon에서 현재 $375)의 직접적인 후속 제품으로 공식화되었습니다. 예상대로 Redmi Note 14 Pro Plus는 Redmi Note 14 및 Redmi Note 14 Pro와 함께 Redmi Note 14 시리즈를 주도합니다. 리
