建議是不要用轉換,因為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ū)域存儲相當有必要。當然這里面我認為 還需要考慮兩點內容。
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>
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í)行該方法,不好控制是否是第一次點擊。因此也沒有嘗試成功
不知道有沒有更好的解決方案?期待你的回答。
實際項目總可能會遇到一個頁面中有多個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。
獲取到的時長應該是 long 類型的;
你獲取的資源是在線資源還是本地資源?
可以在 prepare 之后獲取看下。
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學院和江蘇省首批服務外包人才培訓基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術與教育服務機構,發(fā)展為教育服務業(yè)的綜合性企業(yè)集團,成為集合面授教學培訓、網(wǎng)
達內教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構,是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術, 熟練的跨平臺面向對象開發(fā)經(jīng)驗,技術功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術顧問,美國Dachieve 系統(tǒng)架構師,美國AngelEngineers Inc. 系統(tǒng)架構師。