2026/04/02

오늘의 이야기

제트팩 구성에서 인스타그램과 같은 롱 프레스 및 드래그 가능한 회전목마 지표 작성

• 이 기사는 제트팩 컴포즈에서 인스타그램과 같은 긴 프레스와 드래그 가능한 캐러셀 표시기를 만드는 방법을 설명하여 코드 스니펫과 함께 자세한 단계별 가이드를 제공한다.

• 핵심 아이디어는 드래그블 인디케이터라는 구성 가능한 지표를 만들어 HorizontalPager와 함께 사용하는 것입니다.

• 드래그 가능 인디케이터 구성은 상자를 사용하여 각 인디케이터를 그리고 초기 스타일의 회색 색상으로 뒤로 그리기 수식어를 사용하여 래지로우를 사용하여 수평 행에 추가한다.

• 현재 선택에서 더 멀리 떨어진 이미지에 대해 지표 크기가 감소하는 시각적 효과를 생성하기 위해 현재 페이지 상태 및 지표 인덱스를 기반으로 각 지표 도트에 대해 스케일 팩터가 계산된다.

• 이 기사는 또한 지시자를 길게 누른 다음 포인터 입력 수정자와 DetectDragGesturesAfterLongPress suspend 기능을 사용하여 좌우 스크롤을 가능하게 하는 제스처의 구현을 다룬다.

• 마지막으로, 약간의 의도하지 않은 드래그가 캐러셀이 페이지를 전환하게 하지 않도록 하기 위해 드래그 임계값이 계산된다.

https://proandroiddev.com/create-instagram-like-long-press-and-draggable-carousel-indicators-in-jetpack-compose-ce16fa75bc1e

Create Instagram-like Long Press and Draggable Carousel Indicators in Jetpack Compose

We must have used this UX in the Instagram mobile app, where we can long press the carousel indicators section and then swipe left or right…

proandroiddev.com





오늘의 이야기


#스하리1000명프로젝트,
有时候和外劳说话很难,对吧?
我制作了一个简单的应用程序,可以帮助您!你用你的语言写作,其他人用他们的语言看到它。
它根据设置自动翻译。
超级方便,可以轻松聊天。有机会就来看看吧!
https://play.google.com/store/apps/details?id=com.billcoreatech.multichat416




오늘의 이야기

Appium을 사용한 안드로이드 제트팩 컴포즈 앱 자동화

안드로이드 UI



• 제트팩 컴포즈는 안드로이드에서 네이티브 사용자 인터페이스를 구축하기 위한 현대적인 툴킷입니다. 구성 가능한 기능을 기반으로 한 선언적 UI 프레임워크를 사용하여 UI 개발을 더 빠르고 쉽게 만듭니다.

• 그러나 제트팩 컴포즈는 UI 요소에 대한 안정적인 식별자를 제공하지 않아 아피움과 같은 도구로 테스트를 자동화하기 어려울 수 있다. 한 가지 대안은 '콘텐츠 설명'을 사용하는 것이지만 이는 접근성에 부정적인 영향을 미칠 수 있다.

• 이를 해결하기 위해 제트팩 컴포즈는 개발자가 테스트 목적으로 UI 트리의 노드를 고유하게 식별할 수 있는 '테스트태그' 속성을 도입했다. 그러나 UiAutomator2와 Appium은 현재 'testTag'의 인식을 지원하지 않는다.

• 해결 방법으로 개발자는 MainActivity.kt 파일의 'semantics { testTagsAsResourceId = true }' 구문을 사용하여 테스트 태그를 리소스 ID로 처리할 수 있습니다. 이를 통해 아피움은 리소스-id를 로케이터로 사용하여 요소와 상호 작용할 수 있으므로 보다 신뢰할 수 있는 테스트 자동화가 가능하다.

https://medium.com/@pourzand.p/automating-android-jetpack-compose-app-with-appium-70aa7a5f80e2

Automating Android Jetpack Compose app with Appium

Jetpack Compose is Android's endorsed modern toolkit for constructing native user interfaces. It streamlines and expedites the process of…

medium.com





오늘의 이야기

안드로이드 스튜디오의 Jellyfish 로부터 코드를 보호하기: 지적 재산권 보안 보장

코딩하는 여자 개발자



• 안드로이드 스튜디오에 제미니가 도입되면서 개발자들은 컨텍스트 기반 코드 제안과 자동 완성 기능을 제공할 수 있는 강력한 AI 도구에 접근할 수 있게 됐다. 그러나 민감하거나 독점적인 코드를 구글과 공유하면 지적 재산권 보호에 대한 우려가 제기될 수 있다.

• 민감한 코드를 보호하기 위해 안드로이드 스튜디오는 사용자가 제미니와의 프로젝트 코드 공유를 제어할 수 있는 사용자 정의 가능한 설정을 제공한다. 개발자는 모든 프로젝트 코드, 특정 프로젝트를 허용하거나 프로젝트 코드 공유를 선택할 수 있습니다.

• 포괄적인 보호를 보장하기 위해 개발자는 제외하려는 디렉토리의 상단 수준에서 .aiexclude라는 파일을 만들 수 있습니다. .gitignore와 유사한 이 파일은 별표(*)를 포함하여 모든 파일과 하위 폴더를 재귀적으로 제외할 수 있어 Gemini가 코드에 액세스하는 것을 방지할 수 있습니다.

• 제미니의 코드 완료 기능은 .aiexclude 파일을 사용할 때 비활성화될 수 있지만 개발자는 여전히 특정 코드베이스와 관련이 없는 일반 질문에 대해 도구를 활용할 수 있다.

https://proandroiddev.com/protect-your-code-from-gemini-in-android-studio-982a58e1ea2a

Protect your code from Gemini in Android Studio

The Studio Bot is great, but be sure you are not sharing proprietary code unintentionally

proandroiddev.com





오늘의 이야기


#billcorea #운동동아리관리앱
🏸 Schneedle,羽毛球俱乐部必备应用!
👉 比洞赛 – 记录分数并寻找对手 🎉
适合任何地方,独自一人、与朋友一起或在俱乐部! 🤝
如果你喜欢羽毛球,一定要尝试一下

前往应用程序👉 https://play.google.com/store/apps/details?id=com.billcorea.matchplay




오늘의 이야기

여러 가지 방법으로 다국어 앱을 만들어 보기는 합니다. 이번에는 fork 한 외국어 앱에 한국어를 담아 보도록 하겠습니다.  google gemini api을 호출하는 기능을 이용해 볼 생각입니다. 


 


# Gemini API Key AI********nPU

import google.generativeai as genai
import os
import re

baseDir = 'C:/workspaces/Smart-AutoClicker0510/'

GOOGLE_API_KEY = 'AI********nPU'
genai.configure(api_key=GOOGLE_API_KEY)


# for m in genai.list_models():
# if 'generateContent' in m.supported_generation_methods:
# print(m.name)

def geminiFunc(orgString):
model = genai.GenerativeModel('gemini-pro')
prompt = '''
Translate English sentences '{0}' into Korean naturally. Use expressions that feel natural to Korean speakers.
'''.format(orgString)
response = model.generate_content(prompt)
try:
rValue = response.text
except:
rValue = ''
for item in response.parts:
rValue = rValue + item
rValue = re.sub("'","", rValue)
return rValue.strip()


def getTranslate(line):
xList = line.split('>')
try:
xItem = xList[1].split('<')[0]
except:
xItem = xList[1]
return geminiFunc(xItem)


def getName(line):
xName = line.strip().split('"')
return xName[1]


def doRead(path, fileName):
path = re.sub(r"\\", '/', path)
xPath = path.split('/')
xPath[xPath.index('values')] = 'values-ko'
nPath = '/'.join(xPath)
f = open(fileName, 'r', encoding='UTF-8')
if not os.path.isdir(nPath):
os.makedirs(nPath)
ot = open(os.path.join(nPath, 'strings.xml'), 'w', encoding='UTF-8')
rValue = ''
rName = ''
addTy = False
while True:
line = f.readline()
if not line: break
if line.strip() == '': continue
try:
if line.strip().startswith('<string name') and '</string>' in line and 'false' not in line:
rValue = getTranslate(line)
rName = getName(line)
rValue = '<string name="{0}">{1}</string>'.format(rName, rValue)
print(rValue.strip())
ot.write(rValue + '\n')
addTy = False
elif line.strip().startswith('<string name') and '</string>' not in line and 'false' not in line:
rValue = line.strip().split('>')[1]
rName = getName(line)
addTy = True
elif addTy and '</string' in line:
rValue += line.strip().split('<')[0]
rValue = geminiFunc(rValue)
rValue = '<string name="{0}">{1}</string>'.format(rName, rValue)
print(rValue.strip())
ot.write(rValue + '\n')
rValue = ''
addTy = False
else:
if addTy:
rValue += line
else:
rValue = line
print(rValue.strip())
ot.write(rValue + '\n')
except:
print(path, fileName, line)
ot.close()
f.close()


print('JOB START...')
for (root, directory, files) in os.walk(baseDir):
for file in files:
if not ('values-' not in root and 'strings.xml' in file): continue
print(root, file)
doRead(root, os.path.join(root, file))
print('JOB END...')

 


이전 글에서도 한번 해 보았던 기억이 있기는 합니다. 이번에 조금 더 수정을 해 보았습니다.


 


실행결과



 


이번에는 앱에 정리 되어 있는 strings.xml 파일을 찾아서 한 줄씩 읽어 한국어 파일을 만들고 values-ko 폴더에 저장하는 것 까지을 한 번에 해 보았습니다. 그렇게 하고 앱을 실행해 보면 한국 어을 모르던 앱이 한국어를 표시하게 됩니다. 


 


다만,  gemini api 을 호출할 때 번역을 조금 자연스럽게 해 달라고 prompt을 만들었더니, 조금은 앱이 이상한(?) 표현을 할 수 도 있습니다.


 



prompt = '''
Translate English sentences '{0}' into Korean naturally. Use expressions that feel natural to Korean speakers.
'''.format(orgString)


 


번역은 자연스럽게 하기는 하겠지만, 그런 것이 앱에서 표현 되는 게 맞는 가 싶기도 합니다.  아무튼...


 


번역된 앱 실행 모습



 


한국어로 표시를 하기 시작했습니다. ㅋ~


 


한국어가 표시 되도록 수정된 github 링크을 공유해  드려요.   원작자의 코드을 fork 해서 수정한 버전 임을 알려 드려요.


 


https://github.com/nari4169/Smart-AutoClicker



 


GitHub - nari4169/Smart-AutoClicker: An open-source auto clicker on images for Android


An open-source auto clicker on images for Android. Contribute to nari4169/Smart-AutoClicker development by creating an account on GitHub.


github.com




 


 





오늘의 이야기

MAD(Modern Android Development)란 무엇인가?

• MAD(Modern Android Development)는 최신 기술을 사용하여 더 나은 앱을 더 빠르고 쉽게 구축하는 방법을 알려주는 일련의 비디오 및 기사입니다.

• MAD는 단순히 코드를 작성하는 것이 아니라 예외적인 경험을 만드는 것에 관한 것입니다.

• 시각적으로 놀라울 뿐만 아니라 쉽게 매끄럽고 성능이 뛰어난 앱을 구축하기 위해 최신 도구와 모범 사례의 힘을 활용하는 것입니다.

• MAD의 핵심 구성 요소는 직관적 인터페이스, 반응성능, 원활한 데이터 관리, 모듈러 아키텍처, 현대 공구입니다.

• 직관적 인터페이스는 제트팩 컴포즈와 자재 3이 조화롭게 작동하여 손끝이 자연스럽게 확장된 것처럼 느껴지는 아름답고 사용자 친화적인 UI를 만듭니다.

• 반응성능은 Kotlin Coroutines and Flow가 동시성과 반응성의 힘을 발휘하여 무거운 부하에도 앱을 반응성 있고 효율적으로 유지합니다.

• 원활한 데이터 관리를 위해 Ktor와의 강력한 네트워킹에서 Room과의 오프라인 지속성에 이르기까지 앱이 필요한 데이터에 언제 어디서나 액세스할 수 있도록 보장합니다.

https://zoewave.medium.com/production-mad-android-app-726c2e0bcf3f

Pro Modern Android Dev (MAD)

This doc tries to manage the complexity of a MAD*

zoewave.medium.com





오늘의 이야기


#스하리1000명프로젝트,
韓国で迷子になりましたか?韓国語が話せなくても、このアプリを使えば簡単に移動できます。
あなたの言語で話すだけで、翻訳、検索が行われ、結果があなたの言語で表示されます。
旅行者に最適!英語、日本語、中国語、ベトナム語などを含む 10 以上の言語をサポートします。
今すぐ試してみましょう!
https://play.google.com/store/apps/details?id=com.billcoreatech.opdgang1127




2026/04/01

오늘의 이야기

build gradle 설정'



오늘 갑자기 빌드를 하는데... 오류가 나왔습니다. 


FAILURE: Build failed with an exception.

* What went wrong:
Circular dependency between the following tasks:
:app:extractDeepLinksDemoDebug
\--- :app:injectCrashlyticsMappingFileIdDemoDebug
\--- :app:kspDemoDebugKotlin
\--- :app:processDemoDebugResources
+--- :app:mapDemoDebugSourceSetPaths
| \--- :app:injectCrashlyticsMappingFileIdDemoDebug (*)
+--- :app:mergeDemoDebugResources
| \--- :app:injectCrashlyticsMappingFileIdDemoDebug (*)
+--- :app:parseDemoDebugLocalResources
| \--- :app:packageDemoDebugResources
| \--- :app:injectCrashlyticsMappingFileIdDemoDebug (*)
+--- :app:processDemoDebugManifest
| \--- :app:processDemoDebugMainManifest
| \--- :app:extractDeepLinksDemoDebug (*)
\--- :app:processDemoDebugManifestForPackage
\--- :app:processDemoDebugManifest (*)

 


 


구글링을 통해 알아본 바로는...


 


https://github.com/firebase/firebase-android-sdk/issues/5930



 


"Circular dependency" with `injectCrashlyticsMappingFileId` task in `firebase-crashlytics-gradle` version `3.0.0` · Issue #593


[READ] Step 1: Are you in the right place? yes [REQUIRED] Step 2: Describe your environment Using https://github.com/android/nowinandroid on main at commit afad1b9a [REQUIRED] Step 3: Describe the ...


github.com




 


이 글에서 원인을 찾을 수 있었습니다.


 


buildscript {
ext {
compose_version = '1.6.0'
raamcosta_version = '1.9.54'
}
dependencies {
classpath 'com.android.tools.build:gradle:8.4.0'
classpath 'com.google.gms:google-services:4.4.1'
classpath 'com.google.firebase:firebase-crashlytics-gradle:2.9.9' // 3.0.0 에서는 빌드 오류 ?
}
}// Top-level build file where you can add configuration options common to all sub-projects/modules.
plugins {
id 'com.android.application' version '8.4.0' apply false
id 'com.android.library' version '8.4.0' apply false
id 'org.jetbrains.kotlin.android' version '1.9.23' apply false
}

 


com.google.firebase:firebase-crashlytics-gradle 가 패치가 되기는 한 것 같은데... 그것이 오류를 발생시키고 있다는 사실을...


 


다음 확인이 될 때 까지는 패치를 적용할 수 없을 것 같습니다.  ㅠㅠ


 


 





오늘의 이야기

안드로이드 오리엔테이션 API 업데이트: 정밀한 장치 오리엔테이션 측정을 위한 센서 융합

compass



• 안드로이드의 새로운 오리엔테이션 API는 가속도계, 자이로스코프, 자력계 데이터를 융합하여 장치 오리엔테이션 계산을 단순화합니다. 따라서 보다 정확하고 일관된 측정을 제공합니다.

• API를 사용하려면 Google Play 위치 서비스를 버전 21.2.0으로 업데이트하고 융합 오리엔테이션 제공업체 클라이언트를 얻습니다.

• 원하는 대기 시간 및 실행기를 지정하여 오리엔테이션 업데이트를 수신하기 위해 청취자를 등록합니다. API는 앱이 전경에 있을 때만 샘플을 제공합니다.

• API는 방향 정보에 액세스하기 위한 다양한 방법을 제공하며, 여기에는 방향, 방향 오류 및 태도가 포함된다.

• 이전에는 개발자가 가속도계 및 자이로스코프 데이터에서 회전 행렬과 방향 각도를 수동으로 계산해야 했다. 새로운 API는 이 프로세스를 단순화합니다.

• 융합된 배향 API의 구현을 입증하기 위해 샘플 코드가 제공된다.

• API를 제트팩 컴포즈, 힐트 및 지도 회전을 위한 저장소와 통합하는 예도 포함된다.

https://proandroiddev.com/update-for-your-compass-new-android-orientation-api-dc4e5c25ca35

Update For Your Compass — New Android Orientation API

Android provides a new Fused Orientation API from multiple sensors

proandroiddev.com





오늘의 이야기



#스치니1000프로젝트 #재미 #행운기원 #Compose #Firebase

🎯 야 너 토요일마다 로또 확인하냐?
나도 맨날 "혹시나~" 하면서 봤거든 ㅋㅋ

근데 이제는 그냥 안 해
AI한테 맡겼어 🤖✨

그것도 구글 Gemini로다가!

그래서 앱 하나 만들었지
👉 "로또 예상번호 by Gemini" 🎱

AI가 분석해서 번호 딱! 뽑아줌
그냥 보고 참고만 하면 됨

재미로 해도 좋고…
혹시 모르는 거잖아? 😏


https://play.google.com/store/apps/details?id=com.billcorea.gptlotto1127




오늘의 이야기

클라우드 기능 활용한 이메일 발송법, 파이어스토어&파이어베이스-메일 발송 자동 메일링 • 이 블로그 게시물은 클라우드 기술을 사용하여 이메일을 더 쉽게 보낼 수 있는 방법을 설명합니다. 특히 신규 가입자...