Android样式的开发:Style篇

简介: 笔记

前面铺垫了那么多,终于要讲到本系列的终篇,整合所有资源,定义成统一的样式。

哪些该定义成统一的样式呢?举几个例子吧:

  1. 每个页面标题栏的标题基本会有一样的字体大小、颜色、对齐方式、内间距、外间距等,这就可以定义成样式;
  2. 很多按钮也都使用一致的背景、内间距、文字颜色、文字大小、文字的对齐方式等,这也可以定义成样式;
  3. 网络加载的进度条基本也都是一样的,同样可以定义成样式;
  4. 不喜欢系统的弹出框样式,那也可以自定义样式。


样式的定义


Android的样式一般定义在res/values/styles.xml文件中,其中有一个根元素,而具体的每种样式定义则是通过下的子标签</strong>来完成,<strong><style></strong>通过添加多个<strong><item></strong>来设置样式不同的属性。</div><div>另外,样式是可以继承的,可通过<strong><style></strong>标签的<strong>parent</strong>属性声明要继承的样式,也可通过点前缀 (.) 继承,点前面为父样式名称,后面为子样式名称。点前缀方式只适用于自定义的样式,若要继承Android内置的样式,则只能通过<strong>parent</strong>属性声明。</div><div>用个实例说明具体的用法吧,以下代码为Android 5.0系统默认的按钮样式:</div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22%3Cstyle%20name%3D%5C%22Widget.Material.Button%5C%22%3E%5Cn%20%20%20%20%3Citem%20name%3D%5C%22background%5C%22%3E%40drawable%2Fbtn_default_material%3C%2Fitem%3E%5Cn%20%20%20%20%3Citem%20name%3D%5C%22textAppearance%5C%22%3E%3Fattr%2FtextAppearanceButton%3C%2Fitem%3E%5Cn%20%20%20%20%3Citem%20name%3D%5C%22minHeight%5C%22%3E48dip%3C%2Fitem%3E%5Cn%20%20%20%20%3Citem%20name%3D%5C%22minWidth%5C%22%3E88dip%3C%2Fitem%3E%5Cn%20%20%20%20%3Citem%20name%3D%5C%22stateListAnimator%5C%22%3E%40anim%2Fbutton_state_list_anim_material%3C%2Fitem%3E%5Cn%20%20%20%20%3Citem%20name%3D%5C%22focusable%5C%22%3Etrue%3C%2Fitem%3E%5Cn%20%20%20%20%3Citem%20name%3D%5C%22clickable%5C%22%3Etrue%3C%2Fitem%3E%5Cn%20%20%20%20%3Citem%20name%3D%5C%22gravity%5C%22%3Ecenter_vertical%7Ccenter_horizontal%3C%2Fitem%3E%3C%2Fstyle%3E%22%2C%22id%22%3A%22DWXlq%22%7D"></div><div>其中,<strong>stateListAnimator</strong>指定状态改变时的动画,<strong>button_state_list_anim_material</strong>的代码如下:</div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22%3C!--%20res%2Fanim%2Fbutton_state_list_anim_material.xml%20--%3E%3C%3Fxml%20version%3D%5C%221.0%5C%22%20encoding%3D%5C%22utf-8%5C%22%3F%3E%3Cselector%20xmlns%3Aandroid%3D%5C%22http%3A%2F%2Fschemas.android.com%2Fapk%2Fres%2Fandroid%5C%22%3E%5Cn%20%20%20%20%3Citem%20android%3Astate_pressed%3D%5C%22true%5C%22%20android%3Astate_enabled%3D%5C%22true%5C%22%3E%5Cn%20%20%20%20%20%20%20%20%3Cset%3E%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%3CobjectAnimator%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3ApropertyName%3D%5C%22translationZ%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3Aduration%3D%5C%22%40integer%2Fbutton_pressed_animation_duration%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueTo%3D%5C%22%40dimen%2Fbutton_pressed_z_material%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueType%3D%5C%22floatType%5C%22%20%2F%3E%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%3CobjectAnimator%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3ApropertyName%3D%5C%22elevation%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3Aduration%3D%5C%220%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueTo%3D%5C%22%40dimen%2Fbutton_elevation_material%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueType%3D%5C%22floatType%5C%22%20%2F%3E%5Cn%20%20%20%20%20%20%20%20%3C%2Fset%3E%5Cn%20%20%20%20%3C%2Fitem%3E%5Cn%20%20%20%20%3C!--%20base%20state%20--%3E%5Cn%20%20%20%20%3Citem%20android%3Astate_enabled%3D%5C%22true%5C%22%3E%5Cn%20%20%20%20%20%20%20%20%3Cset%3E%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%3CobjectAnimator%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3ApropertyName%3D%5C%22translationZ%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3Aduration%3D%5C%22%40integer%2Fbutton_pressed_animation_duration%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueTo%3D%5C%220%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AstartDelay%3D%5C%22%40integer%2Fbutton_pressed_animation_delay%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueType%3D%5C%22floatType%5C%22%2F%3E%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%3CobjectAnimator%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3ApropertyName%3D%5C%22elevation%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3Aduration%3D%5C%220%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueTo%3D%5C%22%40dimen%2Fbutton_elevation_material%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueType%3D%5C%22floatType%5C%22%20%2F%3E%5Cn%20%20%20%20%20%20%20%20%3C%2Fset%3E%5Cn%20%20%20%20%3C%2Fitem%3E%5Cn%20%20%20%20%3Citem%3E%5Cn%20%20%20%20%20%20%20%20%3Cset%3E%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%3CobjectAnimator%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3ApropertyName%3D%5C%22translationZ%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3Aduration%3D%5C%220%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueTo%3D%5C%220%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueType%3D%5C%22floatType%5C%22%2F%3E%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%3CobjectAnimator%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3ApropertyName%3D%5C%22elevation%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3Aduration%3D%5C%220%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueTo%3D%5C%220%5C%22%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20android%3AvalueType%3D%5C%22floatType%5C%22%2F%3E%5Cn%20%20%20%20%20%20%20%20%3C%2Fset%3E%5Cn%20%20%20%20%3C%2Fitem%3E%3C%2Fselector%3E%22%2C%22id%22%3A%22QWuMT%22%7D"></div><div>可以看到,每种状态的动画为属性动画集,属性动画的用法请参考Property Animation篇。</div><div>现在我想继承<strong>Widget.Material.Button</strong>样式,改变背景和文字颜色,那么,代码如下:</div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22%3C!--%20res%2Fvalues%2Fstyles.xml%20--%3E%3Cresources%3E%5Cn%20%20%20%20%3Cstyle%20name%3D%5C%22ButtonNormal%5C%22%20parent%3D%5C%22%40android%3Astyle%2FWidget.Material.Button%5C%22%20%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22android%3Abackground%5C%22%3E%40drawable%2Fbg_btn_selector%3C%2Fitem%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22android%3AtextColor%5C%22%3E%40color%2Ftext_btn_selector%3C%2Fitem%3E%20%20%20%20%3C%2Fstyle%3E%3C%2Fresources%3E%22%2C%22id%22%3A%22yxsTw%22%7D"></div><div>其中,<strong>@drawable/bg_btn_selector</strong>和<strong>@color/text_btn_selector</strong>的实现请参照selector篇。</div><div>有些按钮,我只想改变文字颜色,但背景想让它透明,这时就可以用点前缀的方式继承以上的样式,代码如下:</div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22%3C!--%20res%2Fvalues%2Fstyles.xml%20--%3E%3Cresources%3E%5Cn%20%20%20%20%3Cstyle%20name%3D%5C%22ButtonNormal%5C%22%20parent%3D%5C%22%40android%3Astyle%2FWidget.Material.Button%5C%22%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22android%3Abackground%5C%22%3E%40drawable%2Fbg_btn_selector%3C%2Fitem%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22android%3AtextColor%5C%22%3E%40color%2Ftext_btn_selector%3C%2Fitem%3E%20%20%20%20%3C%2Fstyle%3E%5Cn%20%20%20%20%5Cn%20%20%20%20%3Cstyle%20name%3D%5C%22ButtonNormal.Transparent%5C%22%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22android%3Abackground%5C%22%3E%40drawable%2Fbg_btn_transparent%3C%2Fitem%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22android%3AtextColor%5C%22%3E%40color%2Ftext_btn_selector%3C%2Fitem%3E%20%20%20%20%3C%2Fstyle%3E%3C%2Fresources%3E%22%2C%22id%22%3A%22Z9mPp%22%7D"></div><div>引用的时候只要在相应的<strong>Button</strong>里添加<strong>style</strong>就可以了,代码如下:</div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22%3CButton%5Cn%20%20%20%20android%3Alayout_width%3D%5C%22wrap_content%5C%22%5Cn%20%20%20%20android%3Alayout_height%3D%5C%22wrap_content%5C%22%5Cn%20%20%20%20android%3AonClick%3D%5C%22onAction%5C%22%5Cn%20%20%20%20android%3Atext%3D%5C%22%40string%2Fbtn_action%5C%22%5Cn%20%20%20%20style%3D%5C%22%40style%2FButtonNormal.Transparent%5C%22%20%2F%3E%22%2C%22id%22%3A%225eRts%22%7D"></div><div>有时候,定义的样式太多,如果都放在<strong>styles.xml</strong>文件里,那这文件也太臃肿了。因此,可以将样式分类拆分成多个文件。Android系统本身也拆分为多个文件存放的,如下列表全都是样式文件:</div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22styles.xml%5Cnstyles_device_defaults.xml%5Cnstyles_holo.xml%5Cnstyles_leanback.xml%5Cnstyles_material.xml%5Cnstyles_micro.xml%5Cnthemes.xml%5Cnthemes_device_defaults.xml%5Cnthemes_holo.xml%5Cnthemes_leanback.xml%5Cnthemes_material.xml%5Cnthemes_micro.xml%22%2C%22id%22%3A%222eqv8%22%7D"></div><div>其中,主要分为两大类,styles定义了简单的样式,而themes则定义了主题。</div><div><br /></div><h1 id="UVg2m">主题</h1><div data-card-type="block" data-ready-card="hr"></div><div>以上的简单例子只用于单个<strong>View</strong>,这是样式最简单的用法。但样式的用法不只是用于单个<strong>View</strong>,也能用于<strong>Activity</strong>或整个<strong>Application</strong>,这时候需要在相应的<strong><activity></strong>标签或<strong><application>标签里设置</strong>android:theme<strong>属性,引用的其实也是</strong>style**,但一般称为主题。</div><div>Android系统提供了多套主题,查看Android的frameworks/base/core/res/res/values目录,就会看到有以下几个文件(目前为止):</div><ul><li><strong>themes.xml</strong>:低版本的主题,目标API level一般为10或以下</li><li><strong>themes_holo.xml</strong>:从API level 11添加的主题</li><li><strong>themes_device_defaults.xml</strong>:从API level 14添加的主题</li><li><strong>themes_material.xml</strong>:从API level 21添加的主题</li><li><strong>themes_micro.xml</strong>:应该是用于Android Wear的主题</li><li><strong>themes_leanback.xml</strong>: 还不清楚什么用</li></ul><div>不过在实际应用中,因为大部分都采用兼容包的,一般都会采用兼容包提供的一套主题:<strong>Theme.AppCompat</strong>。<strong>AppCompat</strong>主题默认会根据不同版本的系统自动匹配相应的主题,比如在Android 5.0系统,它会继承Material主题。不过这也会导致一个问题,不同版本的系统使用不同主题,就会出现不同的体验。因此,为了统一用户体验,最好还是自定义主题。</div><div>自定义主题也很简单,只要继承某一父主题,然后在<strong><activity></strong>标签或<strong><application></strong>中引用就可以了。</div><div>主题的定义示例如下:</div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22%3Cresources%3E%5Cn%20%20%20%20%3Cstyle%20name%3D%5C%22AppTheme%5C%22%20parent%3D%5C%22Theme.AppCompat%5C%22%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22windowActionBar%5C%22%3Efalse%3C%2Fitem%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22windowNoTitle%5C%22%3Etrue%3C%2Fitem%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22windowAnimationStyle%5C%22%3E%40style%2FWindowAnimation%3C%2Fitem%3E%5Cn%20%20%20%20%3C%2Fstyle%3E%5Cn%20%20%20%20%3C!--%20Standard%20animations%20for%20a%20full-screen%20window%20or%20activity.%20--%3E%5Cn%20%20%20%20%3Cstyle%20name%3D%5C%22WindowAnimation%5C%22%20parent%3D%5C%22%40android%3Astyle%2FAnimation.Activity%5C%22%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22activityOpenEnterAnimation%5C%22%3E%40anim%2Factivity_open_enter%3C%2Fitem%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22activityOpenExitAnimation%5C%22%3E%40anim%2Factivity_open_exit%3C%2Fitem%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22activityCloseEnterAnimation%5C%22%3E%40anim%2Factivity_close_enter%3C%2Fitem%3E%5Cn%20%20%20%20%20%20%20%20%3Citem%20name%3D%5C%22activityCloseExitAnimation%5C%22%3E%40anim%2Factivity_close_exit%3C%2Fitem%3E%20%20%20%20%3C%2Fstyle%3E%3C%2Fresources%3E%22%2C%22id%22%3A%22fY0kL%22%7D"></div><div>其中,<strong>WindowAnimation</strong>重新指定了<strong>Activity</strong>的转场动画,以下为<strong>activity_close_exit</strong>的示例代码:</div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22%3C!--%20res%2Fanim%2Factivity_close_exit.xml%20--%3E%3C%3Fxml%20version%3D%5C%221.0%5C%22%20encoding%3D%5C%22utf-8%5C%22%3F%3E%3Cset%20xmlns%3Aandroid%3D%5C%22http%3A%2F%2Fschemas.android.com%2Fapk%2Fres%2Fandroid%5C%22%5Cn%20%20%20%20android%3AshareInterpolator%3D%5C%22false%5C%22%5Cn%20%20%20%20android%3AzAdjustment%3D%5C%22top%5C%22%3E%5Cn%20%20%20%20%3Calpha%5Cn%20%20%20%20%20%20%20%20android%3AfromAlpha%3D%5C%220.0%5C%22%5Cn%20%20%20%20%20%20%20%20android%3AtoAlpha%3D%5C%221.0%5C%22%5Cn%20%20%20%20%20%20%20%20android%3Ainterpolator%3D%5C%22%40interpolator%2Fdecelerate_quart%5C%22%5Cn%20%20%20%20%20%20%20%20android%3AfillEnabled%3D%5C%22true%5C%22%5Cn%20%20%20%20%20%20%20%20android%3AfillBefore%3D%5C%22false%5C%22%5Cn%20%20%20%20%20%20%20%20android%3AfillAfter%3D%5C%22true%5C%22%5Cn%20%20%20%20%20%20%20%20android%3Aduration%3D%5C%22200%5C%22%20%2F%3E%5Cn%20%20%20%20%3Ctranslate%5Cn%20%20%20%20%20%20%20%20android%3AfromYDelta%3D%5C%228%25%5C%22%5Cn%20%20%20%20%20%20%20%20android%3AtoYDelta%3D%5C%220%5C%22%5Cn%20%20%20%20%20%20%20%20android%3AfillEnabled%3D%5C%22true%5C%22%5Cn%20%20%20%20%20%20%20%20android%3AfillBefore%3D%5C%22true%5C%22%5Cn%20%20%20%20%20%20%20%20android%3AfillAfter%3D%5C%22true%5C%22%5Cn%20%20%20%20%20%20%20%20android%3Ainterpolator%3D%5C%22%40interpolator%2Fdecelerate_quint%5C%22%5Cn%20%20%20%20%20%20%20%20android%3Aduration%3D%5C%22350%5C%22%20%2F%3E%3C%2Fset%3E%22%2C%22id%22%3A%22z0lUK%22%7D"></div><div>这是比较简单的视图动画,视图动画具体用法可参考View Animation篇。</div><div>接着,若要使用到整个Application,则在<strong>AndroidManifest.xml</strong>的<strong><application></strong>标签设置<strong>android:theme</strong>属性,示例代码如下:</div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22%3Capplication%5Cn%20%20%20%20android%3AallowBackup%3D%5C%22true%5C%22%5Cn%20%20%20%20android%3Aicon%3D%5C%22%40mipmap%2Fic_launcher%5C%22%5Cn%20%20%20%20android%3Alabel%3D%5C%22%40string%2Fapp_name%5C%22%5Cn%20%20%20%20android%3Atheme%3D%5C%22%40style%2FAppTheme%5C%22%3E%5Cn%20%20%20%20%3C!--%20activity%20here%20--%3E%3C%2Fapplication%3E%22%2C%22id%22%3A%22oPTQQ%22%7D"></div><div><br /></div><h1 id="X2JcU">写在最后</h1><div data-card-type="block" data-ready-card="hr"></div><div>至此,本系列所有文章就写完了,欢迎留言讨论。</div>

相关文章
|
5天前
|
搜索推荐 Android开发 开发者
探索安卓开发中的自定义视图:打造个性化UI组件
【10月更文挑战第39天】在安卓开发的世界中,自定义视图是实现独特界面设计的关键。本文将引导你理解自定义视图的概念、创建流程,以及如何通过它们增强应用的用户体验。我们将从基础出发,逐步深入,最终让你能够自信地设计和实现专属的UI组件。
|
6天前
|
Android开发 Swift iOS开发
探索安卓与iOS开发的差异和挑战
【10月更文挑战第37天】在移动应用开发的广阔舞台上,安卓和iOS这两大操作系统扮演着主角。它们各自拥有独特的特性、优势以及面临的开发挑战。本文将深入探讨这两个平台在开发过程中的主要差异,从编程语言到用户界面设计,再到市场分布的不同影响,旨在为开发者提供一个全面的视角,帮助他们更好地理解并应对在不同平台上进行应用开发时可能遇到的难题和机遇。
|
8天前
|
XML 存储 Java
探索安卓开发之旅:从新手到专家
【10月更文挑战第35天】在数字化时代,安卓应用的开发成为了一个热门话题。本文旨在通过浅显易懂的语言,带领初学者了解安卓开发的基础知识,同时为有一定经验的开发者提供进阶技巧。我们将一起探讨如何从零开始构建第一个安卓应用,并逐步深入到性能优化和高级功能的实现。无论你是编程新手还是希望提升技能的开发者,这篇文章都将为你提供有价值的指导和灵感。
|
6天前
|
存储 API 开发工具
探索安卓开发:从基础到进阶
【10月更文挑战第37天】在这篇文章中,我们将一起探索安卓开发的奥秘。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和建议。我们将从安卓开发的基础开始,逐步深入到更复杂的主题,如自定义组件、性能优化等。最后,我们将通过一个代码示例来展示如何实现一个简单的安卓应用。让我们一起开始吧!
|
7天前
|
存储 XML JSON
探索安卓开发:从新手到专家的旅程
【10月更文挑战第36天】在这篇文章中,我们将一起踏上一段激动人心的旅程,从零基础开始,逐步深入安卓开发的奥秘。无论你是编程新手,还是希望扩展技能的老手,这里都有适合你的知识宝藏等待发掘。通过实际的代码示例和深入浅出的解释,我们将解锁安卓开发的关键技能,让你能够构建自己的应用程序,甚至贡献于开源社区。准备好了吗?让我们开始吧!
20 2
|
8天前
|
Android开发
布谷语音软件开发:android端语音软件搭建开发教程
语音软件搭建android端语音软件开发教程!
|
12天前
|
移动开发 Java Android开发
探索Android与iOS开发的差异性与互联性
【10月更文挑战第32天】在移动开发的大潮中,Android和iOS两大平台各领风骚。本文将深入浅出地探讨这两个平台的开发差异,并通过实际代码示例,展示如何在各自平台上实现相似的功能。我们将从开发环境、编程语言、用户界面设计、性能优化等多个角度进行对比分析,旨在为开发者提供跨平台开发的实用指南。
34 0
|
Android开发 数据格式 XML
深入理解Android 自定义attr Style styleable以及其应用
<h1 class="title" style="margin:10px 0px; font-family:'lucida grande','lucida sans unicode',lucida,helvetica,'Hiragino Sans GB','Microsoft YaHei','WenQuanYi Micro Hei',sans-serif; line-height:1.5;
1171 0