全部 文章 问答 分享 共找到161个相关内容
[文章] 地图 Android SDK 绘制点标记 绘制自定义 Marker
最近工作项目中用到了地图需要在地图上绘制标记点大概是这个样子按官方给出代码设置是这样的MarkerOptionsmarkerOption=newMarkerOptions();markerOption.position
2023-11-10 09:32 · 高德地图amapp
[问答] Android能否集成静态地图?
额,官方提供的是离线地图,第一次需要联网下载离线地图,后续就不需要网络了,那如果没有网络怎么办呢(话说这年头没有谁的手机没网的),我的想法是项目内部集成地图包一起打包进apk,但是没有找到相关的内容。不知道大家有没有方法。
2020-10-14 15:13 · android / 地图
[问答] 有关地图api定位蓝点显示

最近一个项目有用到地图的需求,我是通过一个AMapWrapper的回调来获取到Amap对象,跟官方的实例中mapview.getMap()不太一样,然后在回调方法中再给这个amap设置locationstyle,也就是是否显示定位蓝点等等,定位是正确的,也都能定位成功,但是无论怎么设置,蓝点就是不显示,还有一系列的uisetting也是不显示(放大放小,回到当前位置那些按钮),有知道的好兄弟可以帮忙看看吗?下面有两个核心代码,一个是LocationFragment,一个是自定义的一个MyWebWrapper。


一,LoacationFragment

public class LocationFragment extends Fragment implements LocationSource.OnLocationChangedListener, AMap.OnMapClickListener, AMap.InfoWindowAdapter, View.OnTouchListener,AMapLocationListener {
    //声明AMapLocationClient类对象
    public AMapLocationClient mLocationClient = null;
    //声明AMapLocationClientOption对象
    public AMapLocationClientOption mLocationOption = null;
    LocationSource.OnLocationChangedListener mListener;
   public AMapLocation location;
   public AMap map;
    private WebView webview;
    View infoWindow = null;
    private NestedScrollView scrollView;
    private LinearLayout layout;
    private LinearLayout layoutBtn;
    private MapView mapView;


    //初始化定位
//设置定位回调监听
    @Nullable
    @org.jetbrains.annotations.Nullable
    @Override
    public View onCreateView(@NonNull @NotNull LayoutInflater inflater, @Nullable @org.jetbrains.annotations.Nullable ViewGroup container, @Nullable @org.jetbrains.annotations.Nullable Bundle savedInstanceState) {
        View rootView = inflater.inflate(R.layout.fragment_location, container, false);

        initView(rootView);
        initLocate();
        initMap();
        initEvent();
        mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);
        setUpMap(savedInstanceState);

        return rootView;

    }

    private void initEvent() {
        webview.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                scrollView.fullScroll(NestedScrollView.FOCUS_DOWN);
            }
        });
        layoutBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent(getActivity(), DetailActivity.class);
                startActivity(intent);
            }
        });
    }

    private void initView(View rootView) {
        webview = rootView.findViewById(R.id.webview);
        scrollView = rootView.findViewById(R.id.pull_down_layout);
        scrollView.fullScroll(NestedScrollView.FOCUS_DOWN);
        layout = rootView.findViewById(R.id.pull_down_linearlayout);

     /*   layout.setNestedScrollingEnabled(false);
        scrollView.setNestedScrollingEnabled(false);
        scrollView.setScrollbarFadingEnabled(true);*/
        layoutBtn = rootView.findViewById(R.id.pull_down_layout_plant);
    }

    private MarkerOptions MarkerOptionsManager(LatLng latLng, String name) {
        MarkerOptions markerOption = new MarkerOptions();
        markerOption.position(latLng);
 //       markerOption.title(name).snippet("植物");
        markerOption.draggable(true);//设置Marker可拖动

        markerOption.icon(BitmapDescriptorFactory.fromView(getActivity().getLayoutInflater().inflate(R.layout.marker_icon,null)));
        // 将Marker设置为贴地显示,可以双指下拉地图查看效果
        //  markerOption.setFlat(true);//设置marker平贴地图效果
        markerOption.setGps(true);
        return markerOption;
    }
    private MarkerOptions MarkerOptionsManager2(LatLng latLng,String name) {
        MarkerOptions markerOption = new MarkerOptions();
        markerOption.position(latLng);
        //       markerOption.title(name).snippet("植物");
        markerOption.draggable(true);//设置Marker可拖动
          markerOption.icon(BitmapDescriptorFactory.fromView(getActivity().getLayoutInflater().inflate(R.layout.marker_icon,null)));

        // 将Marker设置为贴地显示,可以双指下拉地图查看效果
        //  markerOption.setFlat(true);//设置marker平贴地图效果
        markerOption.setGps(true);

        return markerOption;
    }
    private void initMarker(AMap aMap) {
        LatLng latLng = new LatLng(21.150661067659183,110.3071524442981);
        LatLng latLng1 = new LatLng(21.157661067459986,110.30111524442982);
        LatLng latLng2 = new LatLng(21.158661067259482,110.30611524442983);
        LatLng latLng3 = new LatLng(21.151661067151281,110.30511524442984);
        LatLng latLng4 = new LatLng(21.159661067959285,110.30211524442985);
        MarkerOptions markerOptions = MarkerOptionsManager(latLng, "枫香树");
        MarkerOptions markerOptions1 = MarkerOptionsManager2(latLng1, "食人花");
        MarkerOptions markerOptions2 = MarkerOptionsManager(latLng2, "豌豆射手");
        MarkerOptions markerOptions3 = MarkerOptionsManager(latLng3, "樱桃炸弹");
        MarkerOptions markerOptions4 = MarkerOptionsManager(latLng4, "窝瓜");

        ArrayList<MarkerOptions> list = new ArrayList<>();
        list.add(markerOptions);

        list.add(markerOptions1);
        list.add(markerOptions2);
        list.add(markerOptions3);
        list.add(markerOptions4);
        Marker marker1 = aMap.addMarker(markerOptions1);
        marker1.setAnchor(44f,54f);
        marker1.showInfoWindow();
        Marker marker = aMap.addMarker(markerOptions4);
        marker.showInfoWindow();
        aMap.setInfoWindowAdapter(this);



        aMap.setOnMarkerClickListener(new AMap.OnMarkerClickListener() {
            @Override
            public boolean onMarkerClick(Marker marker) {
              //  marker.showInfoWindow();
                scrollView.fullScroll(NestedScrollView.FOCUS_UP);
                return true;
            }
        });
          aMap.addMarkers(list,true);
    }

    private void initMap() {

        MyLocationStyle locationStyle;
        locationStyle = new MyLocationStyle();//初始化定位蓝点样式
        // locationStyle.interval(2000);//设置连续定位模式下的的定位间隔,值在连续定位模式下生效,单次定位模式下不会生效。单位为毫秒
        locationStyle.showMyLocation(true);
        locationStyle.strokeColor(Color.BLUE);
        locationStyle.radiusFillColor(Color.RED);
        locationStyle.strokeWidth(20);
        locationStyle.myLocationIcon(BitmapDescriptorFactory.fromResource(R.drawable.gps_point));
        locationStyle.myLocationType(MyLocationStyle.LOCATION_TYPE_FOLLOW);
        locationStyle.myLocationType(MyLocationStyle.LOCATION_TYPE_LOCATION_ROTATE);
        locationStyle.myLocationType(MyLocationStyle.LOCATION_TYPE_LOCATE);
       MAWebViewWrapper webViewWrapper = new MAWebViewWrapper(webview);


        AMapWrapper aMapWrapper = new AMapWrapper(getContext(),webViewWrapper);
      aMapWrapper.onCreate();
        aMapWrapper.getMapAsyn(new AMap.OnMapReadyListener() {
            @Override
            public void onMapReady(AMap aMap) {
                map=aMap;
                initMarker(aMap);
                aMap.setMyLocationEnabled(true);//设置为true表示启动显示定位蓝点,false表示隐藏定位蓝点并不进行定位,默认是false
                aMap.setMyLocationStyle(locationStyle); //设置定位蓝点的style
                aMap.getUiSettings().setAllGesturesEnabled(true); // 设置默认定位按钮是否显示,非必须设置

                locationStyle.anchor(0.0f,1.0f);
                locationStyle.showMyLocation(true);
                aMap.setMyLocationStyle(locationStyle);


            }
        });

    }

    private void getLocation(AMapLocation location) {
      this.location=location;
    }
    private void setUpMap(Bundle savedInstanceState) {


    }

    //声明定位回调监听器
     AMapLocationListener mLocationListener =new AMapLocationListener() {
        @Override
        public void onLocationChanged(AMapLocation location) {
                     getLocation(location);
            map.moveCamera(CameraUpdateFactory.changeLatLng(new LatLng(location.getLatitude(), location.getLongitude())));
            map.moveCamera(CameraUpdateFactory.zoomTo(16));



            if (null != location) {
                System.out.println("错误信息————"+  location.getErrorInfo());
                StringBuffer sb = new StringBuffer();
                //errCode等于0代表定位成功,其他的为定位失败,具体的可以参照官网定位错误码说明
                if(location.getErrorCode() == 0){
                    sb.append("定位成功" + "\n");
                    sb.append("定位类型: " + location.getLocationType() + "\n");
                    sb.append("经    度    : " + location.getLongitude() + "\n");
                    sb.append("纬    度    : " + location.getLatitude() + "\n");
                    sb.append("精    度    : " + location.getAccuracy() + "米" + "\n");
                    sb.append("提供者    : " + location.getProvider() + "\n");

                    sb.append("速    度    : " + location.getSpeed() + "米/秒" + "\n");
                    sb.append("角    度    : " + location.getBearing() + "\n");
                    // 获取当前提供定位服务的卫星个数
                    sb.append("星    数    : " + location.getSatellites() + "\n");
                    sb.append("国    家    : " + location.getCountry() + "\n");
                    sb.append("省            : " + location.getProvince() + "\n");
                    sb.append("市            : " + location.getCity() + "\n");
                    sb.append("城市编码 : " + location.getCityCode() + "\n");
                    sb.append("区            : " + location.getDistrict() + "\n");
                    sb.append("区域 码   : " + location.getAdCode() + "\n");
                    sb.append("地    址    : " + location.getAddress() + "\n");
                    sb.append("兴趣点    : " + location.getPoiName() + "\n");
                    //定位完成的时间
                   // sb.append("定位时间: " + Utils.formatUTC(location.getTime(), "yyyy-MM-dd HH:mm:ss") + "\n");
                } else {
                    //定位失败
                    sb.append("定位失败" + "\n");
                    sb.append("错误码:" + location.getErrorCode() + "\n");
                    sb.append("错误信息:" + location.getErrorInfo() + "\n");
                    sb.append("错误描述:" + location.getLocationDetail() + "\n");
                }
                sb.append("***定位质量报告***").append("\n");
                sb.append("* WIFI开关:").append(location.getLocationQualityReport().isWifiAble() ? "开启":"关闭").append("\n");
                sb.append("* GPS状态:").append(getGPSStatusString(location.getLocationQualityReport().getGPSStatus())).append("\n");
                sb.append("* GPS星数:").append(location.getLocationQualityReport().getGPSSatellites()).append("\n");
                sb.append("* 网络类型:" + location.getLocationQualityReport().getNetworkType()).append("\n");
                sb.append("* 网络耗时:" + location.getLocationQualityReport().getNetUseTime()).append("\n");
                sb.append("****************").append("\n");
                //定位之后的回调时间
         //       sb.append("回调时间: " + Utils.formatUTC(System.currentTimeMillis(), "yyyy-MM-dd HH:mm:ss") + "\n");

                //解析定位结果,
                String result = sb.toString();
                System.out.println(result);
                // tvResult.setText(result);
            } else {
                System.out.println("定位失败");
             //   tvResult.setText("定位失败,loc is null");
            }
        }

    };



    private String getGPSStatusString(int statusCode){
        String str = "";
        switch (statusCode){
            case AMapLocationQualityReport.GPS_STATUS_OK:
                str = "GPS状态正常";
                break;
            case AMapLocationQualityReport.GPS_STATUS_NOGPSPROVIDER:
                str = "手机中没有GPS Provider,无法进行GPS定位";
                break;
            case AMapLocationQualityReport.GPS_STATUS_OFF:
                str = "GPS关闭,建议开启GPS,提高定位质量";
                break;
            case AMapLocationQualityReport.GPS_STATUS_MODE_SAVING:
                str = "选择的定位模式中不包含GPS定位,建议选择包含GPS定位的模式,提高定位质量";
                break;
            case AMapLocationQualityReport.GPS_STATUS_NOGPSPERMISSION:
                str = "没有GPS定位权限,建议开启gps定位权限";
                break;
        }
        return str;
    }
    private void initLocate() {
                       //初始化AMapLocationClientOption对象
                        //mLocationOption = new AMapLocationClientOption();
        mLocationOption  = getDefaultOption();
        mLocationOption.setLocationPurpose(AMapLocationClientOption.AMapLocationPurpose.SignIn);
                         if(null != mLocationClient){
                             mLocationClient.setLocationOption(mLocationOption);
                         }//设置场景模式后最好调用一次stop,再调用start以保证场景模式生效 locationClient.stopLocation(); locationClient.startLocation();
        try {
            AMapLocationClient.updatePrivacyShow(getContext(),true,true);
            AMapLocationClient.updatePrivacyAgree(getContext(),true);
            mLocationClient = new AMapLocationClient(getContext());

        } catch (Exception e) {
            e.printStackTrace();
        }
        mLocationClient.setLocationOption(mLocationOption);
        mLocationClient.setLocationListener(mLocationListener);
       mLocationClient.startLocation();
    }
    private AMapLocationClientOption getDefaultOption(){
        AMapLocationClientOption mOption = new AMapLocationClientOption();
        mOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);//可选,设置定位模式,可选的模式有高精度、仅设备、仅网络。默认为高精度模式
        mOption.setGpsFirst(false);//可选,设置是否gps优先,只在高精度模式下有效。默认关闭
        mOption.setHttpTimeOut(30000);//可选,设置网络请求超时时间。默认为30秒。在仅设备模式下无效
        mOption.setInterval(2000);//可选,设置定位间隔。默认为2秒
        mOption.setNeedAddress(true);//可选,设置是否返回逆地理地址信息。默认是true
        mOption.setOnceLocation(false);//可选,设置是否单次定位。默认是false
        mOption.setOnceLocationLatest(false);//可选,设置是否等待wifi刷新,默认为false.如果设置为true,会自动变为单次定位,持续定位时不要使用
        AMapLocationClientOption.setLocationProtocol(AMapLocationClientOption.AMapLocationProtocol.HTTP);//可选, 设置网络请求的协议。可选HTTP或者HTTPS。默认为HTTP
        mOption.setSensorEnable(false);//可选,设置是否使用传感器。默认是false
        mOption.setWifiScan(true); //可选,设置是否开启wifi扫描。默认为true,如果设置为false会同时停止主动刷新,停止以后完全依赖于系统刷新,定位位置可能存在误差
        mOption.setLocationCacheEnable(true); //可选,设置是否使用缓存定位,默认为true
        mOption.setGeoLanguage(AMapLocationClientOption.GeoLanguage.DEFAULT);//可选,设置逆地理信息的语言,默认值为默认语言(根据所在地区选择语言)
        return mOption;
    }
    @Override
    public void onLocationChanged(AMapLocation aMapLocation) {
        if (aMapLocation!=null&&mListener!=null){
       mListener.onLocationChanged(aMapLocation);
       mLocationListener.onLocationChanged(aMapLocation);
            System.out.println("显示系统小兰点——————————————————");
        }else {
            System.out.println("定位失败");
        }
    }




    @Override
    public void onMapClick(LatLng latLng) {

    }

    @Override
    public void onLocationChanged(Location location) {
        if (mLocationListener!=null&&mListener!=null){
            mListener.onLocationChanged(location);

            System.out.println("显示系统小兰点——————————————————");
        }else {
            System.out.println("定位失败");
        }
    }

    @Override
    public View getInfoWindow(Marker marker) {
        if(infoWindow == null) {
            infoWindow = LayoutInflater.from(getContext()).inflate(
                    R.layout.info_window_layout, null);
        }
     //   render(marker, infoWindow);
        return infoWindow;
    }

    @Override
    public View getInfoContents(Marker marker) {
        return null;
    }

    @Override
    public boolean onTouch(View v, MotionEvent event) {

        scrollView.fullScroll(NestedScrollView.FOCUS_DOWN);
        return true;
    }

}



二、MAWebViewWrapper
public class MAWebViewWrapper implements IAMapWebView {

    private final WebView webView;
    private WebViewClient mapWebViewClient;

    public MAWebViewWrapper(final WebView webView) {
        this.webView = webView;
        if (this.webView != null) {
            this.webView.setWebViewClient(
                    new WebViewClient() {
                        @TargetApi(Build.VERSION_CODES.N)
                        @Override
                        public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
                            if (mapWebViewClient != null) {
                                boolean flag = mapWebViewClient.shouldOverrideUrlLoading(view, request);
                                if (flag) {
                                    return true;
                                }

                            }
                            return super.shouldOverrideUrlLoading(view, request);
                        }

                        @TargetApi(Build.VERSION_CODES.LOLLIPOP)
                        @Override
                        public WebResourceResponse shouldInterceptRequest(WebView view, WebResourceRequest request) {
                            if (mapWebViewClient != null) {
                                WebResourceResponse flag = mapWebViewClient.shouldInterceptRequest(view, request);
                                if (flag != null) {
                                    return flag;
                                }

                            }
                            return super.shouldInterceptRequest(view, request);
                        }

                        @Override
                        public WebResourceResponse shouldInterceptRequest(WebView view, String url) {
                            if (mapWebViewClient != null) {
                                WebResourceResponse flag = mapWebViewClient.shouldInterceptRequest(view, url);
                                if (flag != null) {
                                    return flag;
                                }

                            }
                            return super.shouldInterceptRequest(view, url);
                        }
                    }
            );
        }
    }

    @Override
    public void evaluateJavascript(String jsCallSig, ValueCallback<String> callback) {
        if (this.webView != null) {
            this.webView.evaluateJavascript(jsCallSig, callback);
        }
    }

    @Override
    public void loadUrl(String toString) {
        if (this.webView != null) {
            this.webView.loadUrl(toString);
        }
    }



    @SuppressLint("JavascriptInterface")
    @Override
    public void addAMapJavascriptInterface(IAMapJsCallback object, String javascriptInterfaceName) {
        if (this.webView != null) {
            this.webView.addJavascriptInterface(object, javascriptInterfaceName);
        }
    }

    @Override
    public void setWebViewClient(WebViewClient webViewClient) {
        this.mapWebViewClient = webViewClient;
    }

    @Override
    public int getWidth() {
        if (this.webView != null) {
            return this.webView.getWidth();
        }
        return 0;
    }

    @Override
    public int getHeight() {
        if (this.webView != null) {
            this.webView.getHeight();
        }
        return 0;
    }


    @Override
    public void addView(View v, ViewGroup.LayoutParams params) {
        if (webView != null && v != null) {
            webView.addView(v, params);
        }
    }
}


2022-11-29 12:00 · 高德地图安卓
[问答] 定位程序的耗电优化问题


  • 可能是的sdk耗电




大概是上面的三种情况,有没有大佬指点下怎么优化

2023-01-31 09:51 · Android / GPS / 高德
[问答] Android 版本如何获取后台进程及应用所占内存大小
Android版本如何获取后台进程及应用所占内存大小就像是手机管家清理后台软件进程现在版本还可以做到么我看很多人推荐用UsageStatsManager但是这个好像获取不到运行占用
2020-12-23 22:34 · Android
[文章] Android——RecyclerView宽自适应填充
setOrientation(GridLayoutManager.HORIZONTAL)+layout_height="match_parent"可以让RecyclerView在纵方向高度自适应;宽双方向自适应填充
2020-04-28 15:04 · Android / RecyclerView / 动态布局 / 自适应
[文章] 《资治通鉴》开篇故事-三家分晋
这个人很聪明,很厉害,但是没。所以原文中的智氏族人智果说:智果曰:“不如宵也。瑶之贤于人者五,其不逮者一也。美鬓长大则贤,射御足力则贤,伎艺毕给则贤,巧文辩慧则贤,强毅果敢则贤,如是而甚不仁。
2019-09-27 19:18 · 读书 / 程序员 / 历史 / 资治通鉴 / 三家分晋
[问答] 领券联盟,特惠界面根据ImageView大小加载图片,在获取控件宽时值为0
第一次进入特惠界面时,无法获取ImageView的宽,但往下浏览,又可以获取到ImageView的宽布局代码
2020-05-25 13:55 · 领券联盟 / Android
[文章] nginx安装以及实现可用负载均衡
连接并发的情况下,Nginx是Apache服务器不错的替代品。
2020-09-02 18:56 · nginx / keepalived
[问答] 喜马拉雅604
网络请求失败android:networkSecurityConfig="@xml/network_security_config"android:usesCleartextTraffic="true"能加1
2020-08-14 17:16 · 访问请求604
[问答] 控件的宽测量问题,直接使用getMeasuredWidth获取的是0,用layoutParams就是对的

补充一点,如果对一个ViewGroup类型的container获取宽,则直接getMeasuredHeight()就获取到了


2022-09-15 15:56 · 安卓 / 控件宽高测量

[文章] 版本android连数据库失败:CLEARTEXT communication ** not permitted by network
在低版本手机上测试项目可以访问数据库,但是在正在使用的版本手机上无法更新数据。
2020-12-03 12:44 · 高版本android / 网络
[问答] docker占用内存

先贴个图

场景:部署博客门户网站后,只要有 发送请求,哪怕只有一个,服务器CPU占用100% 。如上图所示,node 和 docker-proxy两个占用了全部cpu。


服务器配置:1核4G 云硬盘100G。


请问这是什么情况=.=! 拉大锯的部署教程里使用的服务器好像是2G的,都没出现过这样的情况。

2021-06-29 02:06 · docker
[文章] Android逆向破解某力定位打卡
NonNullLocationListenerlistener,@NullableLooperlooper)另一个方向就是基于基站和周边WiFi列表的定位+ip,这里叫LBS,这里就取2种逻辑中最快回调回来的,比如GPS快,就拿GPS的经纬度,再使用
2023-01-01 22:15 · Android逆向 / 定位打卡 / hook / frida / 动态调试
[文章] 地图的onLocationChanged返回经纬度经常都是(0,0),为什么,这几个小细节要注意。
正常应该是这样的。但有的时候你会发现自己获得的经纬度都是0.0第一,看看service。<application><!--定位需要的服务使用2.0的定位需要加上这个--><serviceandroid:name="com.amap.api.location.APSService"/>.........</application>第二,看看依赖jar里面如果少了内容就不行。implementationfiles('libs/AMap3DMap_7.1.0_AMapNavi_7.1.0_AMapSearch_7.1.0_AMapTrack_1.1.0_AMapLocation_4.7.2_20191030.jar')第三,看看服务是否开了<!--地图包、搜索包需要的基础权限--><!--允许程序打开网络套接字--><uses-permissionandroid:name="android.permission.INTERNET"/><!--允许程序设置内置sd卡的写权限--><uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE"/><!--允许程序获取网络状态--><uses-permissionandroid:name="android.permission.ACCESS_NETWORK_STATE"/><!--允许程序访问WiFi网络信息--><uses-permissionandroid:name="android.permission.ACCESS_WIFI_STATE"/><!--允许程序读写手机状态和身份--><uses-permissionandroid:name="android.permission.READ_PHONE_STATE"/><!--允许程序访问CellID或WiFi热点来获取粗略的位置--><uses-permissionandroid:name="android.permission.ACCESS_COARSE_LOCATION"/>第四,重启手机试试。定位一直在北京,无法显示本地,检查手机是否给你的app开了定位权限,然后重启试试,我就是发现位置切换不过来,然后重启了一下就ok了。看到这里了就点个赞吧!!!
2019-12-11 11:55 · 高德地图
[文章] 李开复给程序员的七个建议
大家不妨试试纳所著TheArtofComputerProgramming里的题目,如果你能够解决其中的大部分题目,就说明你在算法方面有一定的功力了。(2)多实战。通过编程的实战积累经验、巩固知识。
2020-06-25 11:27 · 建议 / 程序员 / 算法 / 基础 / 李开复
[文章] 自定义View-会动的圆形
(今天在摸鱼的时候,听着网易云音乐,突然发现播放页面的碟片动画没写过,于是就试着简单写下效果)View的测量先看一幅图(从一本书上拍的)总结上图:1.当子控件宽取固定值(如??
2021-11-10 23:39 · Android
[文章] Android逆向植入经纬度破解某力定位打卡
但是现在定位失败了,原因:我们重签名,地图SDK是根据包名和签名来检查定位初始化的,重签之后肯定失败。
[文章] 程序员读《史记·五帝本纪》你以为尧舜禹的禅让是非亲非故?
黄帝-有熊颛顼-高阳帝喾-辛帝尧-陶唐帝禹-有虞依据:自黄帝至舜、禹,皆同姓而异其国号,以章明德。故黄帝为有熊,帝颛顼为高阳,帝喾为辛,帝尧为陶唐,帝舜为有虞。
2019-09-27 19:32 · 程序员 / 读书 / 历史 / 史记 / 三五五帝
[问答] 使用版本Gradle6.5时,构建报aapt2错误
Afailureoccurredwhileexecutingcom.android.build.gradle.internal.tasks.Workers$ActionFacade   >AAPT2aapt2-4.1.2-6503028-windowsDaemon#7:Daemonstartupfailed    PleasecheckifyouinstalledtheWindowsUniversalCRuntime.    Thisshouldnothappenundernormalcircumstances,pleasefileanissueifitdoes.
2021-04-17 11:06 · android / gradle / aapt2
[文章] Volley/Xutils对大图片处理算法源码分析
理论:第一次读取图片,不写入内存,直接获取到图片的宽,再通过用户设置的宽,和这個拉伸形式來计算期望的宽,结合这四個参数來找出最适合的采样率,或者直接根据屏幕大小,控件大小來计算最佳采样率。
2019-12-01 20:01 · 源码分析 / 源码 / android / xutils / volley
[文章] 阳光沙滩博客插入emoji表情的小问题
,终于可以了o(╥﹏╥)o然后我兴冲冲的去后端管理模块发了篇文章我尼玛,我emoji呢,咋都成?号了啊,我吐了。。。我转念一想,数据库是支持emoji,那只能是JPA配置问题了吧。。。。
2020-08-25 12:08 · sql / jpa / emoji / 阳光沙滩
[文章] UI 绘制流程(测量、布局、绘制)
gt;wrap_contentmode+size->MeasureSpecMeasureSpec=mode+sizeViewGroup:measure->onMeasure(测量子控件的宽
2022-02-10 15:59 · Android / 安卓
[分享] 推荐程序员拉大锯的B站主页
你想事情吗..不,你不想! 拿起你的键盘吧!拿起你的鼠标吧!点亮你的屏幕,开始改变世界 吧!
2019-08-31 08:45 · 程序员日常 / 推荐 / 安卓 / 编程 / 开发
[文章] 安卓字体描边效果
heightMeasureSpec:Int){//测量字体所在矩形(mRect)的大小mPaint.getTextBounds(mTextStr,0,mTextStr.length,mRect)//设置自定义View的宽
2022-09-11 19:08 · Android / 字体描边 / 自定义View
[问答] 领劵联盟的内存问题
图一是课程视频里的内存使用情况,图二是从学院里下的demo,我自己跟着写的app内存使用情况也是这么,滑几下就上200,触发刷新动作还会继续上升,怎么肥四,虚拟机和真机的区别么
2020-06-18 11:27 · 内存优化
[问答] 关于APT无法生成编译代码
https://github.com/baojie0327/AnnotationDemo参考:https://www.jianshu.com/p/8e46db1e0c96这个利用gradle版本后,发现
2021-03-09 13:10 · android / apt
[问答] 面试官问题,直接傻了求解答?
直接傻了,我回答的是activity的开销大,Fragment可重用性,但是没有答到面试官的认可?
2021-03-19 09:16 · 面试 / 领券联盟
[分享] 网易行为式验证码
搭载风险感知引擎,智能切换验证难度,安全性,极致用户体验。读屏软件深度适配,视障群体也可轻松使用,符合工信部无障碍适配要求。

2022-03-03 11:13 · 网易 / 验证码 / 行为验证码
[问答] 关于打开本地相册选择多张照片
return-data", true);

这是我原生的选择单图片的代码

有多选择图片的修改方案吗



如果没有有没有兼容性

2022-06-01 15:46 · 多图片选择
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6