android 设置状态栏与标题背景颜色一致
必须在Android4.4以上版本才能设置状态栏颜色;
一、在单个Activity里面,设置状态栏的背景:
效果:
1、在Activity的布局根文件中添加属性:
- android:fitsSystemWindows="true" //不设置此属性,标题栏和系统状态栏会重叠
2、将第三方核心代码类 SystemBarTintManager 复制到自己的项目:
- /*
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- package com.xczl.smart.application;
- import android.annotation.SuppressLint;
- import android.annotation.TargetApi;
- import android.app.Activity;
- import android.content.Context;
- import android.content.res.Configuration;
- import android.content.res.Resources;
- import android.content.res.TypedArray;
- import android.graphics.drawable.Drawable;
- import android.os.Build;
- import android.util.DisplayMetrics;
- import android.util.TypedValue;
- import android.view.Gravity;
- import android.view.View;
- import android.view.ViewConfiguration;
- import android.view.ViewGroup;
- import android.view.Window;
- import android.view.WindowManager;
- import android.widget.FrameLayout.LayoutParams;
- import java.lang.reflect.Method;
- /**
- * Class to manage status and navigation bar tint effects when using KitKat
- * translucent system UI modes.
- *
- */
- public class SystemBarTintManager {
- static {
- // Android allows a system property to override the presence of the navigation bar.
- // Used by the emulator.
- // See https://github.com/android/platform_frameworks_base/blob/master/policy/src/com/android/internal/policy/impl/PhoneWindowManager.java#L1076
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
- try {
- Class c = Class.forName("android.os.SystemProperties");
- Method m = c.getDeclaredMethod("get", String.class);
- m.setAccessible(true);
- sNavBarOverride = (String) m.invoke(null, "qemu.hw.mainkeys");
- } catch (Throwable e) {
- sNavBarOverride = null;
- }
- }
- }
- /**
- * The default system bar tint color value.
- */
- public static final int DEFAULT_TINT_COLOR = 0x99000000;
- private static String sNavBarOverride;
- private final SystemBarConfig mConfig;
- private boolean mStatusBarAvailable;
- private boolean mNavBarAvailable;
- private boolean mStatusBarTintEnabled;
- private boolean mNavBarTintEnabled;
- private View mStatusBarTintView;
- private View mNavBarTintView;
- /**
- * Constructor. Call this in the host activity onCreate method after its
- * content view has been set. You should always create new instances when
- * the host activity is recreated.
- *
- * @param activity The host activity.
- */
- @TargetApi(19)
- public SystemBarTintManager(Activity activity) {
- Window win = activity.getWindow();
- ViewGroup decorViewGroup = (ViewGroup) win.getDecorView();
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
- // check theme attrs
- int[] attrs = {android.R.attr.windowTranslucentStatus,
- android.R.attr.windowTranslucentNavigation};
- TypedArray a = activity.obtainStyledAttributes(attrs);
- try {
- mStatusBarAvailable = a.getBoolean(0, false);
- mNavBarAvailable = a.getBoolean(1, false);
- } finally {
- a.recycle();
- }
- // check window flags
- WindowManager.LayoutParams winParams = win.getAttributes();
- int bits = WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS;
- if ((winParams.flags & bits) != 0) {
- mStatusBarAvailable = true;
- }
- bits = WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION;
- if ((winParams.flags & bits) != 0) {
- mNavBarAvailable = true;
- }
- }
- mConfig = new SystemBarConfig(activity, mStatusBarAvailable, mNavBarAvailable);
- // device might not have virtual navigation keys
- if (!mConfig.hasNavigtionBar()) {
- mNavBarAvailable = false;
- }
- if (mStatusBarAvailable) {
- setupStatusBarView(activity, decorViewGroup);
- }
- if (mNavBarAvailable) {
- setupNavBarView(activity, decorViewGroup);
- }
- }
- /**
- * Enable tinting of the system status bar.
- *
- * If the platform is running Jelly Bean or earlier, or translucent system
- * UI modes have not been enabled in either the theme or via window flags,
- * then this method does nothing.
- *
- * @param enabled True to enable tinting, false to disable it (default).
- */
- public void setStatusBarTintEnabled(boolean enabled) {
- mStatusBarTintEnabled = enabled;
- if (mStatusBarAvailable) {
- mStatusBarTintView.setVisibility(enabled ? View.VISIBLE : View.GONE);
- }
- }
- /**
- * Enable tinting of the system navigation bar.
- *
- * If the platform does not have soft navigation keys, is running Jelly Bean
- * or earlier, or translucent system UI modes have not been enabled in either
- * the theme or via window flags, then this method does nothing.
- *
- * @param enabled True to enable tinting, false to disable it (default).
- */
- public void setNavigationBarTintEnabled(boolean enabled) {
- mNavBarTintEnabled = enabled;
- if (mNavBarAvailable) {
- mNavBarTintView.setVisibility(enabled ? View.VISIBLE : View.GONE);
- }
- }
- /**
- * Apply the specified color tint to all system UI bars.
- *
- * @param color The color of the background tint.
- */
- public void setTintColor(int color) {
- setStatusBarTintColor(color);
- setNavigationBarTintColor(color);
- }
- /**
- * Apply the specified drawable or color resource to all system UI bars.
- *
- * @param res The identifier of the resource.
- */
- public void setTintResource(int res) {
- setStatusBarTintResource(res);
- setNavigationBarTintResource(res);
- }
- /**
- * Apply the specified drawable to all system UI bars.
- *
- * @param drawable The drawable to use as the background, or null to remove it.
- */
- public void setTintDrawable(Drawable drawable) {
- setStatusBarTintDrawable(drawable);
- setNavigationBarTintDrawable(drawable);
- }
- /**
- * Apply the specified alpha to all system UI bars.
- *
- * @param alpha The alpha to use
- */
- public void setTintAlpha(float alpha) {
- setStatusBarAlpha(alpha);
- setNavigationBarAlpha(alpha);
- }
- /**
- * Apply the specified color tint to the system status bar.
- *
- * @param color The color of the background tint.
- */
- public void setStatusBarTintColor(int color) {
- if (mStatusBarAvailable) {
- mStatusBarTintView.setBackgroundColor(color);
- }
- }
- /**
- * Apply the specified drawable or color resource to the system status bar.
- *
- * @param res The identifier of the resource.
- */
- public void setStatusBarTintResource(int res) {
- if (mStatusBarAvailable) {
- mStatusBarTintView.setBackgroundResource(res);
- }
- }
- /**
- * Apply the specified drawable to the system status bar.
- *
- * @param drawable The drawable to use as the background, or null to remove it.
- */
- @SuppressWarnings("deprecation")
- public void setStatusBarTintDrawable(Drawable drawable) {
- if (mStatusBarAvailable) {
- mStatusBarTintView.setBackgroundDrawable(drawable);
- }
- }
- /**
- * Apply the specified alpha to the system status bar.
- *
- * @param alpha The alpha to use
- */
- @TargetApi(11)
- public void setStatusBarAlpha(float alpha) {
- if (mStatusBarAvailable && Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
- mStatusBarTintView.setAlpha(alpha);
- }
- }
- /**
- * Apply the specified color tint to the system navigation bar.
- *
- * @param color The color of the background tint.
- */
- public void setNavigationBarTintColor(int color) {
- if (mNavBarAvailable) {
- mNavBarTintView.setBackgroundColor(color);
- }
- }
- /**
- * Apply the specified drawable or color resource to the system navigation bar.
- *
- * @param res The identifier of the resource.
- */
- public void setNavigationBarTintResource(int res) {
- if (mNavBarAvailable) {
- mNavBarTintView.setBackgroundResource(res);
- }
- }
- /**
- * Apply the specified drawable to the system navigation bar.
- *
- * @param drawable The drawable to use as the background, or null to remove it.
- */
- @SuppressWarnings("deprecation")
- public void setNavigationBarTintDrawable(Drawable drawable) {
- if (mNavBarAvailable) {
- mNavBarTintView.setBackgroundDrawable(drawable);
- }
- }
- /**
- * Apply the specified alpha to the system navigation bar.
- *
- * @param alpha The alpha to use
- */
- @TargetApi(11)
- public void setNavigationBarAlpha(float alpha) {
- if (mNavBarAvailable && Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
- mNavBarTintView.setAlpha(alpha);
- }
- }
- /**
- * Get the system bar configuration.
- *
- * @return The system bar configuration for the current device configuration.
- */
- public SystemBarConfig getConfig() {
- return mConfig;
- }
- /**
- * Is tinting enabled for the system status bar?
- *
- * @return True if enabled, False otherwise.
- */
- public boolean isStatusBarTintEnabled() {
- return mStatusBarTintEnabled;
- }
- /**
- * Is tinting enabled for the system navigation bar?
- *
- * @return True if enabled, False otherwise.
- */
- public boolean isNavBarTintEnabled() {
- return mNavBarTintEnabled;
- }
- private void setupStatusBarView(Context context, ViewGroup decorViewGroup) {
- mStatusBarTintView = new View(context);
- LayoutParams params = new LayoutParams(LayoutParams.MATCH_PARENT, mConfig.getStatusBarHeight());
- params.gravity = Gravity.TOP;
- if (mNavBarAvailable && !mConfig.isNavigationAtBottom()) {
- params.rightMargin = mConfig.getNavigationBarWidth();
- }
- mStatusBarTintView.setLayoutParams(params);
- mStatusBarTintView.setBackgroundColor(DEFAULT_TINT_COLOR);
- mStatusBarTintView.setVisibility(View.GONE);
- decorViewGroup.addView(mStatusBarTintView);
- }
- private void setupNavBarView(Context context, ViewGroup decorViewGroup) {
- mNavBarTintView = new View(context);
- LayoutParams params;
- if (mConfig.isNavigationAtBottom()) {
- params = new LayoutParams(LayoutParams.MATCH_PARENT, mConfig.getNavigationBarHeight());
- params.gravity = Gravity.BOTTOM;
- } else {
- params = new LayoutParams(mConfig.getNavigationBarWidth(), LayoutParams.MATCH_PARENT);
- params.gravity = Gravity.RIGHT;
- }
- mNavBarTintView.setLayoutParams(params);
- mNavBarTintView.setBackgroundColor(DEFAULT_TINT_COLOR);
- mNavBarTintView.setVisibility(View.GONE);
- decorViewGroup.addView(mNavBarTintView);
- }
- /**
- * Class which describes system bar sizing and other characteristics for the current
- * device configuration.
- *
- */
- public static class SystemBarConfig {
- private static final String STATUS_BAR_HEIGHT_RES_NAME = "status_bar_height";
- private static final String NAV_BAR_HEIGHT_RES_NAME = "navigation_bar_height";
- private static final String NAV_BAR_HEIGHT_LANDSCAPE_RES_NAME = "navigation_bar_height_landscape";
- private static final String NAV_BAR_WIDTH_RES_NAME = "navigation_bar_width";
- private static final String SHOW_NAV_BAR_RES_NAME = "config_showNavigationBar";
- private final boolean mTranslucentStatusBar;
- private final boolean mTranslucentNavBar;
- private final int mStatusBarHeight;
- private final int mActionBarHeight;
- private final boolean mHasNavigationBar;
- private final int mNavigationBarHeight;
- private final int mNavigationBarWidth;
- private final boolean mInPortrait;
- private final float mSmallestWidthDp;
- private SystemBarConfig(Activity activity, boolean translucentStatusBar, boolean traslucentNavBar) {
- Resources res = activity.getResources();
- mInPortrait = (res.getConfiguration().orientation == Configuration.ORIENTATION_PORTRAIT);
- mSmallestWidthDp = getSmallestWidthDp(activity);
- mStatusBarHeight = getInternalDimensionSize(res, STATUS_BAR_HEIGHT_RES_NAME);
- mActionBarHeight = getActionBarHeight(activity);
- mNavigationBarHeight = getNavigationBarHeight(activity);
- mNavigationBarWidth = getNavigationBarWidth(activity);
- mHasNavigationBar = (mNavigationBarHeight > 0);
- mTranslucentStatusBar = translucentStatusBar;
- mTranslucentNavBar = traslucentNavBar;
- }
- @TargetApi(14)
- private int getActionBarHeight(Context context) {
- int result = 0;
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.ICE_CREAM_SANDWICH) {
- TypedValue tv = new TypedValue();
- context.getTheme().resolveAttribute(android.R.attr.actionBarSize, tv, true);
- result = TypedValue.complexToDimensionPixelSize(tv.data, context.getResources().getDisplayMetrics());
- }
- return result;
- }
- @TargetApi(14)
- private int getNavigationBarHeight(Context context) {
- Resources res = context.getResources();
- int result = 0;
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.ICE_CREAM_SANDWICH) {
- if (hasNavBar(context)) {
- String key;
- if (mInPortrait) {
- key = NAV_BAR_HEIGHT_RES_NAME;
- } else {
- key = NAV_BAR_HEIGHT_LANDSCAPE_RES_NAME;
- }
- return getInternalDimensionSize(res, key);
- }
- }
- return result;
- }
- @TargetApi(14)
- private int getNavigationBarWidth(Context context) {
- Resources res = context.getResources();
- int result = 0;
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.ICE_CREAM_SANDWICH) {
- if (hasNavBar(context)) {
- return getInternalDimensionSize(res, NAV_BAR_WIDTH_RES_NAME);
- }
- }
- return result;
- }
- @TargetApi(14)
- private boolean hasNavBar(Context context) {
- Resources res = context.getResources();
- int resourceId = res.getIdentifier(SHOW_NAV_BAR_RES_NAME, "bool", "android");
- if (resourceId != 0) {
- boolean hasNav = res.getBoolean(resourceId);
- // check override flag (see static block)
- if ("1".equals(sNavBarOverride)) {
- hasNav = false;
- } else if ("0".equals(sNavBarOverride)) {
- hasNav = true;
- }
- return hasNav;
- } else { // fallback
- return !ViewConfiguration.get(context).hasPermanentMenuKey();
- }
- }
- private int getInternalDimensionSize(Resources res, String key) {
- int result = 0;
- int resourceId = res.getIdentifier(key, "dimen", "android");
- if (resourceId > 0) {
- result = res.getDimensionPixelSize(resourceId);
- }
- return result;
- }
- @SuppressLint("NewApi")
- private float getSmallestWidthDp(Activity activity) {
- DisplayMetrics metrics = new DisplayMetrics();
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) {
- activity.getWindowManager().getDefaultDisplay().getRealMetrics(metrics);
- } else {
- // TODO this is not correct, but we don't really care pre-kitkat
- activity.getWindowManager().getDefaultDisplay().getMetrics(metrics);
- }
- float widthDp = metrics.widthPixels / metrics.density;
- float heightDp = metrics.heightPixels / metrics.density;
- return Math.min(widthDp, heightDp);
- }
- /**
- * Should a navigation bar appear at the bottom of the screen in the current
- * device configuration? A navigation bar may appear on the right side of
- * the screen in certain configurations.
- *
- * @return True if navigation should appear at the bottom of the screen, False otherwise.
- */
- public boolean isNavigationAtBottom() {
- return (mSmallestWidthDp >= 600 || mInPortrait);
- }
- /**
- * Get the height of the system status bar.
- *
- * @return The height of the status bar (in pixels).
- */
- public int getStatusBarHeight() {
- return mStatusBarHeight;
- }
- /**
- * Get the height of the action bar.
- *
- * @return The height of the action bar (in pixels).
- */
- public int getActionBarHeight() {
- return mActionBarHeight;
- }
- /**
- * Does this device have a system navigation bar?
- *
- * @return True if this device uses soft key navigation, False otherwise.
- */
- public boolean hasNavigtionBar() {
- return mHasNavigationBar;
- }
- /**
- * Get the height of the system navigation bar.
- *
- * @return The height of the navigation bar (in pixels). If the device does not have
- * soft navigation keys, this will always return 0.
- */
- public int getNavigationBarHeight() {
- return mNavigationBarHeight;
- }
- /**
- * Get the width of the system navigation bar when it is placed vertically on the screen.
- *
- * @return The width of the navigation bar (in pixels). If the device does not have
- * soft navigation keys, this will always return 0.
- */
- public int getNavigationBarWidth() {
- return mNavigationBarWidth;
- }
- /**
- * Get the layout inset for any system UI that appears at the top of the screen.
- *
- * @param withActionBar True to include the height of the action bar, False otherwise.
- * @return The layout inset (in pixels).
- */
- public int getPixelInsetTop(boolean withActionBar) {
- return (mTranslucentStatusBar ? mStatusBarHeight : 0) + (withActionBar ? mActionBarHeight : 0);
- }
- /**
- * Get the layout inset for any system UI that appears at the bottom of the screen.
- *
- * @return The layout inset (in pixels).
- */
- public int getPixelInsetBottom() {
- if (mTranslucentNavBar && isNavigationAtBottom()) {
- return mNavigationBarHeight;
- } else {
- return 0;
- }
- }
- /**
- * Get the layout inset for any system UI that appears at the right of the screen.
- *
- * @return The layout inset (in pixels).
- */
- public int getPixelInsetRight() {
- if (mTranslucentNavBar && !isNavigationAtBottom()) {
- return mNavigationBarWidth;
- } else {
- return 0;
- }
- }
- }
- }
3、在Activity代码中进行设置:
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { //系统版本大于19
- setTranslucentStatus(true);
- }
- SystemBarTintManager tintManager = new SystemBarTintManager(this);
- tintManager.setStatusBarTintEnabled(true);
- tintManager.setStatusBarTintResource(R.color.title_green); //设置标题栏颜色,此颜色在color中声明
- }
- @TargetApi(19)
- private void setTranslucentStatus(boolean on) {
- Window win = getWindow();
- WindowManager.LayoutParams winParams = win.getAttributes();
- final int bits = WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS;
- if (on) {
- winParams.flags |= bits; // a|=b的意思就是把a和b按位或然后赋值给a 按位或的意思就是先把a和b都换成2进制,然后用或操作,相当于a=a|b
- } else {
- winParams.flags &= ~bits; //&是位运算里面,与运算 a&=b相当于 a = a&b ~非运算符
- }
- win.setAttributes(winParams);
- }
二、设置状态栏字体为黑色,判断版本,并添加代码:
效果:
- setContentView(R.layout.activity_login);
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { //系统版本大于19
- setTranslucentStatus(true);
- }
- SystemBarTintManager tintManager = new SystemBarTintManager(this);
- tintManager.setStatusBarTintEnabled(true);
- tintManager.setStatusBarTintResource(R.color.title_green);
- Class clazz = this.getWindow().getClass();
- try {
- int darkModeFlag = 0;
- Class layoutParams = Class.forName("android.view.MiuiWindowManager$LayoutParams");
- Field field = layoutParams.getField("EXTRA_FLAG_STATUS_BAR_DARK_MODE");
- darkModeFlag = field.getInt(layoutParams);
- Method extraFlagField = clazz.getMethod("setExtraFlags", int.class, int.class);
- if(true){
- extraFlagField.invoke(this.getWindow(),darkModeFlag,darkModeFlag);//状态栏透明且黑色字体
- }else{
- extraFlagField.invoke(this.getWindow(), 0, darkModeFlag);//清除黑色字体
- }
- }catch (Exception e){
- }
- }
- @TargetApi(19)
- private void setTranslucentStatus(boolean on) {
- Window win = getWindow();
- WindowManager.LayoutParams winParams = win.getAttributes();
- final int bits = WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS;
- if (on) {
- winParams.flags |= bits; // a|=b的意思就是把a和b按位或然后赋值给a 按位或的意思就是先把a和b都换成2进制,然后用或操作,相当于a=a|b
- } else {
- winParams.flags &= ~bits; //&是位运算里面,与运算 a&=b相当于 a = a&b ~非运算符
- }
- win.setAttributes(winParams);
- }
android 设置状态栏与标题背景颜色一致的更多相关文章
- android中在java代码中设置Button按钮的背景颜色
android中在java代码中设置Button按钮的背景颜色 1.设置背景图片,图片来源于drawable: flightInfoPanel.setBackgroundDrawable(getRes ...
- Android中设置控件的背景颜色的方式整理
版权声明:本文为博主原创文章,未经博主允许不得转载. 前言 在Android开发中,经常需要设置控件的背景颜色或者图片的src颜色. 效果图 代码分析 根据使用的方法不同,划分为 setBackgro ...
- android:改动PagerTabStrip中的背景颜色,标题字体的样式、颜色和图标以及指示条的颜色
1.改动PagerTabStrip中的背景颜色 我们在布局中直接设置background属性就可以: <android.support.v4.view.ViewPager android:id= ...
- iOS平台设置系统状态栏(通知栏、顶部状态栏)样式背景颜色或透明
5+App开发 状态栏 配置系统状态栏样式 iOS平台可支持对系统状态栏样式的配置,在应用manifest.json文件的plus->distribute->apple下添加UIStatu ...
- android:修改PagerTabStrip中的背景颜色,标题字体的样式、颜色和图标以及指示条的颜色
1.修改PagerTabStrip中的背景颜色 我们在布局中直接设置background属性即可: <android.support.v4.view.ViewPager android:id=& ...
- android:theme决定AlertDialog的背景颜色
最近遇到一个很奇怪的问题,两个项目弹出的dialog背景颜色不一样,一个是黑色的,一个是白色的,最后发现是AndroidManifest.xml文件里面application指定的android:th ...
- DevExpress.XtraGrid.Views 设置指定行的背景颜色 .
如需要将指定行的背景设置颜色,可参考以下示例 1.事件:CustomDrawCell 2.示例: private void gridView1_CustomDrawCell(object sender ...
- iOS 8 设置导航栏的背景颜色和背景图片
假设是storyboard 直接embed一个导航栏.然后在新出现的导航栏 选属性 选一下颜色就能够了 代码实现背景颜色改动:self.navigationController.navigationB ...
- Android设置状态栏颜色
1.代码设置if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { Window window = this.getWindow ...
随机推荐
- Linux shell相关
1 一些常见的问题及解决方法 <1> ssh登录不显示用户名跟路径 可能原因: ssh登录的用户没有配置shell 对应解决方案:在/etc/passwd文件对应用户那一行末尾添加/bin ...
- Laravel学习笔记(五)数据库 数据库迁移案例2——创建数据结构,数据表,修改数据结构
默认假设 所有的列在定义的时候都有默认的假设,你可以根据需要重写. Laravel假定每个表都有一个数值型的主键(通常命名为”id”),确保新加入的每一行都是唯一的.Laravel只有在每个表都有数值 ...
- 使用delphi+intraweb进行微信开发3—微信消息处理
示例代码已经放出!请移步使用delphi+intraweb进行微信开发1~4代码示例进行下载,虽为示例代码但是是从我项目中移出来的,封装很完备适于自行扩展和修改. 在第二讲使用delphi+intra ...
- php-建造者模式(Builder)解析
其与抽象模式相类似,都可以创建复杂的对象,但是抽象工厂更注重多个系列的产品对象,而Builder模式则着重于一步一步的构建一个复杂的对象,在最后一步才返回产品, 使用建造者模式的好处是: 1.将构造代 ...
- iOS10 权限适配
权限适配 这应该算iOS10系统适配的范畴,最近这两个都在弄,所以就直接和Xcode8适配一起写出来了. 在iOS10之后需要在Info.plist中,添加新的字段获取权限,否则在iOS10上运行会导 ...
- xcode 8 去除无用打印信息
更新Xcode8之后,控制台会默认打印一坨东西,屏蔽的方法如下:Xcode8里边 Edit Scheme-> Run -> Arguments, 在Environment Variable ...
- JS中offsetTop、clientTop、scrollTop、offsetTop各属性介绍
这里是javascript中制作滚动代码的常用属性 页可见区域宽: document.body.clientWidth;网页可见区域高: document.body.clientHeight;网页可见 ...
- golang在linux下的开发环境部署[未完]
uname -a Linux symons_laptop 4.8.2-1-ARCH #1 SMP PREEMPT Mon Oct 17 08:11:46 CEST 2016 x86_64 GNU/Li ...
- SequoiaDB 笔记
SequoiaDB 笔记 这几天翻了翻SequoiaDB的代码,记了点笔记.不保证下面内容的正确性(肯定有错的地方) 个人观感 优点 代码还不错,设计也算简洁. EDU和CB的使用让整个系统变得简单很 ...
- WebServices(转)
一.序言 大家或多或少都听过WebService(Web服务),有一段时间很多计算机期刊.书籍和网站都大肆的提及和宣传WebService技术,其中不乏很多吹嘘和做广告的成分.但是不得不承认的是Web ...