26 Nisan 2024 Cuma

Kotlinin Temelleri



 1.Değişkenler(Variables)

Kotlin’de val (value)  ve  var (variable) olarak iki farklı değişken tanımlama yöntemi mevcuttur.

  • Val(Value), değerine ulaşılabilir ( get edilebilir). Ancak değişmez .
  • Var(Variable) , hem değeri değiştirilebilir hem de değerine ulaşılabilir (get-set )



2.Sayılar (Numbers)

Kotlin’de Byte, Short, Int, Long, Float, Double olarak değişken tipleri olup bunlar farklı sayı tiplerini ifade ederler.

Type

Size (bits)

Min value

Max value

Byte

8

-128

127

Short

16

-32768

32767

Int

32

-2,147,483,648 (-231)

2,147,483,647 (231 - 1)

Long

64

-9,223,372,036,854,775,808 (-263)

9,223,372,036,854,775,807 (263 - 1)

  • Sayıların değer aralıkları yukarda yer aldığı şekildedir.
  • Float ve Double ondalıklı sayıları tanımlarken kullanılır.
  • Byte , Short , Int ve Long değer aralıklarına göre farklılık gösterir.

Değişkenlere  değer ataması yapılırken maksimum performans için doğru değişken tipini yukarda yer alan şemayı esas alarak  kullanmak önemlidir.Aksi takdirde kodlarımız çalışmayacak veya çalışsa da verimli olmayacaktır.

Tip çıkarımı yapılırken eğer değer Int ifade aralığında ise default olarak Int tanımlanır. Tanımladığınız değerler Int değer aralığından büyük ise default olarak Long tanımlanır.

Long ve Float değer ataması yapılırken sayı sonlarına “L” ve “F” işaretleri konularak bu işlem gerçekleştirilebilir.

Number değişken tanımı yapılırken "." yerine _ kullanılabilir. Bu sayede sayının okunabilirliği kolaylaşır.

Misal :val idNumber = 2133_0062_0065_0000L

  • Değişken referanslarını karşılaştırma yaparken “===” ; Değişken değer karşılaştırılması yapılırken ise “==” kullanılır.
  • Yalnızca aynı değişkenlerin referans karşılaştırması “true” dönerken 2 farklı değişkenin referansları farklı olduğundan “false” dönmektedir.

Hesaplamaların daha iyi olması için Float yerine Double kullanmak daha güvenli olur. Çıkacak sonucun 15 rakamdan az olacağına emin isek Float da kullanabiliriz.

Bilimsel Sayılar( Scientific Numbers)

Float sayılarımız Bilimsel bir sayı olacaksa bu durumu "e" veya "E" rakamıyla ifade edebiliriz.

Misal:val myNum1: Float = 21E3F

val myNum2: Double = 33E4

println(myNum1)

println(myNum2)

3.Booleans 




Booleans veri tipi  true ( Doğru) veya false (Yanlış)  olabilir.

Misal: 
val isTravelFun: Boolean = true
val isTomatoesTasty: Boolean = false
println(isTravelFun)   // Outputs true
println(isTomatoesTasty)   // Outputs false 

True/ False   yanında  Şart kontrolü yaparken “&&, ||, and, or” gibi operatörler kullanılır.

4.String

Çift tırnak içerisinde ("String") yazılan yazılar şeklinde kullanımı temsil eder.

 String ifadelendirmelerinde + operatörünü kullanırken :

A. Farklı tipteki bir değişkenin önüne String bir değişken veya ifade koyarak toplarsanız, sonuç String olacaktır. 

B.Farklı tipteki değişkenin sonrasına String bir değişken koyarsanız kodlamanız  hata verecektir.

Misal  

val value: String = "diyarbakır" + (true) + (21+33) println(value) çalışır val value: String = "diyarbakır" + (true) + (21+33) fun main() { println(value) } Output:diyarbakırtrue54
5.Char

Tek tırnak içerisinde genellikle harf tanımlamalarında kullanılır. Misal; unicode   veya escape ifadesi char olarak tanımlanabilir.

Misal

val firstCharofName: Char = 'd'

Char ile sayı tanımlaması da yapılabilirse de  Int tipine dönüştürülürken  ASCII tablosundaki sayısal karşılığını elde ederiz.

Kodlama yaparken yazılan yazılarda  Boşluk bırakmak , alt satıra geçmek ,satır başı yapmak gibi escape tanımlamalarını char olarak ifade edilmektedir.


Aynı zamanda Escape Character (Kaçış karakteri) tanımlamak için de Char kullanılır.

Kotlinde kod içerisinde yazı yazılırken kullanılacak kodlar:

  • \t - Tab
  • \b - Backspace
  • \n - Yeni satır
  • \r - Satır Başı
  • \' - Tek Tırnak
  • \" - Çift Tırnak
  • \\ - Backslash
  • \$ - Dolar


6.TYPE CONVERSION (Tip Dönüşümü)

Kotlinde sadece açık tip dönüşümüne Explicit

 (Açık) Type izin verilir.

Misal
 

val value1 = 33
val value2: Long = value1.toLong()

Yaptığımız işlemde Int olarak alınmış bir değeri Long türüne çevirdik.

Type conversion için Numeric fonksiyonların listesi :

  • toByte()
  • toShort()
  • toInt()
  • toLong()
  • toFloat()
  • toDouble()
  • toChar()

7.Array

Aynı veya farklı türdeki verileri tek bir değişkende tanımlama için kullanılan bir kod yapısıdır.

a. arrayOf() tanımlaması ile aynı veya farklı türdeki değişkenler ile array oluşturabiliriz.

b. Farklı türdeki verileri bir arada tutmak için arrayOf<Any>() şeklinde tanımlama yaparak kullanırız. 

c.Belli bir  sayı kadar null değerli bir array tanımlamak için arrayOfNulls<Type>(size) şeklinde bir yapı kullanırız.


Misal
val doorNumbers = arrayOf(20, 21, 22, 23, 24, 25) val arrayOfNulls = arrayOfNulls<String>(5) val firstCharOfNames = arrayOf('S', 'A', 'D', 'M') val mixedArray = arrayOf<Any>(33, "Sami", 'A', true) val prayerNames = arrayOf("Hasan", "Hüseyin", "Ömer", "Ebu Bekir")



13 Nisan 2024 Cumartesi

Kotlin Dilinin Avantajları



Kotlin Öğrenmenin Avantajları:

1. Java ile tamamen uyumludur, yani geliştiriciler onu mevcut Java projeleriyle kolayca entegre edebilir ve mevcut kütüphaneleri ve framework'ler dahil olmak üzere Java ekosisteminden yararlanabilir. Java kodunu Kotlin diline eklediğinizde otomatikmen kodlar kotlin diline çevrilecektir.

 2.Kotlin, geliştirilmiş tür çıkarımı, boş güvenlik ve işlevsel programlama için daha iyi destek gibi gelişmiş özelliklere sahiptir ve bu da onu uygulama geliştirmek için daha anlamlı ve verimli bir dil haline getirir. 

3.Google'ın Android uygulama geliştirme için resmi dil olarak Kotlin'i duyurmasıyla, Kotlin geliştiricilerine olan talep artıyor ve bu, iş arayanlar veya becerilerini geliştirmek isteyen geliştiriciler için harika bir fırsat olabilir. Aynı zamanda hızla büyüyen bir topluluğa sahip olup daha pek çok büyük şirket tarafından kullanılmaktadır.

4 Nisan 2024 Perşembe

HTML Kilo Hesaplama Kodu



 <https://aksoyyazilim.blogspot.com/ --->

            </p>  <script language="JavaScript">


            function kontrol()


            {


            if (diyet.boy.value == "" )


            {


            alert("Boyunuzu giriniz.");


            diyet.boy.focus();


            return(false);


            }


            if (diyet.kilo.value == "" )


            {


            alert("Kilonuzu giriniz.");


            diyet.kilo.focus();


            return(false);


            }


            if (diyet.yas.value == "" )


            {


            alert("Yaşınızı giriniz.");


            diyet.yas.focus();


            return(false);


            }


            check()


            }


            function check()


            {


            var c1=0 ; var d1=0


            var c2=0 ; var d2=0


            var c3=0 ; var d3=0


            if (document.diyet.boy.value >= 140)  {var c1=1}


            if (document.diyet.boy.value <= 200)  {var d1=1}


            if (document.diyet.kilo.value >= 37)  {var c2=2}


            if (document.diyet.kilo.value <= 140)  {var d2=2}


            if (document.diyet.yas.value >= 16)  {var c3=4}


            if (document.diyet.yas.value <= 60)  {var d3=4}


            var c=c1+c2+c3


            var d=d1+d2+d3


            alarm=new Array()


            alarm[0]="Boy, kilo ve yaş "


            alarm[1]="kilo ve yaş "


            alarm[2]="boy ve yaş "


            alarm[3]="yaş "


            alarm[4]="boy ve kilo "


            alarm[5]="kilo "


            alarm[6]="boy "


            if (c==7)


            {if (d==7){i_kilo()}


            else {alert(alarm[d] + "uygun değil !")}


            }


            else {alert(alarm[c] + "uygun değil !")}


            }


            function i_kilo()


            {


            var temp1 = Math.round(document.diyet.yas.value/49);


            var temp2 = Math.round(document.diyet.yas.value/71);


            var temp3 = Math.round(document.diyet.yas.value/91);


            var tem = document.diyet.cinsiyet.value


            var neki = 0


            if (tem == 0)


            {


            if (temp1 != 0)  {neki = 21}


            if (temp1 == 0)  {neki = 20}


            }


            if (tem != 0)


            {


            if (temp1 != 0)


            {


            if (temp2 != 0)


            {


            if (temp3 != 0)  {neki = 24}


            if (temp3 == 0)  {neki = 23}


            }


            if (temp2 == 0)  {neki = 22}


            }


            if (temp1 == 0)  {neki = 21}


            }


            document.diyet.ideal.value = Math.round(neki * Math.pow(document.diyet.boy.value,2)/10000)


            document.diyet.fark.value = document.diyet.kilo.value - document.diyet.ideal.value


            if (document.diyet.fark.value > 0 )


            {alert(document.diyet.fark.value + " kilo vermelisiniz.")}


            if (document.diyet.fark.value < 0 )


            {alert(document.diyet.fark.value*(-1) + " kilo almalısınız.")}


            if (document.diyet.fark.value == 0 )


            {alert("Bravo. İdeal kilonuzdasınız.")}


            }


            // end hiding -->


            </script>


            <form name="diyet">


            <table border="1" cellpadding="20" cellspacing="" style="width: 592px;">


            <tbody>


            <tr bgcolor="005999">


            <td><font color="Black"><strong>Boyunuz</strong> </font></td>


            <td><input maxlength="5" name="boy" size="3" />  <font color="white"><strong>Cm</strong></font></td>


            <td align="middle" background="" rowspan="4" width="1"><input onclick="kontrol()" style="background-color: #ebe2d3;" type="button" value="HESAPLA" />


            </td>


            <td>  </td>


            <td>  </td></tr>


            <tr bgcolor="#556f95">


            <td><font color="#RRRRRR">Kilonuz</font></td>


            <td><input maxlength="5" name="kilo" size="3" />  <font color="#FFFFFF">Kg</font></td>


            <td><font color="#FFFFFF">İdeal Kilonuz</font> </td>


            <td><input name="ideal" size="3" type="list" />  <font color="#FFFFFF">Kg</font></td></tr>


            <tr bgcolor="#556f95">


            <td><font color="#SSSSSS">Yaşınız</font></td>


            <td><input name="yas" size="3" /></td>


            <td>  </td>


            <td>  </td></tr>


            <tr bgcolor="#005999">


            <td><font color="#FFFFFF">Cinsiyetiniz</font></td>


            <td><select name="cinsiyet"> <option selected="" value="0">Bayan</option>


            <option value="1">Erkek</option></select> </td>


            <td><font color="#FFFFFF">Fark </font></td>


            <td><input name="fark" size="3" type="list" />  <font color="#FFFFFF">Kg</font></td></tr>


            </tbody></table></form>




            < https://aksoyyazilim.blogspot.com/--->

Kilo Hesaplama


          

Boyunuz Cm
Kilonuz Kg İdeal Kilonuz Kg
Yaşınız
Cinsiyetiniz Fark Kg

27 Mart 2024 Çarşamba

Dersimiz Tarih Pro Uygulaması





Dersimiz Tarih uygulamamızın bu versiyonu Pro tarzı olup çeşitli yeni özellikler içermektedir. 


Tamamen yeni olan  işlevler  ekledim.

Konu anlatımları menusunden Yazılılar kısmıyla kullanıcılar istedikleri sınıf seviyesinden istedikleri dersin istedikleri yazılısına ulaşabilecekler. 

Hicri Miladi çevirci kısmıyla bu takvim çevirme işinin nasıl yapılacağını açıklamaya çalıştım.

Roma Rakamları kısmıyla Tarih metinlerinde yer alan Roma rakamlarını nasıl okunacağını açıklamaya çalıştım.

İslam Tarihi, Türk Tarihi,Cumhuriyet Tarihi kronoloji bölümleriyle  de tarih kavramada temel olan kronolojik bilgileri pratik bir şekilde kullanıcıya aktarmaya çalıştım.


Uygulama esas itibariyle bir web app olarak tasarlanmıştı. Ancak bu  pro serisiyle birlikte uygulama hibrit hale geldi.Sitede olmayan sadece Uygulamada olan tarihle ilgili  temel bilgilerinin öğrenilebilmesi için menuleriyle uygulama ileri bir seviyeye ulaşmış oldu.

 Uygulama her 10 yeni kullanıcı tarafından indirildikçe yeni vazifeleri ve işlevleri içine ekleyeceğim,inşaallah.

                            

9 Mart 2024 Cumartesi

Kotlinde Action Bar Rengini Değiştirme Nasıl Yapılır ?

 İlk iş olarak projemizde resource kısmında 

colors altbölümüne giderek aşağıdaki kodu içine yapıştırız.

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
<!-- Customize your theme here. -->
<!-- This code is for changing the color of the bar. -->
<!-- Type your colour code which you want to set in colorPrimary item -->
<item name="colorPrimary">#0F9D58</item>
<item name="colorPrimaryDark">#BAC9D8</item>
<item name="colorAccent">#151414</item>
</style>
<style name="AppTheme.NoActionBar">
<item name="windowActionBar">true</item>
<item name="windowNoTitle">true</item>
</style>
<!-- Define other styles to fix theme -->
<style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar" />
<style name="AppTheme.PopupOverlay" parent="ThemeOverlay.AppCompat.Light" />
Eğer ki bölümlerin adlarının otomatikmen görünmesini istiyorsak ilk satırdaki NoActionBar yerine Action Bar lı seçeneklerden birini seçiyoruz.
Kaynak dosyada belirlediğim renkler yerine istiyorsan renk seçimi yaparak bunları değiştirebilirsin.
Burdaki ayarları yaptıktan sonra AndroidManifest bölümünün içine gideriz. Orda application alt bölümün içinde android:theme= "......" aşağıdaki kodun olduğu yeri bulup onu silip yerine bunu yapıştırıyoruz.
android:theme="@style/AppTheme"
İstersen bunun yerine thema seçme yöntemiyle burdaki temayı bulup seçerek de bunu yapabiliriz.

Hepsi bu kadar.
Hayırlı kodlamalar dilerim.

8 Mart 2024 Cuma

Linear Layout Örneği

 <?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   
android:layout_width="match_parent"
   
android:layout_height="match_parent"
   
android:paddingLeft="16dp"
   
android:paddingRight="16dp"
   
android:orientation="vertical" >
Buraya içinde kullanacağınız öğeleri ekleyin.
</LinearLayout>


2 Mart 2024 Cumartesi

Text View Kullanımı

 Text View Kullanımı 

Attribute(Nitelik)Tanımı
android:textMetin buraya yazılır
android:textSizeBu özelliği kullanarak metnin boyutunu büyütme ve küçültmeye yarar.
android:textColorBu özelliği kullanarak metnimizin rengini seçeriz.
android:textAllCapsTrue ayarlanırsa, bu, metnin hepsinin büyük harfle görünmesini sağlar.
android:letterSpacingMetnin harfleri arasındaki boşluğu ayarlar.
android:textStyleYazının italik, normal veya bold yazı seçenekleriyle kullanılabilmesini sağlar
TextView içindeki yazıda alt satıra geçmek için  "   \n  " kullanırız.
Bunun dışındaki  özellikler Main Activity de veya hangi aktiviteye bağlı ise o aktivite içinde fonksiyon tanımlayarak gerçekleştirebiliriz.
Onlar ayrı bir yazının konusu olarak ileride gelecektir,inşaallah.

Kotlin Video Player

İlkin Manifest dosyasına aşağıdaki izinler eklenir


  1. <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>  
  2. <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>  
Ardından layout dosyasına aşağıdaki kod eklenir
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     xmlns:app="http://schemas.android.com/apk/res-auto"  
  4.     xmlns:tools="http://schemas.android.com/tools"  
  5.     android:layout_width="match_parent"  
  6.     android:layout_height="match_parent"  
  7.     tools:context="example.javatpoint.com.kotlinvideoplayer.MainActivity">  
  8.   
  9.     <FrameLayout  
  10.         android:layout_width="match_parent"  
  11.         android:layout_height="wrap_content">  
  12.   
  13.         <VideoView  
  14.             android:id="@+id/videoView"  
  15.             android:layout_width="wrap_content"  
  16.             android:layout_height="308dp"  
  17.             android:layout_marginBottom="0dp"  
  18.             android:layout_marginEnd="0dp"  
  19.             android:layout_marginStart="0dp"  
  20.             app:layout_constraintBottom_toBottomOf="parent"  
  21.             app:layout_constraintEnd_toEndOf="parent"  
  22.             app:layout_constraintHorizontal_bias="0.0"  
  23.             app:layout_constraintStart_toStartOf="parent"  
  24.             app:layout_constraintTop_toTopOf="parent"  
  25.             app:layout_constraintVertical_bias="1.0" />  
  26.     </FrameLayout>  
  27. </android.support.constraint.ConstraintLayout>  



Ardından Main Actity aşağıdaki şekle çevrilir
Üsttte kendi packet isminin altına şunları yapıştır
  1. import android.net.Uri  
  2. import android.net.Uri.*  
  3. import android.support.v7.app.AppCompatActivity  
  4. import android.os.Bundle  
  5. import android.os.Environment  
  6. import android.widget.MediaController  
  7. import android.widget.VideoView  
  8.   
  9. class MainActivity : AppCompatActivity() {  
  10.   
  11.     override fun onCreate(savedInstanceState: Bundle?) {  
  12.         super.onCreate(savedInstanceState)  
  13.         setContentView(R.layout.activity_main)  
  14.   
  15.         val videoView = findViewById<VideoView>(R.id.videoView)  
  16.         //Creating MediaController  
  17.         val mediaController = MediaController(this)  
  18.         mediaController.setAnchorView(videoView)  
  19.         //specify the location of media file  
  20.         val uri:Uri = parse(Environment.getExternalStorageDirectory().getPath() + "/Movies/video.mp4")  
  21.         //Setting MediaController and URI, then starting the videoView  
  22.         videoView.setMediaController(mediaController)  
  23.         videoView.setVideoURI(uri)  
  24.         videoView.requestFocus()  
  25.         videoView.start()  
  26.     }  
  27. }  





1 Mart 2024 Cuma

Kotlin Audio Converter Code

dependecies

 testImplementation(kotlin("test"))

    implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core:1.7.3")

    implementation("ws.schild:jave-all-deps:3.4.0")



import kotlinx.coroutines.*

import ws.schild.jave.Encoder

import ws.schild.jave.MultimediaObject

import ws.schild.jave.encode.AudioAttributes

import ws.schild.jave.encode.EncodingAttributes

import java.io.File

import kotlin.system.measureTimeMillis


class AudioConverter {

    suspend fun convertWavToMp3(inputDirectory: File, outputDirectory: File) = coroutineScope {

        launch {

            // Code in here won't block the main thread.

            outputDirectory.mkdirs()


            if (!inputDirectory.exists() || !inputDirectory.isDirectory) {

                println("Input directory does not exist or is not a directory.")

                return@launch

            }


            val files = inputDirectory.listFiles { file ->

                file.extension == "wav"

            } ?: arrayOf()


            val jobs = files.map { inputFile ->

                async(Dispatchers.IO) {

                    processFile(inputFile, outputDirectory)

                }

            }


            jobs.awaitAll()

        }

    }


    private fun createAudioAttributes(): AudioAttributes {

        val audioAttributes = AudioAttributes()

        audioAttributes.setCodec("libmp3lame")

        audioAttributes.setBitRate(128000) // 128 kbps

        audioAttributes.setChannels(2)

        audioAttributes.setSamplingRate(44100)

        return audioAttributes

    }


    private fun createEncodingAttributes(audioAttributes: AudioAttributes): EncodingAttributes {

        val encodingAttributes = EncodingAttributes()

        encodingAttributes.setOutputFormat("mp3")

        encodingAttributes.setAudioAttributes(audioAttributes)

        return encodingAttributes

    }


    private fun processFile(inputFile: File, outputDirectory: File) {

        try {

            val outputFileName = "${inputFile.nameWithoutExtension}.mp3"

            val outputFile = File(outputDirectory, outputFileName)


            val audioAttributes = createAudioAttributes()

            val encodingAttributes = createEncodingAttributes(audioAttributes)


            Encoder().encode(MultimediaObject(inputFile), outputFile, encodingAttributes)


        } catch (exception: Exception) {

            println("Error converting file ${inputFile.name}: ${exception.message}")

        }

    }

}


fun main() {

    runBlocking {

        println("What WAV files do you want to convert? (Path to directory):")

        val userInputForWAV = readLine().toString()

        println("Where would you like your MP3 files to end up? (Path to directory):")

        val userInputForMP3 = readLine().toString()


        val inputDirectoryPath = File(userInputForWAV)

        val outputDirectoryPath = File(userInputForMP3)


        val time = measureTimeMillis {

            AudioConverter().convertWavToMp3(inputDirectoryPath, outputDirectoryPath)

        }

        println("Completed in $time ms")

    }

}