Android. Программирование для профессионалов. 4-е издание



Download 21,53 Mb.
Pdf ko'rish
bet387/485
Sana13.07.2022
Hajmi21,53 Mb.
#787165
1   ...   383   384   385   386   387   388   389   390   ...   485
Bog'liq
Android Programmirovanie dlya professionalov 4-e izdanie 2020 Fillips Styuart Marsikano Gardner


20sp
3dp
name="AppTheme"
parent="
Theme.AppCompat.Light.DarkActionBar
">
name="colorPrimary">@color/colorPrimary
name="colorPrimaryDark">@color/colorPrimaryDark

name="colorAccent">@color/colorAccent
name="AppTheme"
parent="Theme.AppCompat.Light.DarkActionBar">

 
 
 
 
 
 
 
 

name="android:background">@color/dark_blue
m>

name="android:background">@color/dark_bluem>

bold

name="android:background">@color/dark_bluem>
name="StrongBeatBoxButton"
parent="@style/BeatBoxButton">
bold

name="AppTheme"
parent="Theme.AppCompat.Light.DarkActionBar">
...

name="android:background">@color/dark_bluem>
name="AppTheme"
parent="Theme.AppCompat
.Light.DarkActionBar
">
...
name="AppTheme"
parent="Theme.AppCompat">
name="colorPrimary">@color/
colorPrimaryred<
/item>
name="colorPrimaryDark">@color/
colorPrimary
Darkdark_red

name="colorAccent">@color/
colorAccentgrayitem>
name="Theme.AppCompat"
parent="Base.Theme.AppCompat" />
Тема 
Theme.AppCompat
наследует 
атрибуты 
от
Base.Theme.AppCompat
. Интересно, что 
Theme.AppCompat
не
переопределяет никакие атрибуты, а только содержит ссылку
на своего родителя.
Щелкните мышью по 
Base.Theme.AppCompat
с нажатой
клавишей (
Ctrl
). Android Studio сообщит, что тема уточняется
по ресурсам. Существует несколько разных версий этой темы в
зависимости от используемой версии Android.
name="Base.Theme.AppCompat"
parent="Base.V7.Theme.AppCompat">
name="Base.V7.Theme.AppCompat"
parent="Platform.AppCompat">

androidx.appcompat.app.AppCompatVie
wInflater

false

true

name="windowActionBarOverlay">false
name="Platform.AppCompat"
parent="android:Theme.Holo">
name="android:windowNoTitle">true
name="android:windowActionBar">false
?
attr/buttonBarStyle

?
attr/buttonBarButtonStyle
name="android:borderlessButtonStyle">?
attr/borderlessButtonStyle

...
name="Platform.AppCompat"
parent="android:Theme.Holo">
...
...
name="android:windowBackground">@color/backgrou
nd_material_dark

name="AppTheme"
parent="Theme.AppCompat">
@color/red
name="colorPrimaryDark">@color/dark_red
@color/gray
 
 
 
 

name="android:windowBackground">@color/soothing
_blue
name="Base.V7.Theme.AppCompat"
parent="Platform.AppCompat">
...
name="buttonStyle">@style/Widget.AppCompat.Butt
on

name="buttonStyleSmall">@style/Widget.AppCompat
.Button.Small

...
name="Widget.AppCompat.Button"
parent="Base.Widget.AppCompat.Button"/>
Стиль 
Widget.AppCompat.Button
самостоятельно никакие
атрибуты не определяет. Чтобы просмотреть его содержимое,
перейдите к его родителю. Вы увидите, что базовый стиль
существует 
в 
двух 
версиях. 
Выберите 
версию
values/values.xml
.
name="Base.Widget.AppCompat.Button"
parent="android:Widget">
name="android:background">@drawable/abc_btn_def
ault_mtrl_shape

?
android:attr/textAppearanceButton

48dip
88dip
true
true
name="android:gravity">center_vertical|center_h
orizontal

name="AppTheme"
parent="Theme.AppCompat">
name="colorPrimary">@color/red

name="BeatBoxButton"
parent="Widget.AppCompat.Button">
name="android:background">@color/dark_bluem>

name="android:textStyle">bold
name="AppTheme"
parent="Theme.AppCompat">
name="colorPrimary">@color/red
name="colorPrimaryDark">@color/dark_red
name="colorAccent">@color/gray
name="android:windowBackground">@color/soothing
_blue

name="BeatBoxButton"
parent="Widget.AppCompat.Button">
name="android:background">@color/dark_bluem>
name="Platform.AppCompat"
parent="android:Theme.Holo">
...
name="AppTheme"
parent="Theme.AppCompat">
...
name="BeatBoxButton"
parent="Widget.AppCompat.Button">
name="AppTheme"
parent="Theme.AppCompat">
...
name="BeatBoxButton"
parent="Widget.AppCompat.Button">
name="android:background">@drawable/button_beat
_box_normal

 
 
 
 
 
 
 
 

name="android:background">@drawable/button_beat
_box

(FlickrFetchr.kt)
class FlickrFetchr {
private val flickrApi: FlickrApi
init {
val retrofit: Retrofit =
Retrofit.Builder()
.baseUrl("https://api.flickr.com/")
.addConverterFactory(
ScalarsCon
verterFactoryGsonConverterFactory.create())
.build()
flickrApi 
=
retrofit.create(FlickrApi::class.java)
}
fun 
fetchPhotos():
LiveData<
StringList> {
val responseLiveData:
MutableLiveData = MutableLiveData()
 
 
 
 
 
 
 
 
val 
responseLiveData:
MutableLiveData
=
MutableLiveData()
val 
flickrRequest:
Call<
StringFlickrResponse> 
=
flickrApi.fetchPhotos()
flickrRequest.enqueue(object :
Callback<
StringFlickrResponse> {


override fun onFailure(call:
Call<
StringFlickrResponse>, t: Throwable) {
Log.e(TAG, "Failed to fetch
photos", t)
}
override fun onResponse(
call:
Call<
StringFlickrResponse>,
response:
Response<
StringFlickrResponse>
) {
Log.d(TAG, "Response received")
responseLiveData.value =
response.body()
val flickrResponse:
FlickrResponse? = response.body()
val photoResponse:
PhotoResponse? = flickrResponse?.photos
var galleryItems:
List = photoResponse?.galleryItems
?: mutableListOf()
galleryItems =
galleryItems.filterNot {
it.url.isBlank()
}
responseLiveData.value =
galleryItems
}
})
return responseLiveData


}
}
Обратите внимание, что Flickr не всегда возвращает для
изображения правильный 
url_s
. Код выше отфильтровывает
элементы галереи с пустыми значениями URL-адреса,
используя 
filterNot{...}
.
Наконец, измените код спецификатора типа 
LiveData
в
PhotoGalleryFragment
.
Листинг 24.28. Новые спецификаторы типов в
PhotoGalleryFragment (PhotoGalleryFragment.kt)
class PhotoGalleryFragment : Fragment() {
private lateinit var photoRecyclerView:
RecyclerView
override fun onCreate(savedInstanceState:
Bundle?) {
super.onCreate(savedInstanceState)
val flickrLiveData:
LiveData = FlickrFetchr().fetchPhotos()
 
 
 
 
 
 
 
 
val 
flickrLiveData:
LiveData
=
FlickrFetchr().fetchPhotos()
flickrLiveData.observe(
this,
Observer 
{
responseStringgalleryItems ->


Log.d(TAG, "Response received:
$
responseStringgalleryItems")
})
}
...
}
Запустите приложение PhotoGallery, чтобы протестировать
ваш парсер JSON. Вы должны увидеть вывод списка элементов
галереи 
ToString()
на панели 
Logcat
. Если вы хотите изучить
результаты более подробно, установите точку останова на
строке журнала 
Observer
и используйте отладчик для
проверки 
galleryItems
(рис. 24.7).
Рис. 24.7. Исследование ответа Flickr
Если 
выброшено 
исключение
UninitializedPropertyAccessException
, убедитесь, что
ваш веб-запрос отформатирован правильно. В некоторых
случаях (например, когда ключ API недействителен) Flickr API
возвращает правильный код ответа (
200
), но пустое тело
ответа, и Gson не сможет инициализировать ваши поздно
инициализированные модели.



Download 21,53 Mb.

Do'stlaringiz bilan baham:
1   ...   383   384   385   386   387   388   389   390   ...   485




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish