Android开发中Launcher3常见默认配置修改方法总结

本文实例讲述了Android开发中Launcher3常见默认配置修改方法。分享给大家供大家参考,具体如下:

Launcher概述

Launcher是开机完成后第一个启动的应用,用来展示应用列表和快捷方式、小部件等。Launcher作为第一个(开机后第一个启动的应用)展示给用户的应用程序,其设计的好坏影响到用户的体验,甚至影响用户购机的判断。所以很多品牌厂商都会不遗余力的对Launcher进行深度定制,如小米的MIUI、华为的EMUI等。Android默认的Launcher没有过多的定制,更加简洁,受到源生党的追捧,Google的Nexus系列手机基本都是用的源生Launcher,目前Android源生的Launcher版本是Launcher3,后面的相关内容也都是以Launcher3为基础。

Launcher3默认配置修改

1.如何设置默认页

res/values/Config.xml

<integer name="config_workspaceDefaultScreen">0</integer>

在Launcher3 桌面,不管在哪一页,按HOME 键,会回到默认页。

2.如何隐藏launcher3中的搜索框

① 在Launcher3/src/com/android/launcher3/Launcher.java中

注释updateGlobalIcons()方法调用,共两处。

public View getQsbBar() {
  if (mQsbBar == null) {
    mQsbBar = mInflater.inflate(R.layout.search_bar, mSearchDropTargetBar, false);
-       mSearchDropTargetBar.addView(mQsbBar);
  }
+    mQsbBar.setVisibility(View.GONE);
  return mQsbBar;
}
@Override
public void bindSearchablesChanged() { //注释该方法内容
/*    boolean searchVisible = updateGlobalSearchIcon();
  boolean voiceVisible = updateVoiceSearchIcon(searchVisible);
  if (mSearchDropTargetBar != null) {
    mSearchDropTargetBar.onSearchPackagesChanged(searchVisible, voiceVisible);
  }
*/
}

② 在Launcher3/src/com/android/launcher3/DynamicGrid.java中

// Layout the search bar
  //注释如下内容
/*    View qsbBar = launcher.getQsbBar();
  LayoutParams vglp = qsbBar.getLayoutParams();
  vglp.width = LayoutParams.MATCH_PARENT;
  vglp.height = LayoutParams.MATCH_PARENT;
  qsbBar.setLayoutParams(vglp);
*/

③ 在Launcher3/res/values/dimens.xml中
    -    <dimen name="dynamic_grid_search_bar_height">48dp</dimen>
    +    <dimen name="dynamic_grid_search_bar_height">18dp</dimen>

重新编译后即可看到效果。

3.如何调整原生Launcher3主界面的search框的大小?

修改如下:

定位打/packages/apps/Launcher3/res/values/dimens.xml。

<dimen name="dynamic_grid_edge_margin">3dp</dimen>//修改这个可以调整search框距离顶部距离。
<dimen name="dynamic_grid_search_bar_max_width">500dp</dimen>//search框的宽度,一般不需要调整。
<dimen name="dynamic_grid_search_bar_height">48dp</dimen>//search框的高度,不要调整为0,删除按钮需要占用一部分空间。

4.让主菜单部分应用按指定顺序排在前面?

添加res/values/arrays.xml:需要排序的应用:这里的item 内容一定要填写正确,否则会匹配不上,无法参与排序。

<?xml version="1.0" encoding="utf-8"?>
<resources>
<string-array name="apps_componentName" translatable="false">
  <item>ComponentInfo{com.android.vending/com.android.vending.AssetBrowserActivity}</item>
  <item>ComponentInfo{com.android.browser/com.android.browser.BrowserActivity}</item>
  <item>ComponentInfo{com.android.settings/com.android.settings.Settings}</item>
  <item>ComponentInfo{com.android.camera2/com.android.camera.CameraLauncher}</item>
  <item>ComponentInfo{com.android.mms/com.android.mms.ui.ConversationList}</item>
</string-array>
</resources>

src/com/android/launcher3/Utilities.java

 import java.util.Arrays;
 import java.util.List;
  public static List<String> getAppsComponentName(final Context context) {
    return Arrays.asList(context.getResources().getStringArray(R.array.apps_componentName));
  }
src/com/android/launcher3/LauncherModel.java
 protected int mPreviousConfigMcc;
  static List<String> appArray = new ArrayList<String>();
  LauncherModel(LauncherAppState app, IconCache iconCache, AppFilter appFilter) {
    ......
    mUserManager = UserManagerCompat.getInstance(context);
    appArray = Utilities.getAppsComponentName(context);
  }

添加如下sortApps 方法:apps 按arrays.xml 排序,在原来的排序基础上,将arrays.xml 配置的应用按顺序排在前面。arrays.xml中没有涉及到的应用,还是原来的顺序。

public static final void sortApps(ArrayList<AppInfo> apps) {
  int length = appArray.size();
  List<AppInfo> assignApps = new ArrayList<AppInfo>();
  for(int i=0;i<length;i++) {
    assignApps.add(i, null);
  }
  for(AppInfo app : apps){
    for(int k=0; k<length; k++){
      if (app.componentName.toString().equals(appArray.get(k))) {
        assignApps.set(k,app );
        continue;
      }
    }
  }
  for (int i =length -1;i > -1 ;i--) {
   AppInfo app = assignApps.get(i);
   if(app != null){
     apps.remove(app);
     apps.add(0, app);
   }
 }
 Log.d(TAG ,"The Apps List after Sort!");
}

src/com/android/launcher3/AppsCustomizePagedView.java

public void setApps(ArrayList<AppInfo> list) {
    if (!LauncherAppState.isDisableAllApps()) {
      ......
      SprdAppSortAddonStub.getInstance().sortApps(mApps);
      LauncherModel.sortApps(mApps);//在原来排序的基础上,再将arrays.xml中配置的应用按顺序排在前面。
      updatePageCountsAndInvalidateData();
    }
}
private void addAppsWithoutInvalidate(ArrayList<AppInfo> list) {
    ......
    // SPRD: bug375932 2014-12-02 Feature customize app icon sort.
    SprdAppSortAddonStub.getInstance().sortApps(mApps);
    LauncherModel.sortApps(mApps);//在原来排序的基础上,再将arrays.xml中配置的应用按顺序排在前面。
}

5.如何确定待机HOME界面布局使用的是哪个default_workspace文件?

src/com/android/launcher3/DynamicGrid.java

选择哪个default_workspace 和public DynamicGrid(Context context, Resources resources,int minWidthPx, int minHeightPx, int widthPx, int heightPx, int awPx, int ahPx)中的minWidthPx 和minHeightPx 以及该方法中创建的deviceProfiles 列表关。              
minWidthPx 、minHeightPx 值转换为dpi之后 ,deviceProfiles 列表与其进行比较,选择与当前屏幕大小最接近的deviceProfiles 的default_workSpace作为最终Home界面使用的default_workspace。

详细解释如下:

src/com/android/launcher3/DynamicGrid.java中

① deviceProfiles 列表如下:

deviceProfiles.add(new DeviceProfile("Super Short Stubby",
    255, 300, 2, 3, 48, 13, (hasAA ? 3 : 5), 48, R.xml.default_workspace_4x4));
deviceProfiles.add(new DeviceProfile("Shorter Stubby",
    255, 400, 3, 3, 48, 13, (hasAA ? 3 : 5), 48, R.xml.default_workspace_4x4));
deviceProfiles.add(new DeviceProfile("Short Stubby",
    275, 420, 3, 4, 48, 13, (hasAA ? 5 : 5), 48, R.xml.default_workspace_4x4));
deviceProfiles.add(new DeviceProfile("Stubby",
    255, 450, 3, 4, 48, 13, (hasAA ? 5 : 5), 48, R.xml.default_workspace_4x4));
deviceProfiles.add(new DeviceProfile("Nexus S",
    296, 491.33f, 4, 4, 48, 13, (hasAA ? 5 : 5), 48, R.xml.default_workspace_4x4));
deviceProfiles.add(new DeviceProfile("Nexus 4",
    335, 567, 4, 4, DEFAULT_ICON_SIZE_DP, 13, (hasAA ? 5 : 5), 56, R.xml.default_workspace_4x4));
deviceProfiles.add(new DeviceProfile("Nexus 5",
    359, 567, 4, 4, DEFAULT_ICON_SIZE_DP, 13, (hasAA ? 5 : 5), 56, R.xml.default_workspace_4x4));
deviceProfiles.add(new DeviceProfile("Large Phone",
    406, 694, 5, 5, 64, 14.4f, 5, 56, R.xml.default_workspace_5x5));
// The tablet profile is odd in that the landscape orientation
// also includes the nav bar on the side
deviceProfiles.add(new DeviceProfile("Nexus 7",
    575, 904, 5, 6, 72, 14.4f, 7, 60, R.xml.default_workspace_5x6));
// Larger tablet profiles always have system bars on the top & bottom
deviceProfiles.add(new DeviceProfile("Nexus 10",
    727, 1207, 5, 6, 76, 14.4f, 7, 64, R.xml.default_workspace_5x6));
deviceProfiles.add(new DeviceProfile("20-inch Tablet",
    1527, 2527, 7, 7, 100, 20, 7, 72, R.xml.default_workspace_4x4));

② 重新计算MinWidth 和MinHeigh  单位是dpi。

mMinWidth = dpiFromPx(minWidthPx, dm);
mMinHeight = dpiFromPx(minHeightPx, dm);

③ 创建mProfile,mProfile.defaultLayoutId 就是最终Home界面使用的default_workspace 的id。

mProfile中的defaultLayoutId 是哪个default_workspace 见DeviceProfile.java。

mProfile = new DeviceProfile(context, deviceProfiles,
        mMinWidth, mMinHeight,
        widthPx, heightPx,
        awPx, ahPx,
        resources);
src/com/android/launcher3/DeviceProfile.java
  DeviceProfile(Context context,
         ArrayList<DeviceProfile> profiles,
         float minWidth, float minHeight,
         int wPx, int hPx,
         int awPx, int ahPx,
         Resources res) { 

方法中:

④ 用屏幕宽高创建的点(PointF xy = new PointF(width, height))与 deviceProfiles中的w 和 h 创建的点(dimens = new PointF(widthDps, heightDps))进行比较,也就是从deviceProfiles 列表中找出和当前屏幕大小最接近的deviceProfiles。

DeviceProfile closestProfile = findClosestDeviceProfile(minWidth, minHeight, points);
......

⑤ 采用和当前屏幕大小最接近的deviceProfiles的default_workspace

defaultLayoutId = closestProfile.defaultLayoutId;

6.如何替换第三方应用在launcher上显示的图标?

在launcher/src/com/android/launcher3/IconCache.java中修改,

private CacheEntry cacheLocked(ComponentName componentName, ResolveInfo info,  private CacheEntry cacheLocked(ComponentName componentName, ResolveInfo info,
    HashMap<Object, CharSequence> labelCache) {
  CacheEntry entry = mCache.get(componentName);
  if (entry == null) {
    entry = new CacheEntry();
    mCache.put(componentName, entry);
    ComponentName key = LauncherModel.getComponentNameFromResolveInfo(info);
    if (labelCache != null && labelCache.containsKey(key)) {
      entry.title = labelCache.get(key).toString();
    } else {
      entry.title = info.loadLabel(mPackageManager).toString();
      if (labelCache != null) {
        labelCache.put(key, entry.title);
      }
    }
    if (entry.title == null) {
      entry.title = info.activityInfo.name;
    }
    Drawable icon;
    int index = sysIndexOf(componentName.getClassName());
    Log.i("jxt", "index:"+index+",Name:"+componentName.getClassName());
    icon = getFullResIcon(info);
    if (index >= 0) {
      entry.icon = Utilities.createIconBitmap(icon, mContext);
    } else {
      entry.icon = Utilities.createIconBitmap(
          /* SPRD: Feature 253522, Remove the application drawer view @{ */
          // getFullResIcon(info), mContext);
          icon, mContext, true);
    }
    /* 此处即为替换图标代码 {@*/
    if("第三方应用的componentName".equals(componentName.toString())){
      entry.icon = BitmapFactory.decodeResource(mContext.getResources(), R.drawable.xxx);
    }
    /* @} */
  }
  return entry;
}

7.如何去掉Launcher3的开机引导页面?

修改方案如下:

请定位到src/com/android/launcher3/LauncherClings.java文件:

class LauncherClings implements OnClickListener {
     ......
     private static final String TAG_CROP_TOP_AND_SIDES = "crop_bg_top_and_sides
    private static final boolean DISABLE_CLINGS = false;
    private static final boolean DISABLE_CLINGS = true;

8.为何Launcher3设置一些壁纸后,壁纸显示比预览图模糊?

预览的时候,没有做格式转化,所以显示正常!

在设置壁纸的时候,默认是采用jpeg格式转换的,导致转换后损耗了一些,设置壁纸后,某些对比度比较高的壁纸就显示的模糊!

修改方案:

默认修改为采用png格式转换!

android6.0之前的版本,请做如下修改:

定位到/packages/apps/Launcher3/的WallpaperCropActivity.java文件

1、String mOutputFormat = "jpg";//修改为"png"

2、

protected static String getFileExtension(String requestFormat) {
    String outputFormat = (requestFormat == null)
        ? "jpg"//修改为"png"
        : requestFormat;
    outputFormat = outputFormat.toLowerCase();
    return (outputFormat.equals("png") || outputFormat.equals("gif"))
        ? "png" // We don't support gif compression.
        : "jpg";
}

android6.0的版本,请做如下修改:

定位到/packages/apps/Launcher3/WallpaperPicker/src/com/android/gallery3d/common/BitmapCropTask.java文件

if (crop.compress(CompressFormat.JPEG, DEFAULT_COMPRESS_QUALITY, tmpOut))

修改为:

if (crop.compress(CompressFormat.PNG, DEFAULT_COMPRESS_QUALITY, tmpOut))

9. 6.0平台上Launcher3自带的壁纸路径是什么?

在6.0中,平台版本预置了一些壁纸资源,相关路径如下:

资源文件在:

packages/apps/Launcher3/WallpaperPicker/res/drawable-xhdpi/

字串文件在:

packages/apps/Launcher3/WallpaperPicker/res/values-nodpi/wallpapers.xml

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android开发入门与进阶教程》、《Android调试技巧与常见问题解决方法汇总》、《Android多媒体操作技巧汇总(音频,视频,录音等)》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

时间: 2017-11-02

Android笔记之:App应用之启动界面SplashActivity的使用

当前比较成熟一点的应用基本上都会在进入应用之显示一个启动界面.这个启动界面或简单,或复杂,或简陋,或华丽,用意不同,风格也不同.下面来观摩几个流行的应用的启动界面. 1. 货比三家以腾讯qq,新浪weibo,UC浏览器,游戏神庙逃亡等7个应用为例,比比看:(我认为最精美的界面应该是qq2012,虽然只有一张图,基本的应用名称,版本,图标这些信息都有,但是看着舒服,觉得美.) 2. 元素启动界面的本意是以友好用户界面来掩饰后台缓冲加载,让用户用平和等待的心情进入正常应用界面.但是因为启动界面是放在

Android 应用启动欢迎界面广告的实现实例

Android 应用启动欢迎界面广告 0.写在前面 在这篇教程中来实现一个类似于微信的的延迟3秒再进入主界面的效果. 1.项目准备 先新建一个空的android项目.里面只自带一个MainActivity,首先我们再新建一个Activity叫做WelcomeActivity继承自Activity. Activity代码如下: //package在此省略,根据实际自行添加 import android.app.Activity; import android.os.Bundle; import a

Android开发实现Launcher3应用列表修改透明背景的方法

本文实例讲述了Android开发实现Launcher3应用列表修改透明背景的方法.分享给大家供大家参考,具体如下: Launcher时开机完成后第一个启动的应用,用来展示应用列表和快捷方式.小部件等.Launcher作为第一个(开机后第一个启动的应用)展示给用户的应用程序,其设计的好坏影响到用户的体验,甚至影响用户购机的判断.所以很多品牌厂商都会不遗余力的对Launcher进行深度定制,如小米的MIUI.华为的EMUI等.Android默认的Launcher没有过多的定制,更加简洁,受到源生党的

详解Android中App的启动界面Splash的编写方法

一.Splash界面的作用 用来展现产品的Logo 应用程序初始化的操作 检查应用程序的版本 检查当前应用程序是否合法注册 二.界面的xml定义 写一个布局背景设置为产品的logo图片,再添加一个textview显示版本号. <TextView android:id="@+id/tv_splash_version" android:layout_width="wrap_content" android:layout_height="wrap_cont

Android实现向Launcher添加快捷方式的方法

本文实例讲述了Android实现向Launcher添加快捷方式的方法.分享给大家供大家参考.具体如下: 当我们在应用程序Launcher的桌面空白处长按触摸时,会出现一个对话框,提示选择要添加的桌面组件,如下图所示 选择快捷方式后,会弹出一个对话框,显示出了可添加快捷方式的Activity所属的应用程序的图标和名称的列表.当我们想把添加快捷方式的Activity添加到这一列表时,只需要在这个Activity注册时添加一个Action为android.intent.action.CREATE_SH

Android launcher中模拟按home键的实现

Android launcher中模拟按home键的实现 Intent mHomeIntent = new Intent(Intent.ACTION_MAIN); mHomeIntent.addCategory(Intent.CATEGORY_HOME); mHomeIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED);    getApplicationContext

Android6.0 Launcher2应用解析

在之前我们分析了Android6.0系统在启动时安装应用程序的过程,这些应用程序安装好之后,Launcher应用就负责把它们在桌面上展示出来. 一.AMS启动Launcher Launcher应用是在AMS的systemReady方法中直接调用startHomeActivityLocked启动的,下面是systemReady启动Launcher的代码. startHomeActivityLocked(mCurrentUserId, "systemReady");我们来看下这个函数,先调

Android的Launcher启动器中添加快捷方式及小部件实例

前言: 最近一直在看Launcher模块,经过差不多两个月学习,终于摸透了Launcher的一些主要功能实现,目前继续还处于 摸索状态.未看Launcher时,于我而言,只能膜拜,以为所有功能都是它实现的 :入门后,才发现,Launcher的很多功能只是 集成了框架/应用程序提供的功能.很多陌生的东西,只有接触了才感叹:"oh ,原来是这样的!" 添加快捷方式 今天先给大家分享下Launcher如何实现添加快捷方式(Shortcut) ,后续会慢慢增加其他方面的功能,帮助大家"

Android开发基础之创建启动界面Splash Screen的方法

本文实例讲述了Android开发基础之创建启动界面Splash Screen的方法.分享给大家供大家参考.具体如下: 启动界面Splash Screen在应用程序是很常用的,往往在启动界面中显示产品Logo.公司Logo或者开发者信息,如果应用程序启动时间比较长,那么启动界面就是一个很好的东西,可以让用户耐心等待这段枯燥的时间. Android 应用程序创建一个启动界面Splash Screen非常简单.比如创建一个工程MySample,主Acitity就叫MySample,创建另一个Activ

Android UI设计与开发之实现应用程序只启动一次引导界面

这篇文章算是对整个引导界面开发专题的一个终结了吧,个人觉得大部分的引导界面基本上都是千篇一律的,只要熟练掌握了一个,基本上也就没什么好说的了,要是在今后的开发中遇到了更好玩,更有趣的引导界面,博主也会在这里及时的跟大家分享,今天的内容主要是教大家的应用程序只有在第一次启动的时候显示引导界面,以后在启动程序的时候就不再显示了. 其实要想实现这样的效果,只要使用SharedPreferences类,就会让程序变的非常简单,下面来详细介绍一下这个类的使用方法 一.SharedPreferences的详

Android UI设计与开发之仿人人网V5.9.2最新版引导界面

这一篇我将会以人人网的引导界面为实例来展开详细的讲解,人人网的引导界面比较的新颖,不同于其他应用程序千篇一律的靠滑动来引导用户,而是以一个一个比较生动形象的动画效果展示在用户们的面前,有一种给人眼前一亮的感觉,话不多说,进入正题. 一.实现的效果图 欢迎界面: 引导界面1 引导界面 2 引导界面 3 二 .项目的目录结构 三.具体的编码实现 1.欢迎界面的xml布局,activity_welcome: <?xml version="1.0" encoding="utf-

Android UI设计与开发之使用ViewPager实现欢迎引导页面

本系列文章都会以一个程序的实例开发为主线来进行讲解,以求达到一个循序渐进的学习效果,这样更能加深大家对于程序为什么要这样写的用意,理论加上实际的应用才能达到事半功倍的效果,不是吗? 最下方有源码的下载地址,几乎源码的每一行都有注释,写的通俗易懂,非常清晰,如有不懂的可以留言,本博主一定尽心尽力,为大家答题解惑,希望大家多多支持,好的,话不多说,让我们回归到今天的正题. 一.实现的效果图 也许是养成了这样一个习惯,每次看别人的代码前,必须要先看实现的效果图达到了一个什么样的效果,是不是跟自己想要实

Android UI设计系列之自定义ListView仿QQ空间阻尼下拉刷新和渐变菜单栏效果(8)

好久没有写有关UI的博客了,刚刚翻了一下之前的博客,最近一篇有关UI的博客:Android UI设计系列之自定义Dialog实现各种风格的对话框效果(7) ,实现各种风格效果的对话框,在那篇博客写完后由于公司封闭开发封网以及其它原因致使博客中断至今,中断这么久很是惭愧,后续我会尽量把该写的都补充出来.近来项目有个需求,要做个和QQ空间类似的菜单栏透明度渐变和下拉刷新带有阻尼回弹的效果.于是花点时间动手试了试,基本上达到了QQ空间的效果,截图如下: 通过观察QQ空间的运行效果,发现当往上滚动时菜单

Android UI设计系列之自定义ViewGroup打造通用的关闭键盘小控件ImeObserverLayout(9)

转载请注明出处:http://blog.csdn.net/llew2011/article/details/51598682 我们平时开发中总会遇见一些奇葩的需求,为了实现这些需求我们往往绞尽脑汁有时候还茶不思饭不香的,有点夸张了(*^__^*)--我印象最深的一个需求是在一段文字中对部分词语进行加粗显示.当时费了不少劲,不过还好,这个问题最终解决了,有兴趣的童靴可以看一下:Android UI设计之<六>使用HTML标签,实现在TextView中对部分文字进行加粗显示. 之前产品那边提了这样

Android UI设计系列之自定义Dialog实现各种风格的对话框效果(7)

虽然Android给我们提供了众多组件,但是使用起来都不是很方便,我们开发的APK都有自己的风格,如果使用了系统自带的组件,总是觉得和应用的主题不着边际并且看起来也不顺心,那我们就需要自定义了,为了方便大家对自定义组件的学习,我接下来准备了几遍有关自定义的Dialog的文章,希望对大家有帮助. 在开发APK中最常见的估计就数弹出对话框了,这种对话框按照按钮数量来分大致是三种:一个按钮,两个按钮,三个按钮.现在要讲的就是按照按钮数量分为以上三类吧(当然了可以有更多的按钮,只要你愿意). 自定义Di

Android UI设计与开发之ViewPager介绍和简单实现引导界面

做Android开发加起来差不多也有一年多的时间了,总是想写点自己在开发中的心得体会与大家一起交流分享.共同进步,刚开始写也不知该如何下手,仔细想了一下,既然是刚开始写,那就从一个软件给人最直观的感受--UI设计开始写起吧,循序渐进,娓娓道来.博主在这里和大家一起学习,希望能多多支持,话不多说,下面就开始讲解UI设计的第一篇. 在讲解如何实现引导界面的效果之前,我想先详细介绍一下ViewPager类的使用和说明,因为这是开发引导界面最重要的类,没有之一. 一.ViewPager实现的效果图 二.

Android UI设计系列之自定义TextView属性实现带下划线的文本框(4)

在Android开发过程中,如果Android系统自带的属性不能满足我们日常开发的需求,那么就需要我们给系统控件添加额外的属性了.假如有个需求是实现带下划线的文本显示(下划线),如果不使用自定义属性的话实现起来也不太难(起码我认为的实现方式是有许多种的),今天就讲解一下如何使用自定义属性来实现上述带下划线的文本框吧.还好Android中自定义属性不是很复杂,也可以归纳为三步走吧. 老规矩,还是先贴出工程目录吧: 一.添加属性文件 在values文件夹中新建attrs.xml文件,在文件中新建属性

Android UI设计系列之自定义SwitchButton开关实现类似IOS中UISwitch的动画效果(2)

做IOS开发的都知道,IOS提供了一个具有动态开关效果的UISwitch组件,这个组件很好用效果相对来说也很绚丽,当我们去点击开关的时候有动画效果,但遗憾的是Android上并没有给我们提供类似的组件(听说在Android4.0的版本上提供了具有动态效果的开关组件,不过我还没有去看文档),如果我们想实现类似的效果那该怎么办了呢?看来又得去自定义了. 公司的产品最近一直在做升级,主要做的就是把界面做的更绚丽更美观给用户更好的体验(唉,顾客是上帝......),其中的设置功能中就有开关按钮,原来的开

Android UI设计系列之自定义DrawView组件实现数字签名效果(5)

最近项目中有个新的需求,用户在完交易需要进行输入支付密码付款的时候,要让用户签下自己的签名,提起到数字签名这个东西,感觉有点高大上,后来想想数字签名的原理也不是太复杂,主要实现原理就是利用了View的绘图原理,把用户在屏幕上的手指移动轨迹显示在屏幕上,接着把在屏幕上显示的轨迹View转换成一张图片,最后把图片保存到本地或者上传到服务器... 还是老规矩,首先看一下工程目录吧: public class DrawView extends View { /** * 签名画笔 */ private P