鍍金池/ 問答/ Android問答
喜歡你 回答

建議是不要用轉換,因為Rxjava2和Rxjava1是連包名都換了的,這個只是單純的為1和2的方法和對象做對應,如果有功夫不如直接自己替換

我不懂 回答

hover之后將該區(qū)域塊顯示出來,然后加上animation,從左到右的滑動
舉個例子

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JS Bin</title>
  <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
  <style>
    ul li{list-style:none; width:100px; position:relative; float:left; overflow:hidden;}
    ul li img{width:100%;}
    ul li .info{position:absolute; bottom:0; left:0; width:100%; height:40px; line-height:40px; background:-webkit-gradient(linear, 0 0, 0 bottom, from(rgba(255,255,255,.2)), to(rgba(0,0,0,.2)));}
    .hide{display:none;}
    .slideleft{animation:left .5s 1; animation-fill-mode:forwards;}
    .slideright{animation:right .5s 1; animation-fill-mode:forwards;}
    .slidetop{animation:top .5s 1; animation-fill-mode:forwards;}
    .slidebottom{animation:bottom .5s 1; animation-fill-mode:forwards;}
    
    @keyframes left{
      from{left:-100%;}
      to{left:0;}
    }
    @keyframes top{
      from{bottom:-100%; left:0;}
      to{bottom:0; left:0;}
    }
    @keyframes bottom{
      from{bottom:100%;}
      to{bottom:0;}
    }
    @keyframes right{
      from{left:100%;}
      to{left:0;}
    }
  </style>
</head>
<body>
  <ul>
    <li>
      <img src="https://img1.epetbar.com/2017-05/24/10/7982bafb75e8aba985e08de99780be52.jpg?x-oss-process=style/fill&$1=300&$2=300" alt="">
      <div class="info hide">
        test
      </div>
    </li>
    <li>
      <img src="https://img1.epetbar.com/2017-05/24/10/7982bafb75e8aba985e08de99780be52.jpg?x-oss-process=style/fill&$1=300&$2=300" alt="">
      <div class="info hide">
        test
      </div>
    </li>
    <li>
      <img src="https://img1.epetbar.com/2017-05/24/10/7982bafb75e8aba985e08de99780be52.jpg?x-oss-process=style/fill&$1=300&$2=300" alt="">
      <div class="info hide">
        test
      </div>
    </li>
  </ul>

<script>
$("li").hover(function(e){
  var mX = e.clientX;
  var mY = e.clientY;
  var liLeft = $(this).offset().left;
  var liTop = $(this).offset().top;
  var liW = $(this).width();
  var liH = $(this).height();

  x = (mX - liLeft - ( liW  / 2 ) ) * ( liW  > liH ? (liH / liW ) : 1 )
  y = (mY - liTop - (liH / 2)) * (liH > liW ? (liW / liH) : 1),  
  // 上(0) 右(1) 下(2) 左(3)  
  direction = Math.round( ( ( ( Math.atan2( y, x ) * ( 180 / Math.PI ) ) + 180 ) / 90) + 3 ) % 4;
  if(direction == 0){
    $(this).find(".info").removeClass("hide").addClass("slidetop");
  }else if(direction == 1){
    $(this).find(".info").removeClass("hide").addClass("slideright");
  }else if(direction == 2){
    $(this).find(".info").removeClass("hide").addClass("slidebottom");
  }else if(direction == 3){
    $(this).find(".info").removeClass("hide").addClass("slideleft");
  }
},function(){
  $(this).find(".info").addClass("hide").removeClass("slideleft").removeClass("slidetop").removeClass("slideright").removeClass("slidebottom")
})
</script>
</body>
</html>
巴扎嘿 回答

http://idea.iteblog.com/key.php
我用的是這個,用的2017.3.2版本
另外講真這東西百度一搜一大堆,為啥會有搜不到的情況
本機實拍。。

維她命 回答
http(s)協(xié)議本身是不適合用來直接傳輸二進制數(shù)據(jù)的,這是協(xié)議本身造成的。

因此,必須將數(shù)據(jù)轉化成可見的連續(xù)的內容,而Base64正好能做到這點。

傳送門:扒一扒HTTP的構成

久舊酒 回答

實際上通常是你所說的做法,圖片一般是上傳到你們自己的CDN上面,因為圖片加載畢竟比文本更加耗時,為了提升用戶體驗,分區(qū)域存儲相當有必要。當然這里面我認為 還需要考慮兩點內容。

  1. 弱網(wǎng)絡,圖片上傳失敗怎么處理?
    了解下job,intentservice,斷點續(xù)傳。
  2. 多圖上傳如何保證順序的問題?
    了解一下rxjava的contactMap操作。
孤星 回答

git rm -r --cached .
git add .
git commit -m "update gitignore"

九年囚 回答

找到原因了,是因為高德2.0之后的,要在Manifest里面添加AppService的服務。添加上去就能很快的獲取到定位了。

終相守 回答

可能是忘記調用 av_register_all(),你試一下找其它的編碼,比如aac,wma, 如果都找不到那肯定是忘記調用了。

別硬撐 回答

touchmove時不讓其移出可視窗口,或者touchend事件加在document上

function touch(id){
            var obj = document.getElementById(id); 
            obj.addEventListener('touchstart', function(event) {     
            if (event.targetTouches.length == 1) { 
            var touch = event.targetTouches[0]; 
            var disX=touch.pageX-obj.offsetLeft; 
            var disY=touch.pageY-obj.offsetTop;
            var W = document.documentElement.clientWidth-obj.offsetWidth;
            var H = document.documentElement.clientHeight-obj.offsetHeight;
            obj.addEventListener('touchmove',move);  
            function move(event){    
                event.preventDefault();
                    var touch2=event.targetTouches[0];
                    var l=touch2.pageX-disX;
                    var t=touch2.pageY-disY;
                    if(l<0){
                        l=0;
                    };
                    if(l>W){
                        l=W;
                    };
                    if(t<0){
                        t=0;
                    };
                    if(t>H){
                        t=H;
                    };
                    obj.style.left=l+'px';
                    obj.style.top=t+'px';
         
            };
              obj.addEventListener('touchend',chend);
              function chend(event){
                obj.removeEventListener('touchmove',move);
                obj.removeEventListener('touchend',chend);
              };
        }; 
        }, false);
    };
歆久 回答

Android gradle 4.1的問題,就是在你要設置apk路徑與名稱的時候可能會遇到的問題,通常是將里面的each改為all,設置里面的文件名稱就好,不要new File(XXX)。
或者手動將gradle版本降級比如3.3等

拽很帥 回答

https://leancloud.cn/docs/cha...

這個文檔中的第三點應該是實現(xiàn)自己的用戶體系的吧

久舊酒 回答

問題已經(jīng)解決了

這個問題的 關鍵點setSelection() 方法的執(zhí)行時機

先說下如何解決

  • 布局中不需要做任何多余的設置
<RelativeLayout
    <!-- 這兩個設置不需要了,因為接下來要在程序總設定 -->
    android:focusable="false"
    android:focusableInTouchMode="true" />
    <EditText />
</RelativeLayout>
  • Java代碼部分
public class MainActivity extends AppCompatActivity {
    private boolean isFirst = true; // 是否是第一次點擊 EditText
    private InputMethodManager mIMM; // 第一次點擊時,軟鍵盤不自動彈出,所以要手動彈出
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mIMM = (InputMethodManager) (InputMethodManager)getSystemService(Context.INPUT_METHOD_SERVICE);
        mEditText = findViewById(R.id.xxx);
        
        // 關鍵部分
        mEditText.setFocusable(false);
        mEditText.setOnClickListener( v -> {
            if(isFirst) {
                mEditText.setFocusableInTouchMode(true);
                mEditText.requestFocus();
                mEditText.setSelection(mEditText.getText().length());
                mIMM.toggleSoftInput(0, InputMethodManager.HIDE_NOT_ALWAYS);
                isFirst = false;
            }
        });
    }
}

再說下嘗試的過程

1. 直接設置 setSelection()

因為之前設置了 android:focusabelInTouchMode="true",所以直接設置是沒有效果的,第一次點擊EditText區(qū)域,會自動彈出軟鍵盤,并且光標位置是手指點擊的位置

2. 自定義 EditText,重寫 onSelectionChanged(int selStart, int selEnd)方法

這個方法感知光標位置的變化,編寫如下代碼,可控制光標始終在結尾處:

    @Override
    protected void onSelectionChanged(int selStart, int selEnd) {
        super.onSelectionChanged(selStart, selEnd);
            if (selStart == selEnd) { // 不考慮多個文字被選中
                setSelection(getText().length());
            }
    }

這個方法的執(zhí)行時機在自定義EditText對象初始化之前,并且在沒點擊之前,或者點擊時會多次執(zhí)行該方法,不好控制是否是第一次點擊。因此也沒有嘗試成功

總結

不知道有沒有更好的解決方案?期待你的回答。


2018-05-28 補充

實際項目總可能會遇到一個頁面中有多個EditText,那么 isFirstTouch 就可能被多個EditText共用,如果有這個問題存在的話,一種解決方案是自定義EditText:

public class MyEditText extends EditText {
    private boolean isFirstTouch = true;
    // 構造方法中調用 init() 方法
    private void init() {
        post( () -> {
            setFocusable(false);
            if(isFirst) {
                setFocusableInTouchMode(true);
                requestFocus();
                setSelection(mEditText.getText().length());
                inputMethodManger.toggleSoftInput(0, InputMethodManager.HIDE_NOT_ALWAYS);
                isFirst = false;
            }
        });
    }
}
青黛色 回答

Web緩存可以理解為Web資源在Web服務器和客戶端(瀏覽器)的副本,其作用體現(xiàn)在減少網(wǎng)絡帶寬消耗、降低服務器壓力和減少網(wǎng)絡延遲,加快頁面打開速度等方面

WebView是手機中內置了一款高性能webkit 內核瀏覽器,在SDK 中封裝的一個組件。 沒有提供地址欄和導航欄,WebView只是單純的展示一個網(wǎng)頁界面。簡單地可以理解為簡略版的瀏覽器且對html緩存機制做了支持

webview的優(yōu)勢:速度 – 緩存資源為本地資源,因此加載速度較快,提供用戶體驗。服務器負載更少 – 瀏覽器只會從發(fā)生了更改的服務器下載資源。離線瀏覽 – 用戶可在離線時瀏覽您的完整網(wǎng)頁

參考:
Android WebView緩存機制詳解
H5 和移動端 WebView 緩存機制解析與實戰(zhàn)
webView 離線緩存機制

嫑吢丕 回答

所以你的問題是什么

葬憶 回答

沒有找到具體原因,但是我把cordova版本降低到6.5就好了,所以猜測是版本高的問題,如果有知道問題的大神請指教。

傻丟丟 回答

同問+1 一直報錯日了狗了

陪妳哭 回答

報錯信息很明顯。
你先看看目錄是否存在。
存在的話,看看目錄權限。

櫻花霓 回答

既然只有確認鍵不能捕捉,那就設置為default。

拮據(jù) 回答

獲取到的時長應該是 long 類型的;
你獲取的資源是在線資源還是本地資源?
可以在 prepare 之后獲取看下。