상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - HorizontalScrollView에서 버튼 클릭 시 스크롤 효과를 주는 방법은?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
HorizontalScrollView에서 버튼 클릭 시 스크롤 효과를 주는 방법은 여러 가지가 있습니다. 아래는 Android의 `HorizontalScrollView`를 사용하여 버튼 클릭 시 특정 위치로 스크롤하는 방법에 대한 단계별 설명입니다. 단계 1: 레이아웃 구성 1. `res/layout` 폴더 안에 XML 파일을 생성하거나 기존의 레이아웃 파일에 다음과 같은 구조를 추가하세요. ```xml <HorizontalScrollView android:id="@+id/horizontalScrollView" android:layout_width="match_parent" android:layout_height="wrap_content"> <LinearLayout android:id="@+id/linearLayout" android:layout_width="wrap_content" android:layout_height="match_parent" android:orientation="horizontal"> <!-- 여러 개의 버튼 또는 뷰를 추가 --> <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Button 1" /> <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Button 2" /> <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Button 3" /> <!-- 추가 버튼 계속 --> </LinearLayout> </HorizontalScrollView> ``` 단계 2: 코드 구현 2. 이제 Activity 또는 Fragment에서 버튼 클릭 시 스크롤 동작을 구현합니다. ```java import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.HorizontalScrollView; import androidx.appcompat.app.AppCompatActivity; public class MainActivity extends AppCompatActivity { private HorizontalScrollView horizontalScrollView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); horizontalScrollView = findViewById(R.id.horizontalScrollView); Button button1 = findViewById(R.id.button1); Button button2 = findViewById(R.id.button2); Button button3 = findViewById(R.id.button3); button1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { scrollToView(button1); } }); button2.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { scrollToView(button2); } }); button3.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { scrollToView(button3); } }); } private void scrollToView(View view) { int offset = view.getLeft() + view.getWidth() / 2 - horizontalScrollView.getWidth() / 2; horizontalScrollView.smoothScrollTo(offset, 0); } } ``` 설명: - `HorizontalScrollView`에 여러 가지 버튼을 배치합니다. - 각 버튼에 클릭 리스너를 설정하여 버튼 클릭 시 해당 버튼으로 스크롤하는 `scrollToView()` 메서드를 호출합니다. - `scrollToView()` 메서드는 버튼의 위치를 계산하여 수평 스크롤 뷰를 해당 위치로 스크롤합니다. 버튼의 중심을 화면 중앙에 위치시키기 위해 버튼의 `getLeft()`, `getWidth()`, 그리고 `HorizontalScrollView`의 `getWidth()`를 사용하여 계산합니다. 스크롤 효과 최적화 - `smoothScrollTo()` 메서드를 사용하여 부드러운 스크롤 효과를 줍니다. 대신 `scrollTo()`를 사용하면 즉각적으로 이동할 수 있습니다. 애니메이션 효과를 원한다면 `smoothScrollTo()`를 사용하는 것이 좋습니다. 위의 예시를 참고하여 원하는 UI를 구현해보세요!
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기