建議是不要用轉(zhuǎn)換,因為Rxjava2和Rxjava1是連包名都換了的,這個只是單純的為1和2的方法和對象做對應(yīng),如果有功夫不如直接自己替換
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ù)轉(zhuǎn)化成可見的連續(xù)的內(nèi)容,而Base64正好能做到這點。
傳送門:扒一扒HTTP的構(gòu)成
實際上通常是你所說的做法,圖片一般是上傳到你們自己的CDN上面,因為圖片加載畢竟比文本更加耗時,為了提升用戶體驗,分區(qū)域存儲相當(dāng)有必要。當(dāng)然這里面我認為 還需要考慮兩點內(nèi)容。
git rm -r --cached .
git add .
git commit -m "update gitignore"
找到原因了,是因為高德2.0之后的,要在Manifest里面添加AppService的服務(wù)。添加上去就能很快的獲取到定位了。
可能是忘記調(diào)用 av_register_all(),你試一下找其它的編碼,比如aac,wma, 如果都找不到那肯定是忘記調(diào)用了。
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的問題,就是在你要設(shè)置apk路徑與名稱的時候可能會遇到的問題,通常是將里面的each改為all,設(shè)置里面的文件名稱就好,不要new File(XXX)。
或者手動將gradle版本降級比如3.3等
https://leancloud.cn/docs/cha...
這個文檔中的第三點應(yīng)該是實現(xiàn)自己的用戶體系的吧
問題已經(jīng)解決了
這個問題的 關(guān)鍵點 是 setSelection() 方法的執(zhí)行時機
<RelativeLayout
<!-- 這兩個設(shè)置不需要了,因為接下來要在程序總設(shè)定 -->
android:focusable="false"
android:focusableInTouchMode="true" />
<EditText />
</RelativeLayout>
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);
// 關(guān)鍵部分
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. 直接設(shè)置 setSelection()
因為之前設(shè)置了 android:focusabelInTouchMode="true",所以直接設(shè)置是沒有效果的,第一次點擊EditText區(qū)域,會自動彈出軟鍵盤,并且光標位置是手指點擊的位置
2. 自定義 EditText,重寫 onSelectionChanged(int selStart, int selEnd)方法
這個方法感知光標位置的變化,編寫如下代碼,可控制光標始終在結(jié)尾處:
@Override
protected void onSelectionChanged(int selStart, int selEnd) {
super.onSelectionChanged(selStart, selEnd);
if (selStart == selEnd) { // 不考慮多個文字被選中
setSelection(getText().length());
}
}
這個方法的執(zhí)行時機在自定義EditText對象初始化之前,并且在沒點擊之前,或者點擊時會多次執(zhí)行該方法,不好控制是否是第一次點擊。因此也沒有嘗試成功
不知道有沒有更好的解決方案?期待你的回答。
實際項目總可能會遇到一個頁面中有多個EditText,那么 isFirstTouch 就可能被多個EditText共用,如果有這個問題存在的話,一種解決方案是自定義EditText:
public class MyEditText extends EditText {
private boolean isFirstTouch = true;
// 構(gòu)造方法中調(diào)用 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服務(wù)器和客戶端(瀏覽器)的副本,其作用體現(xiàn)在減少網(wǎng)絡(luò)帶寬消耗、降低服務(wù)器壓力和減少網(wǎng)絡(luò)延遲,加快頁面打開速度等方面
WebView是手機中內(nèi)置了一款高性能webkit 內(nèi)核瀏覽器,在SDK 中封裝的一個組件。 沒有提供地址欄和導(dǎo)航欄,WebView只是單純的展示一個網(wǎng)頁界面。簡單地可以理解為簡略版的瀏覽器且對html緩存機制做了支持
webview的優(yōu)勢:速度 – 緩存資源為本地資源,因此加載速度較快,提供用戶體驗。服務(wù)器負載更少 – 瀏覽器只會從發(fā)生了更改的服務(wù)器下載資源。離線瀏覽 – 用戶可在離線時瀏覽您的完整網(wǎng)頁
參考:
Android WebView緩存機制詳解
H5 和移動端 WebView 緩存機制解析與實戰(zhàn)
webView 離線緩存機制
所以你的問題是什么
沒有找到具體原因,但是我把cordova版本降低到6.5就好了,所以猜測是版本高的問題,如果有知道問題的大神請指教。
同問+1 一直報錯日了狗了
報錯信息很明顯。
你先看看目錄是否存在。
存在的話,看看目錄權(quán)限。
既然只有確認鍵不能捕捉,那就設(shè)置為default。
獲取到的時長應(yīng)該是 long 類型的;
你獲取的資源是在線資源還是本地資源?
可以在 prepare 之后獲取看下。
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內(nèi)教育集團成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復(fù)興的升級產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負責(zé)iOS教學(xué)及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。