Jetpack Compose용 간단한 텍스트 편집기 라이브러리 만들기 시작
소개
저는 주로 Craft를 사용하는데 Craft의 텍스트 편집기는 필기감이 좋고 불만이 없어서 Jetpack Compose에 Craft와 같은 텍스트 편집기가 필요하다고 생각했습니다.
Craft - The Future of Documents
data:image/s3,"s3://crabby-images/8481b/8481b351f553c30a4d6341a10707bab53764a32e" alt=""
그래서 저는 text-editor-compose라는 라이브러리를 만들기 시작했습니다.
GitHub - kaleidot725/text-editor-compose: A simple text editor library for Jetpack Compose
특징
text-editor-compose에는 다음과 같은 기능이 있습니다.
텍스트 수정
각 행의 텍스트를 편집하고 다음과 같이 텍스트를 추가 및 삭제합니다.
data:image/s3,"s3://crabby-images/7b1b0/7b1b0e6f1b98f1af12e7fdc0353285960b1a5383" alt=""
줄 바꿈
줄 바꿈을 삽입하거나 줄 바꿈을 삭제합니다.
data:image/s3,"s3://crabby-images/82023/82023df51feb1ec315cf389c216e968dd7d1a663" alt=""
줄 번호
줄 번호를 표시합니다.
data:image/s3,"s3://crabby-images/1342c/1342c8a034f5375dde757d6087337abaa9214af6" alt=""
선택한 라인
선택한 라인을 표시합니다.
data:image/s3,"s3://crabby-images/910fb/910fb012ccce6dba98cd5a38e459b2195b7a79f1" alt=""
로드맵
여러 줄 선택
여러 줄에 대한 복사 및 삭제는 지원되지 않습니다. 그래서 여러 줄 선택을 추가할 예정입니다.
data:image/s3,"s3://crabby-images/d84c0/d84c018ebee51fa331d5d3f2f94f87506cb38e87" alt=""
물리적 키보드
물리적 키보드는 지원되지 않습니다. 그래서 물리적 키보드 지원을 추가할 계획입니다.
data:image/s3,"s3://crabby-images/72859/728592202d32e304ffc91b1cc98fd5e910855240" alt=""
용법
이 라이브러리는 사용하기 쉽습니다. 종속성을 추가하고 코드를 작성하려면 아래 단계를 따르십시오.
1단계: build.gradle에 JitPack 저장소 추가
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
2단계: 종속 항목에 라이브러리 추가
dependencies {
implementation 'com.github.kaleidot725:text-editor-compose:0.1.0'
}
3단계: 텍스트 편집기 및 텍스트 EditorState 선언
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
SampleTheme {
val textEditorState by rememberTextEditorState(lines = DemoText.lines())
TextEditor(
textEditorState = textEditorState,
onUpdatedState = { },
modifier = Modifier.fillMaxSize()
)
}
}
}
}
4단계: 각 행에 표시되는 항목 맞춤설정
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
SampleTheme {
val textEditorState by rememberTextEditorState(lines = DemoText.lines())
TextEditor(
textEditorState = textEditorState,
onUpdatedState = { },
modifier = Modifier.fillMaxSize(),
decorationBox = { index, isSelected, innerTextField ->
val backgroundColor = if (isSelected) Color(0x8000ff00) else Color.White
Row(modifier = Modifier.background(backgroundColor)) {
Text(text = (index + 1).toString().padStart(3, '0'))
Spacer(modifier = Modifier.width(4.dp))
innerTextField(modifier = Modifier.fillMaxWidth())
}
}
)
}
}
}
}
결론
text-eiditor-compose는 최소한의 기능을 구현했습니다. 새로운 기능을 추가할 계획입니다.
GitHub - kaleidot725/text-editor-compose: A simple text editor library for Jetpack Compose
Reference
이 문제에 관하여(Jetpack Compose용 간단한 텍스트 편집기 라이브러리 만들기 시작), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/kaleidot725/start-creating-simple-text-editor-library-for-jetpack-compose-45jh텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)