2026/04/02

오늘의 이야기



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

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

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

그것도 구글 Gemini로다가!

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

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

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


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




오늘의 이야기

웹 스크래핑 기법: 5가지 방법을 갖춘 종합 가이드

웹 스크래핑



• 웹 스크래핑은 프로그래밍 또는 특수 도구를 사용하여 웹사이트에서 데이터를 추출하는 데 사용되는 기술이다. 시장 조사, 데이터 분석, 콘텐츠 집계 및 경쟁 지능과 같은 작업에 유용합니다.

• 이 기사는 뷰티풀수프, 스크래피, 셀레늄 및 LLM을 사용하는 방법을 포함하여 웹 스크래핑에 대한 포괄적인 가이드를 제공한다.

• 태그와 속성을 포함한 HTML의 기본 사항을 설명하여 웹 페이지의 구조를 이해하는 데 도움을 준다.

• 선택기는 웹페이지에서 특정 요소를 정확히 찾아내는 데 사용되며 웹 스크래핑에 대한 윤리적 고려 사항이 논의된다.

• 코드와 함께 뷰티풀수프 및 요청 라이브러리를 사용한 웹 스크래핑의 단계별 시연이 제공됩니다.

• 강력한 웹 스크래핑 프레임워크인 스크래피는 코드 스니펫과 설명과 함께 도입됩니다.

• 셀레늄은 동적 웹 스크래핑을 위한 도구로 제시되며, 코드 예와 브라우저의 동작을 사용자 정의하기 위한 크롬 옵션에 대한 논의가 있다.

https://heartbeat.comet.ml/web-scraping-with-5-different-methods-all-you-need-to-know-403a59fceea0

Web Scraping With 5 Different Methods: All You Need to Know

Including how to use LangChain and LLMs for web scraping!

heartbeat.comet.ml





오늘의 이야기


#스하리1000명프로젝트

스치니들!
내가 만든 이 앱은, 내 폰에 오는 알림 중에서 중요한 키워드가 있는 경우
등록해둔 친구에게 자동으로 전달해주는 앱이야 📲

예를 들어, 카드 결제 알림을 와이프나 자녀에게 보내주거나
이번 달 지출을 달력처럼 확인할 수도 있어!

앱을 함께 쓰려면 친구도 설치 & 로그인해줘야 해.
그래야 친구 목록에서 서로 선택할 수 있으니까~
서로 써보고 불편한 점 있으면 알려줘 🙏

👉 https://play.google.com/store/apps/details?id=com.nari.notify2kakao





오늘의 이야기

구글 지도와 제트팩 구성 통합: 안드로이드 개발자를 위한 종합 가이드

구글 맵




• 이 포괄적인 튜토리얼은 구글 지도를 제트팩 컴포즈와 통합하는 단계별 가이드를 제공하여 안드로이드 개발자가 강력하고 대화형 지도 기반 애플리케이션을 만들 수 있도록 합니다.

• 가이드는 구성 지도 라이브러리를 프로젝트에 통합하기 위해 필요한 종속성 및 API 키를 설정하는 방법을 설명하는 것으로 시작합니다.

• 그런 다음 구글맵 구성 기능을 사용하여 기본 구글 맵을 만드는 것을 파고들어 개발자가 사용자 정의 가능한 카메라 위치가 있는 지도를 표시할 수 있습니다.

• 튜토리얼은 사용자 인터페이스 조정, 줌 제어 가능, 위성 보기 등 서로 다른 지도 유형 간 전환 등 다양한 지도 맞춤화 옵션을 탐색하는 과정을 진행한다.

• 지도에 마커를 추가하는 것은 구성 가능한 기능을 사용하는 간단한 마커, 다중 마커 및 맞춤형 마커의 예와 함께 자세히 설명된다.

• 가이드는 또한 사용자가 마커 정보 창을 클릭할 때 마커 정보 창에 추가 정보를 표시하여 마커를 대화형으로 만드는 방법을 보여준다.

• 마지막으로, 튜토리얼은 여러 좌표를 연결하여 지도에 경로를 그리는 방법을 보여주어 개발자에게 탐색 기반 응용 프로그램을 만들 수 있는 기능을 제공합니다.

https://medium.com/@ridvanozcan48/how-to-use-google-maps-in-jetpack-compose-step-by-step-android-guide-55aedac89e43

How to Use Google Maps in Jetpack Compose: Step-by-Step Android Guide

In this tutorial, we will guide you through the integration of Jetpack Compose and Google Maps to develop Android applications. Our…

medium.com





오늘의 이야기

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

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

• 핵심 아이디어는 드래그블 인디케이터라는 구성 가능한 지표를 만들어 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





오늘의 이야기

KMP: UI 및 Compose Multiplatform으로 안드로이드 앱을 iOS로 이동 ios • 이 기사는 코틀린 멀티플랫폼을 사용하여 기존 안드로이드 앱을 iOS로 마이그레이션하는 시리즈의 일부이다. 이 부분에서는 컴포즈 멀티플랫폼을 활용한 멀...