gdgand / composecamp2022-for-beginners Goto Github PK
View Code? Open in Web Editor NEWhttps://developersonair.withgoogle.com/events/composecamp_22kr
https://developersonair.withgoogle.com/events/composecamp_22kr
기본 Theme의 경우 프로젝트 네임에 따라 Theme이 생성되는데, 프로젝트를 생성할 시 _HappyBirthday_라는 프로젝트로 생성하기에_HappyBirthdayTheme()_이 올바릅니다.
11의 솔루션 코드 가져오기 역시 HappyBirthdayTheme이라고 기재되어 있어 헛갈릴 수도 있어서 Issue를 통해 글 남깁니다!
Art Space
코드랩 진행중에 있습니다.
코드랩 본문에 간략한 내용만 있는데요.
실습에 진행할 이미지나 텍스트는 임의로 사용해도 괜찮을까요?
코드랩 주소는 아래와 같습니다.
코드랩에 있는대로 하드코딩 문자열을 추출하고 있습니다.
코드랩의 내용대로면 추출시 stringResource(R.string.happy_birthday_text)
로 추출이 되는데요.
제 PC에서 진행해보니 getString(R.string.happy_birthday_text)
로 추출이 됨을 확인했습니다.
stringResource
를 호출하나, getString
을 호출하나, 둘다 정상동작함은 확인하였는데요.
두 함수간의 동작에 차이가 있는지요?
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
HappyBirthdayTheme {
Surface(color = MaterialTheme.colors.background) {
BirthDayGreetingWithImage(
getString(R.string.happy_birthday_text),
getString(R.string.signature_text)
)
}
}
}
}
}
Unit2 - TipTime
코드랩 -> 맞춤 팁 계산하기 -> 5.키보드 작업 설정
TipTimeScreen() -> EditNumberField() 로 되어 있음.
영문)
In the TipTimeScreen() function, add a val variable named focusManager and assign it a value of LocalFocusManager.current property:한글)
EditNumberField() 함수에서 focusManager라는 val 변수를 추가하고 LocalFocusManager.current 속성 값을 할당합니다.
Modifer는 어떻게 적용되고 순서는 어떠한 방향으로 적용되는 건가요?
calculateTip
함수에서 사용하는 NumberFormat.getCurrencyInstance().format(tip)
부분이 예상대로 동작하지 않습니다.private fun calculateTip(
amount: Double,
tipPercent: Double = 15.0,
roundUp: Boolean
): String {
var tip = tipPercent / 100 * amount
if (roundUp)
tip = kotlin.math.ceil(tip)
return NumberFormat.getCurrencyInstance().format(tip)
}
NumberFormat.getCurrencyInstance().format(tip)
실행했을 때 소수점이 잘려서 나옵니다.
아예 그 함수 안에서
val tipa: Double = 46.331
val tipa2 = NumberFormat.getCurrencyInstance().format(tipa)
println("tipa2? $tipa2")
로 콘솔 찍어봐도 소수점 잘려서 나옵니다.
달라와 원화 차이인지 모르겠네요.
Kotlin Playground에서는 잘 작동합니다.
https://developer.android.com/codelabs/basic-android-kotlin-compose-text-composables#4
@Composable
fun BusinessCard(
modifier: Modifier
) {
Column() {
Column(
modifier = modifier.weight(7f)
) {
BusinessCardTop(
modifier = modifier
)
}
Column(
modifier = modifier.weight(3f)
) {
BusinessCardInfo(
modifier = modifier
)
}
}
}
// 위 처럼 중복되는 값이 없더라도 최상단에서 val modifier = Modifier 객체를 넘겨주어 계속해서 재사용할 것인지
// 아니라면 아래처럼 중복되지 않을경우 매개변수로 받지 않고 그때 그때 생성해서 주고 중복되는 함수 윗단계에서 만들고 넘겨줄 것인지
@Composable
fun BusinessCard(
) {
Column() {
Column(
modifier = Modifier.weight(7f)
) {
BusinessCardTop(
)
}
Column(
modifier = Modifier.weight(3f)
) {
val paddingModifier = Modifier
.padding(start = 48.dp, top = 8.dp, bottom = 8.dp)
BusinessCardInfo(
modifier = paddingModifier
)
}
}
}
// CardInfo 내부
@Composable
fun BusinessCardInfo(
modifier: Modifier
) {
Column {
Column(
modifier = modifier
) {
BusinessCardInfoText(
)
}
Column(
modifier = modifier
) {
BusinessCardInfoText(
)
}
Column(
modifier = modifier
) {
BusinessCardInfoText(
)
}
}
}
Unit2의 Pathway2, Pathway3의 코드들이 모두 작성되어있는데, 새로 프로젝트를 만들어서 PR 올려야하나요.
기존에 같은 질문이 있었는지 확인했습니다.
라벨이 변경되지않아 Unit1으로 작성하였습니다.
A declarative, efficient, and flexible JavaScript library for building user interfaces.
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google ❤️ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.